@charset "UTF-8";
/* =========================================================================
   top-legitbtc.com  ·  vue-095
   Archetype: "Kraft Paper Stamp"
   크라프트 탄 종이 · 스탬프/도장 라벨 · 따뜻하고 수공예적
   라이트 전용 · comfortable density · radius 10px · hairline border · soft shadow
   이 한 장으로 홈 + 게시판목록 + 게시판본문 + 댓글 전부 담당
   ========================================================================= */

/* -------------------------------------------------------------------------
   :root — 토큰
   ------------------------------------------------------------------------- */
:root{
  /* 핵심 색(지정값 유지) */
  --bg:#f1ebe4;
  --surface:#f6f5f4;
  --surface-alt:#ece4d9;
  --text:#28221a;
  --muted:#7d6f5e;
  --border:#e4ded8;
  --hair:#eeebe7;
  --accent:#8f693d;
  --accent-dark:#725431;
  --accent-2:#4f9092;
  --accent-3:#8a9852;
  --on-accent:#ffffff;

  /* 보조(파생) */
  --accent-soft:#efe3d4;          /* 액센트 옅은 면 */
  --accent-2-soft:#dfecec;
  --accent-3-soft:#e8ecd9;
  --ink-soft:rgba(40,34,26,.06);
  --stamp:rgba(143,105,61,.55);   /* 스탬프 라인 */

  /* 폰트 */
  --font-head:"Bricolage Grotesque","Gowun Dodum",sans-serif;
  --font-body:"Pretendard","Apple SD Gothic Neo","Malgun Gothic",sans-serif;
  --font-mono:"Space Mono",ui-monospace,Consolas,monospace;

  /* 레이아웃 */
  --shell:1140px;
  --gap:24px;
  --radius:10px;
  --radius-sm:7px;
  --radius-lg:16px;

  /* 그림자(soft) */
  --shadow-sm:0 1px 2px rgba(60,46,30,.05);
  --shadow:0 6px 20px -12px rgba(60,46,30,.28), 0 2px 6px -4px rgba(60,46,30,.18);
  --shadow-lg:0 18px 44px -24px rgba(60,46,30,.42);

  /* hairline border helper */
  --line:1px solid var(--border);
  --line-hair:1px solid var(--hair);
}

/* -------------------------------------------------------------------------
   A) 전역
   ------------------------------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box;}

html{
  -webkit-text-size-adjust:100%;
  scroll-behavior:smooth;
}

body{
  margin:0;
  min-width:0;
  overflow-x:hidden;
  font-family:var(--font-body);
  font-size:15.5px;
  line-height:1.7;
  color:var(--text);
  background-color:var(--bg);
  /* 크라프트 종이 결: 아주 은은한 섬유 노이즈(단색 기반, 미세 도트) */
  background-image:
    radial-gradient(rgba(143,105,61,.045) 1px, transparent 1.4px),
    radial-gradient(rgba(79,144,146,.03) 1px, transparent 1.4px);
  background-size:18px 18px, 26px 26px;
  background-position:0 0, 9px 13px;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  word-break:keep-all;
}

img{max-width:100%;height:auto;display:block;}

a{color:var(--accent-dark);text-decoration:none;transition:color .15s ease;}
a:hover{color:var(--accent);}

h1,h2,h3,h4{
  font-family:var(--font-head);
  font-weight:700;
  line-height:1.25;
  color:var(--text);
  margin:0 0 .5em;
  letter-spacing:-.01em;
  word-break:keep-all;
}
h1{font-size:30px;}
h2{font-size:22px;}
h3{font-size:18px;}

p{margin:0 0 1em;}
ul{margin:0;padding:0;list-style:none;}

.mono{font-family:var(--font-mono);font-size:13px;letter-spacing:-.01em;}

/* 공통 컨테이너 */
.shell{
  width:100%;
  max-width:var(--shell);
  margin-inline:auto;
  padding-inline:20px;
}

/* 스킵 링크 */
.skip{
  position:absolute;
  left:-9999px;top:0;
  z-index:200;
  background:var(--accent);
  color:var(--on-accent);
  padding:10px 16px;
  border-radius:0 0 var(--radius) 0;
  font-weight:700;
}
.skip:focus{left:0;color:var(--on-accent);}

/* 포커스 가시성 */
:focus-visible{
  outline:2px solid var(--accent-2);
  outline-offset:2px;
  border-radius:3px;
}

/* 스크린리더 전용 */
.sr-only,.sound_only{
  position:absolute !important;
  width:1px;height:1px;
  padding:0;margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;border:0;
}

/* 메인 래퍼 */
#main{display:block;}
#main-content{min-width:0;}

/* 섹션 사이 간격 */
.layout > main > section,
.layout > div > section,
.view-feed > section{margin-bottom:36px;}

/* -------------------------------------------------------------------------
   B) 헤더 / 네비 / 푸터
   ------------------------------------------------------------------------- */
header.site{
  position:relative;
  background:var(--surface);
  border-bottom:1px solid var(--border);
  box-shadow:var(--shadow-sm);
}
/* 상단 크라프트 스티치 라인(시그니처) */
header.site::before{
  content:"";
  position:absolute;left:0;right:0;top:0;height:3px;
  background:
    repeating-linear-gradient(90deg,
      var(--accent) 0 14px, transparent 14px 24px);
  opacity:.7;
}

.topbar{
  display:flex;
  align-items:center;
  gap:18px;
  padding:16px 0;
}

/* 로고 */
.brand{
  display:inline-flex;
  align-items:center;
  gap:11px;
  color:var(--text);
  flex:0 0 auto;
}
.brand:hover{color:var(--text);}
.brand .mark{
  display:inline-grid;
  place-items:center;
  width:42px;height:42px;
  background:var(--accent-soft);
  border:1.5px solid var(--accent);
  border-radius:var(--radius);
  box-shadow:inset 0 0 0 2px var(--surface);
}
.brand .kicker{
  display:block;
  font-family:var(--font-mono);
  font-size:10px;
  letter-spacing:.18em;
  color:var(--accent);
  text-transform:uppercase;
}
.brand .name{
  display:block;
  font-family:var(--font-head);
  font-size:20px;
  font-weight:700;
  letter-spacing:-.015em;
}

/* 검색 폼 */
.search{
  flex:1 1 auto;
  display:flex;
  align-items:stretch;
  min-width:0;
  max-width:520px;
  margin-left:auto;
  background:var(--bg);
  border:1.5px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
  transition:border-color .15s ease, box-shadow .15s ease;
}
.search:focus-within{
  border-color:var(--accent);
  box-shadow:0 0 0 3px var(--accent-soft);
}
.search input[type="search"]{
  flex:1 1 auto;
  min-width:0;
  border:0;background:transparent;
  padding:11px 14px;
  font-family:var(--font-body);
  font-size:14px;
  color:var(--text);
}
.search input[type="search"]::placeholder{color:var(--muted);}
.search input[type="search"]:focus{outline:none;}
.search button{
  flex:0 0 auto;
  border:0;
  background:var(--accent);
  color:var(--on-accent);
  padding:0 16px;
  display:grid;place-items:center;
  cursor:pointer;
  transition:background .15s ease;
}
.search button:hover{background:var(--accent-dark);}

/* CTA 글쓰기 */
.cta{
  flex:0 0 auto;
  display:inline-flex;
  align-items:center;
  gap:7px;
  background:var(--accent-2);
  color:var(--on-accent);
  padding:11px 18px;
  border-radius:var(--radius);
  font-family:var(--font-head);
  font-weight:700;
  font-size:14px;
  border:1.5px solid transparent;
  box-shadow:var(--shadow-sm);
  transition:transform .12s ease, background .15s ease;
}
.cta:hover{color:var(--on-accent);background:#437b7d;transform:translateY(-1px);}
.cta svg path{stroke:var(--on-accent);}

/* 모바일 토글 */
.hamb{
  display:none;
  flex:0 0 auto;
  width:42px;height:42px;
  align-items:center;justify-content:center;
  background:var(--surface-alt);
  border:1.5px solid var(--border);
  border-radius:var(--radius);
  cursor:pointer;
}
.hamb svg path{stroke:var(--text);}

/* 주 네비 */
nav.main{
  background:var(--surface-alt);
  border-top:1px solid var(--hair);
}
nav.main ul{
  display:flex;
  flex-wrap:wrap;
  gap:4px;
}
nav.main li{display:block;}
nav.main a{
  display:block;
  padding:13px 18px;
  font-family:var(--font-head);
  font-weight:600;
  font-size:15px;
  color:var(--text);
  position:relative;
}
nav.main a:hover{color:var(--accent-dark);}
nav.main a.active{color:var(--accent-dark);}
nav.main a.active::after{
  content:"";
  position:absolute;left:18px;right:18px;bottom:6px;height:2px;
  background:var(--accent);
  border-radius:2px;
}

/* 푸터 */
footer.site{
  margin-top:56px;
  background:var(--surface-alt);
  border-top:1px solid var(--border);
  /* 하단 스티치 */
  background-image:
    repeating-linear-gradient(90deg,
      var(--accent) 0 12px, transparent 12px 22px);
  background-size:100% 3px;
  background-position:0 0;
  background-repeat:no-repeat;
}
footer.site .shell{padding-top:36px;padding-bottom:30px;}
.foot-grid{
  display:grid;
  grid-template-columns:1.6fr 1fr;
  gap:32px;
  align-items:start;
}
.ft-brand{
  font-family:var(--font-head);
  font-size:18px;
  font-weight:700;
  color:var(--text);
  margin:0 0 .5em;
}
.foot-grid p{
  font-size:13.5px;
  color:var(--muted);
  margin:0 0 .4em;
  line-height:1.65;
}
.foot-nav{
  display:flex;
  flex-wrap:wrap;
  gap:8px 18px;
}
.foot-nav a{
  font-family:var(--font-head);
  font-weight:600;
  font-size:14px;
  color:var(--text);
}
.foot-nav a:hover{color:var(--accent);}
.site-label{
  margin-top:24px;
  padding-top:16px;
  border-top:1px solid var(--border);
  display:flex;
  align-items:center;
  gap:7px;
  font-family:var(--font-mono);
  font-size:11.5px;
  letter-spacing:.02em;
  color:var(--muted);
}

/* -------------------------------------------------------------------------
   C) 홈
   ------------------------------------------------------------------------- */

/* 티커 스트립(시그니처) */
.ticker{
  background:var(--accent);
  color:var(--on-accent);
  border-bottom:1px solid var(--accent-dark);
}
.ticker-inner{
  display:flex;
  align-items:center;
  gap:16px;
  padding:9px 0;
  min-width:0;
}
.ticker-label{
  flex:0 0 auto;
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:.08em;
  text-transform:uppercase;
  padding:4px 10px;
  background:rgba(255,255,255,.16);
  border-radius:999px;
}
.ticker-label .lf path{fill:var(--on-accent);}
.ticker-vp{
  flex:1 1 auto;
  min-width:0;
  overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);
          mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);
}
.ticker-track{
  display:flex;
  align-items:center;
  gap:14px;
  white-space:nowrap;
  width:max-content;
  animation:tickerScroll 34s linear infinite;
}
.ticker-item a{
  color:var(--on-accent);
  font-size:13.5px;
  font-weight:500;
}
.ticker-item a:hover{text-decoration:underline;}
.leaf-sep{flex:0 0 auto;opacity:.7;}
.leaf-sep path{fill:var(--on-accent) !important;}
@keyframes tickerScroll{
  from{transform:translateX(0);}
  to{transform:translateX(-50%);}
}

/* 메인+사이드 레이아웃 */
.layout{
  display:grid;
  grid-template-columns:minmax(0,1fr) 320px;
  gap:var(--gap);
  align-items:start;
  padding-top:32px;
}
.layout > main,
.layout > div:first-child{min-width:0;}

/* 히어로 */
.hero{
  position:relative;
  background:var(--surface);
  border:1.5px solid var(--border);
  border-radius:var(--radius-lg);
  padding:34px 34px 30px;
  box-shadow:var(--shadow);
  overflow:hidden;
}
/* 도장 라벨 워터마크(시그니처) */
.hero::after{
  content:"WELLNESS";
  position:absolute;
  right:-10px;top:18px;
  font-family:var(--font-mono);
  font-size:80px;
  font-weight:700;
  letter-spacing:.04em;
  color:var(--stamp);
  opacity:.07;
  transform:rotate(-6deg);
  pointer-events:none;
}
.hero::before{
  content:"";
  position:absolute;left:0;top:0;bottom:0;width:5px;
  background:var(--accent-3);
}
.en-kicker{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--accent);
  margin:0 0 12px;
}
.hero h1{
  font-size:34px;
  margin:0 0 14px;
  max-width:24ch;
}
.lead{
  font-size:16px;
  color:var(--muted);
  line-height:1.75;
  max-width:62ch;
  margin:0 0 18px;
}
.meta-row{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

/* 스탬프 뱃지 */
.badge{
  display:inline-flex;
  align-items:center;
  gap:5px;
  font-family:var(--font-mono);
  font-size:11.5px;
  letter-spacing:.02em;
  color:var(--accent-dark);
  background:var(--accent-soft);
  border:1.5px dashed var(--accent);
  border-radius:var(--radius-sm);
  padding:5px 11px;
}
.badge .lf path{fill:var(--accent-3);}
.badge.warn{
  color:#7a5a1f;
  background:#f4ead6;
  border-color:#c79a4d;
}

/* 섹션 헤더 */
.sec-head,.section-head{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:14px;
  margin:0 0 16px;
  padding-bottom:10px;
  border-bottom:2px solid var(--text);
  position:relative;
}
.sec-head h2,.section-head h1,.section-head h2{
  margin:0;
  font-size:21px;
  position:relative;
  padding-left:14px;
}
/* 도장 점(시그니처 라벨 마커) */
.sec-head h2::before,.section-head h1::before,.section-head h2::before{
  content:"";
  position:absolute;left:0;top:.18em;
  width:8px;height:8px;
  background:var(--accent);
  border-radius:2px;
  transform:rotate(45deg);
}
.section-head .mono{
  flex:0 0 auto;
  color:var(--muted);
}
.more{
  flex:0 0 auto;
  font-family:var(--font-head);
  font-size:13.5px;
  font-weight:600;
  color:var(--accent-dark);
  white-space:nowrap;
}
.more:hover{color:var(--accent);}

/* 게시판 행 리스트 */
.board{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
}
.rows > li{
  display:flex;
  align-items:center;
  gap:14px;
  padding:13px 18px;
  border-bottom:1px solid var(--hair);
  transition:background .12s ease;
}
.rows > li:last-child{border-bottom:0;}
.rows > li:hover{background:var(--accent-soft);}
.rnum{
  flex:0 0 auto;
  width:34px;
  font-family:var(--font-mono);
  font-size:12px;
  color:var(--muted);
  text-align:center;
}
.rtitle{
  flex:1 1 auto;
  min-width:0;
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}
.rtitle a{
  color:var(--text);
  font-weight:500;
  font-size:15px;
  overflow:hidden;
  text-overflow:ellipsis;
}
.rtitle a:hover{color:var(--accent-dark);}
.rcat{
  flex:0 0 auto;
  font-family:var(--font-mono);
  font-size:10.5px;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:var(--accent-2);
  background:var(--accent-2-soft);
  border-radius:var(--radius-sm);
  padding:2px 8px;
}
.cmt{
  flex:0 0 auto;
  font-family:var(--font-mono);
  font-size:12px;
  font-weight:700;
  color:var(--accent);
}
.rmeta{
  flex:0 0 auto;
  display:flex;
  align-items:center;
  gap:12px;
  font-size:12.5px;
  color:var(--muted);
}
.rmeta .au{color:var(--text);font-weight:500;}

/* 갤러리 / 카드 그리드 */
.gallery{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:var(--gap);
}
.card{
  display:flex;
  flex-direction:column;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:transform .14s ease, box-shadow .14s ease, border-color .14s ease;
}
.card:hover{
  transform:translateY(-3px);
  box-shadow:var(--shadow);
  border-color:var(--accent);
}
.card .thumb{
  position:relative;
  aspect-ratio:4/3;
  background:var(--surface-alt);
  overflow:hidden;
}
.card .thumb img{
  width:100%;height:100%;
  object-fit:cover;
  transition:transform .3s ease;
}
.card:hover .thumb img{transform:scale(1.04);}
.card .body{
  flex:1 1 auto;
  display:flex;
  flex-direction:column;
  gap:8px;
  padding:15px 16px 16px;
}
.card .body .rcat{align-self:flex-start;}
.card .body h3{
  margin:0;
  font-size:16px;
  line-height:1.4;
}
.card .body h3 a{color:var(--text);}
.card .body h3 a:hover{color:var(--accent-dark);}
.card .cmeta{
  margin-top:auto;
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:10px;
  font-size:12px;
  color:var(--muted);
  padding-top:8px;
  border-top:1px solid var(--hair);
}
.card .cmeta .au{color:var(--text);font-weight:500;}
.card .cmeta .cmt{margin-left:auto;}

/* 추천글 그리드(ul.gallery 형태) */
ul.gallery > li{display:block;}
ul.gallery > li > .card{height:100%;}

/* 사이드 레일 */
aside.rail{
  display:flex;
  flex-direction:column;
  gap:var(--gap);
  min-width:0;
}
.widget{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:18px 18px 20px;
  box-shadow:var(--shadow-sm);
}
.widget h2{
  display:flex;
  align-items:center;
  gap:7px;
  margin:0 0 14px;
  padding-bottom:10px;
  font-size:15px;
  border-bottom:1.5px solid var(--surface-alt);
}
.widget h2 svg path{fill:var(--accent-3);}

/* 랭크 리스트 */
.ranklist > li{
  display:flex;
  align-items:center;
  gap:11px;
  padding:8px 0;
  border-bottom:1px solid var(--hair);
}
.ranklist > li:last-child{border-bottom:0;}
.rk{
  flex:0 0 auto;
  display:grid;place-items:center;
  width:24px;height:24px;
  font-family:var(--font-mono);
  font-size:12px;
  font-weight:700;
  color:var(--muted);
  background:var(--surface-alt);
  border-radius:var(--radius-sm);
}
.ranklist > li:nth-child(1) .rk{background:var(--accent);color:var(--on-accent);}
.ranklist > li:nth-child(2) .rk{background:var(--accent-2);color:var(--on-accent);}
.ranklist > li:nth-child(3) .rk{background:var(--accent-3);color:var(--on-accent);}
.ranklist > li a{
  flex:1 1 auto;
  min-width:0;
  color:var(--text);
  font-size:14px;
  line-height:1.45;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.ranklist > li a:hover{color:var(--accent-dark);}

/* 태그 칩 */
.tagcloud{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.chip{
  display:inline-block;
  font-family:var(--font-head);
  font-size:13px;
  font-weight:600;
  color:var(--accent-dark);
  background:var(--accent-soft);
  border:1px solid var(--border);
  border-radius:999px;
  padding:6px 13px;
  transition:background .14s ease, color .14s ease;
}
.chip:hover{background:var(--accent);color:var(--on-accent);border-color:var(--accent);}

/* 오늘의 잎 한 줄 */
.leaf-tip{
  display:flex;
  align-items:flex-start;
  gap:11px;
  background:var(--accent-3-soft);
  border:1px dashed var(--accent-3);
  border-radius:var(--radius-sm);
  padding:14px 15px;
}
.leaf-tip svg{flex:0 0 auto;margin-top:2px;}
.leaf-tip span{
  font-size:13.5px;
  line-height:1.65;
  color:var(--text);
}

/* -------------------------------------------------------------------------
   D) 게시판 목록 (list.skin.php 고유 요소)
   ------------------------------------------------------------------------- */

/* 페이저 */
.pager{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  align-items:center;
  gap:6px;
  margin:26px 0 8px;
}
.pager a,.pager span,
.pager strong{
  display:inline-grid;
  place-items:center;
  min-width:38px;height:38px;
  padding:0 11px;
  font-family:var(--font-mono);
  font-size:13px;
  color:var(--text);
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  transition:all .14s ease;
}
.pager a:hover{
  background:var(--accent-soft);
  border-color:var(--accent);
  color:var(--accent-dark);
}
.pager .cur,
.pager strong,
.pager .sound_only + a[aria-current],
.pager span.cur{
  background:var(--accent);
  border-color:var(--accent);
  color:var(--on-accent);
  font-weight:700;
}
.pager .edge{font-weight:700;}

/* 그누보드 코어 페이지네이션 폴백 */
.pg_page,.pg_current{
  display:inline-grid;place-items:center;
  min-width:38px;height:38px;padding:0 11px;margin:0 2px;
  font-family:var(--font-mono);font-size:13px;
  border:1px solid var(--border);border-radius:var(--radius-sm);
  background:var(--surface);color:var(--text);
}
.pg_current{background:var(--accent);border-color:var(--accent);color:var(--on-accent);font-weight:700;}
.pg{display:flex;flex-wrap:wrap;justify-content:center;gap:4px;margin:26px 0 8px;}

/* 게시판 하단 액션 + 검색 폼 */
.board-actions{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  margin-top:24px;
  padding-top:20px;
  border-top:1px solid var(--border);
}
.board-search{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:8px;
  min-width:0;
}
.board-search select,
.board-search input[type="text"]{
  font-family:var(--font-body);
  font-size:14px;
  color:var(--text);
  background:var(--surface);
  border:1.5px solid var(--border);
  border-radius:var(--radius-sm);
  padding:9px 12px;
  transition:border-color .14s ease, box-shadow .14s ease;
}
.board-search select{cursor:pointer;}
.board-search input[type="text"]{min-width:0;flex:1 1 180px;}
.board-search select:focus,
.board-search input[type="text"]:focus{
  outline:none;
  border-color:var(--accent);
  box-shadow:0 0 0 3px var(--accent-soft);
}

/* 버튼 공통 */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  font-family:var(--font-head);
  font-weight:700;
  font-size:14px;
  line-height:1;
  padding:11px 18px;
  border-radius:var(--radius-sm);
  border:1.5px solid transparent;
  cursor:pointer;
  text-align:center;
  transition:transform .12s ease, background .14s ease, color .14s ease, border-color .14s ease;
}
.btn:hover{transform:translateY(-1px);}
.btn-primary{
  background:var(--accent);
  color:var(--on-accent);
  border-color:var(--accent);
}
.btn-primary:hover{background:var(--accent-dark);color:var(--on-accent);border-color:var(--accent-dark);}
.btn-secondary{
  background:var(--surface);
  color:var(--accent-dark);
  border-color:var(--accent);
}
.btn-secondary:hover{background:var(--accent-soft);color:var(--accent-dark);}

/* -------------------------------------------------------------------------
   E) 게시판 본문 (view.skin.php)
   ------------------------------------------------------------------------- */

/* 본문 페이지 2단 레이아웃 */
.view-layout{
  display:grid;
  grid-template-columns:minmax(0,1fr) 320px;
  gap:var(--gap);
  align-items:start;
  padding-top:32px;
}
.view-feed{min-width:0;}
.view-feed > section{margin-top:36px;}

.hm-board-view{
  background:var(--surface);
  border:1.5px solid var(--border);
  border-radius:var(--radius-lg);
  padding:34px 34px 28px;
  box-shadow:var(--shadow);
  overflow:hidden;
}

/* 본문 헤더 */
.hm-view-head{
  position:relative;
  padding-bottom:18px;
  margin-bottom:24px;
  border-bottom:2px solid var(--text);
}
.hm-board-kicker{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--accent);
  margin:0 0 10px;
}
.hm-view-head h1{
  font-size:28px;
  line-height:1.3;
  margin:0 0 14px;
}
.hm-view-meta{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:14px;
  font-size:13px;
  color:var(--muted);
}
.hm-view-meta span:first-child{
  color:var(--accent-dark);
  font-weight:600;
}
.hm-view-meta span{
  display:inline-flex;
  align-items:center;
}
.hm-view-meta span + span::before{
  content:"·";
  margin-right:14px;
  color:var(--border);
}

/* 첨부파일 */
.hm-view-files{
  display:flex;
  flex-direction:column;
  gap:8px;
  margin:0 0 24px;
  padding:16px 18px;
  background:var(--surface-alt);
  border:1px dashed var(--accent);
  border-radius:var(--radius);
}
.hm-view-files a{
  display:flex;
  align-items:center;
  gap:10px;
  font-size:14px;
  color:var(--accent-dark);
  font-weight:500;
}
.hm-view-files a::before{
  content:"⬇";
  font-size:13px;
  color:var(--accent);
}
.hm-view-files a span{
  font-family:var(--font-mono);
  font-size:11.5px;
  color:var(--muted);
}

/* 본문 컨텐츠 */
.hm-view-content{
  font-size:16px;
  line-height:1.85;
  color:var(--text);
  padding:6px 0 12px;
  min-width:0;
  overflow-wrap:break-word;
}
.hm-view-content p{margin:0 0 1.25em;}
.hm-view-content h1,
.hm-view-content h2,
.hm-view-content h3{margin:1.5em 0 .6em;}
.hm-view-content h2{font-size:21px;}
.hm-view-content h3{font-size:18px;}
.hm-view-content img{
  height:auto;
  border-radius:var(--radius);
  margin:1.2em auto;
  box-shadow:var(--shadow-sm);
}
.hm-view-content a{
  color:var(--accent-dark);
  text-decoration:underline;
  text-underline-offset:2px;
}
.hm-view-content a:hover{color:var(--accent);}
.hm-view-content blockquote{
  margin:1.4em 0;
  padding:12px 18px;
  background:var(--accent-3-soft);
  border-left:4px solid var(--accent-3);
  border-radius:0 var(--radius-sm) var(--radius-sm) 0;
  color:var(--text);
}
.hm-view-content ul,
.hm-view-content ol{
  margin:0 0 1.25em;
  padding-left:1.4em;
}
.hm-view-content ul li{list-style:disc;margin:.3em 0;}
.hm-view-content ol li{list-style:decimal;margin:.3em 0;}
.hm-view-content table{
  width:100%;
  border-collapse:collapse;
  margin:1.2em 0;
  font-size:14px;
}
.hm-view-content th,
.hm-view-content td{
  border:1px solid var(--border);
  padding:9px 12px;
  text-align:left;
}
.hm-view-content th{background:var(--surface-alt);font-weight:700;}

/* 추천/비추천 */
.hm-view-vote{
  display:flex;
  justify-content:center;
  gap:12px;
  margin:24px 0;
}
.hm-view-vote a{
  display:inline-flex;
  align-items:center;
  gap:7px;
  font-family:var(--font-head);
  font-weight:700;
  font-size:14px;
  color:var(--accent-dark);
  background:var(--surface);
  border:1.5px solid var(--accent);
  border-radius:999px;
  padding:10px 22px;
  transition:background .14s ease, color .14s ease, transform .12s ease;
}
.hm-view-vote a:hover{
  background:var(--accent);
  color:var(--on-accent);
  transform:translateY(-1px);
}

/* 이전/다음 글 */
.hm-view-neighbor{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  margin:28px 0 0;
}
.hm-view-neighbor a{
  display:flex;
  flex-direction:column;
  gap:5px;
  padding:14px 16px;
  background:var(--surface-alt);
  border:1px solid var(--border);
  border-radius:var(--radius);
  transition:border-color .14s ease, background .14s ease;
}
.hm-view-neighbor a:hover{border-color:var(--accent);background:var(--accent-soft);}
.hm-view-neighbor a span{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:.05em;
  text-transform:uppercase;
  color:var(--accent);
}
.hm-view-neighbor a strong{
  font-family:var(--font-body);
  font-weight:500;
  font-size:14px;
  color:var(--text);
  line-height:1.45;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}

/* 본문 하단 액션 */
.hm-view-actions{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:28px;
  padding-top:22px;
  border-top:1px solid var(--border);
}
.hm-view-actions a{
  display:inline-flex;
  align-items:center;
  font-family:var(--font-head);
  font-weight:600;
  font-size:14px;
  color:var(--text);
  background:var(--surface);
  border:1.5px solid var(--border);
  border-radius:var(--radius-sm);
  padding:9px 18px;
  transition:all .14s ease;
}
.hm-view-actions a:hover{
  border-color:var(--accent);
  color:var(--accent-dark);
  background:var(--accent-soft);
}
.hm-view-actions a.is-primary{
  margin-left:auto;
  background:var(--accent);
  color:var(--on-accent);
  border-color:var(--accent);
}
.hm-view-actions a.is-primary:hover{background:var(--accent-dark);color:var(--on-accent);}

/* -------------------------------------------------------------------------
   F) 댓글 (view_comment.skin.php + 코어 #bo_vc / #bo_vc_w)
   ------------------------------------------------------------------------- */

/* 댓글 토글 버튼 */
.cmt_btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin:28px 0 0;
  font-family:var(--font-head);
  font-weight:700;
  font-size:15px;
  color:var(--text);
  background:var(--surface-alt);
  border:1.5px solid var(--border);
  border-radius:999px;
  padding:9px 18px;
  cursor:pointer;
  transition:border-color .14s ease, background .14s ease;
}
.cmt_btn:hover{border-color:var(--accent);background:var(--accent-soft);}
.cmt_btn .total b{color:var(--accent-dark);}
.cmt_btn .cmt_more::after{content:"펼치기";font-family:var(--font-mono);font-size:11px;color:var(--muted);}
.cmt_btn.cmt_btn_op .cmt_more::after{content:"접기";}

/* 댓글 목록 컨테이너 */
#bo_vc{
  margin:18px 0 0;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:8px 22px 10px;
  box-shadow:var(--shadow-sm);
}
#bo_vc > h2{
  font-size:15px;
  padding:14px 0 12px;
  margin:0 0 4px;
  border-bottom:2px solid var(--surface-alt);
}

/* 댓글 항목 */
#bo_vc article{
  display:flex;
  gap:13px;
  padding:18px 0;
  border-top:1px solid var(--hair);
}
#bo_vc article:first-of-type{border-top:0;}
.pf_img{flex:0 0 auto;}
.pf_img img{
  width:42px;height:42px;
  border-radius:999px;
  border:1.5px solid var(--border);
  background:var(--surface-alt);
  object-fit:cover;
}
.cm_wrap{flex:1 1 auto;min-width:0;}
#bo_vc article header{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:6px 10px;
  margin-bottom:7px;
}
#bo_vc article header h2{
  font-family:var(--font-head);
  font-size:14px;
  font-weight:700;
  color:var(--accent-dark);
  margin:0;
}
.bo_vc_hdinfo{
  font-family:var(--font-mono);
  font-size:11.5px;
  color:var(--muted);
}
.bo_vc_hdinfo time{color:var(--muted);}

/* 댓글 본문 */
.cmt_contents{
  font-size:14.5px;
  line-height:1.7;
  color:var(--text);
}
.cmt_contents p{margin:0;overflow-wrap:break-word;}
.cmt_contents img{display:inline;vertical-align:middle;}

/* 댓글 옵션 */
.bo_vl_opt{position:relative;flex:0 0 auto;}
.btn_cm_opt{
  width:30px;height:30px;
  display:grid;place-items:center;
  background:transparent;
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  color:var(--muted);
  cursor:pointer;
  transition:border-color .14s ease, color .14s ease;
}
.btn_cm_opt:hover{border-color:var(--accent);color:var(--accent-dark);}
.bo_vc_act{
  display:none;
  position:absolute;right:0;top:34px;
  z-index:30;
  min-width:96px;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  box-shadow:var(--shadow);
  padding:5px;
}
.bo_vc_act li{display:block;}
.bo_vc_act a{
  display:block;
  padding:7px 12px;
  font-size:13px;
  color:var(--text);
  border-radius:5px;
}
.bo_vc_act a:hover{background:var(--accent-soft);color:var(--accent-dark);}

/* 답변/수정 인라인 슬롯 */
.bo_vc_w{display:block;}
span.bo_vc_w:empty{display:none;}

/* 빈 댓글 */
#bo_vc_empty{
  text-align:center;
  color:var(--muted);
  font-size:14px;
  padding:26px 0;
  margin:0;
}

/* 댓글 작성 폼 */
#bo_vc_w{
  margin:18px 0 0;
  background:var(--surface);
  border:1.5px solid var(--border);
  border-radius:var(--radius);
  padding:20px 22px 22px;
  box-shadow:var(--shadow-sm);
}
#bo_vc_w > h2{
  font-size:15px;
  margin:0 0 12px;
}
#bo_vc_w #char_cnt,
#bo_vc_w strong#char_cnt{
  display:inline-block;
  font-family:var(--font-mono);
  font-size:11.5px;
  color:var(--muted);
  margin-bottom:6px;
}
#fviewcomment textarea,
#bo_vc_w textarea#wr_content{
  width:100%;
  min-height:96px;
  resize:vertical;
  font-family:var(--font-body);
  font-size:14.5px;
  line-height:1.65;
  color:var(--text);
  background:var(--bg);
  border:1.5px solid var(--border);
  border-radius:var(--radius-sm);
  padding:12px 14px;
  transition:border-color .14s ease, box-shadow .14s ease;
}
#fviewcomment textarea:focus,
#bo_vc_w textarea#wr_content:focus{
  outline:none;
  border-color:var(--accent);
  box-shadow:0 0 0 3px var(--accent-soft);
}
.bo_vc_w_wr{
  display:flex;
  flex-wrap:wrap;
  align-items:flex-end;
  justify-content:space-between;
  gap:14px;
  margin-top:12px;
}
.bo_vc_w_info{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:10px;
  min-width:0;
}
.frm_input{
  font-family:var(--font-body);
  font-size:14px;
  color:var(--text);
  background:var(--surface);
  border:1.5px solid var(--border);
  border-radius:var(--radius-sm);
  padding:9px 12px;
  max-width:170px;
}
.frm_input:focus{
  outline:none;
  border-color:var(--accent);
  box-shadow:0 0 0 3px var(--accent-soft);
}
.btn_confirm{
  display:flex;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
}
.secret_cm{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:13px;
  color:var(--muted);
}
.secret_cm input[type="checkbox"]{
  width:16px;height:16px;
  accent-color:var(--accent);
}
.secret_cm label{cursor:pointer;display:inline-flex;align-items:center;gap:5px;}
.btn_submit{
  font-family:var(--font-head);
  font-weight:700;
  font-size:14px;
  color:var(--on-accent);
  background:var(--accent);
  border:1.5px solid var(--accent);
  border-radius:var(--radius-sm);
  padding:11px 24px;
  cursor:pointer;
  transition:background .14s ease, transform .12s ease;
}
.btn_submit:hover{background:var(--accent-dark);transform:translateY(-1px);}
.btn_submit:disabled{opacity:.55;cursor:not-allowed;transform:none;}

/* 댓글 영역 캡차 정렬 */
#bo_vc_w #captcha,
#bo_vc_w .captcha{margin:4px 0;}

/* =========================================================================
   반응형 (5단계 + reduced-motion)
   ========================================================================= */

/* FHD */
@media (min-width:1600px){
  :root{--shell:1340px;}
  .hero h1{font-size:38px;}
  h1{font-size:33px;}
}

/* QHD */
@media (min-width:2400px){
  :root{--shell:1680px;}
  body{font-size:17px;}
  .hero h1{font-size:44px;}
  .gallery{grid-template-columns:repeat(4,minmax(0,1fr));}
}

/* 태블릿 가로 — 사이드를 가로 위젯 행으로 */
@media (max-width:1024px){
  .layout,
  .view-layout{grid-template-columns:minmax(0,1fr);}
  aside.rail{
    flex-direction:row;
    flex-wrap:wrap;
    width:100%;
  }
  aside.rail .widget{flex:1 1 280px;}
  .gallery{grid-template-columns:repeat(2,minmax(0,1fr));}
}

/* 태블릿 세로 / 모바일 토글 */
@media (max-width:768px){
  h1{font-size:26px;}
  .hero{padding:26px 22px 24px;}
  .hero h1{font-size:27px;}
  .hero::after{font-size:56px;}

  .topbar{
    flex-wrap:wrap;
    gap:12px;
  }
  .brand{order:1;}
  .cta{order:2;margin-left:auto;}
  .hamb{display:inline-flex;order:3;}
  .search{
    order:4;
    flex:1 1 100%;
    max-width:none;
    margin-left:0;
  }

  /* 데스크탑 가로 네비 → 토글 */
  nav.main{display:none;}
  nav.main.open{
    display:block;
    position:fixed;
    inset:0;
    z-index:120;
    background:var(--bg);
    padding:24px 20px 40px;
    overflow-y:auto;
    border-top:0;
  }
  nav.main.open .shell{padding-inline:0;}
  nav.main.open ul{
    flex-direction:column;
    gap:6px;
    margin-top:8px;
  }
  nav.main.open a{
    padding:15px 16px;
    font-size:18px;
    background:var(--surface);
    border:1px solid var(--border);
    border-radius:var(--radius);
  }
  nav.main.open a.active::after{display:none;}
  nav.main.open a.active{
    background:var(--accent-soft);
    border-color:var(--accent);
  }

  .gallery{grid-template-columns:repeat(2,minmax(0,1fr));}
  .hm-board-view{padding:24px 20px 22px;}
  .hm-view-head h1{font-size:24px;}
  .hm-view-content{font-size:15.5px;}
  .hm-view-neighbor{grid-template-columns:1fr;}
  .board-actions{flex-direction:column;align-items:stretch;}
  .board-search{width:100%;}
  .board-search input[type="text"]{flex:1 1 auto;}
  .rmeta{gap:9px;font-size:11.5px;}
}

/* 모바일 */
@media (max-width:480px){
  body{font-size:15px;}
  .shell{padding-inline:15px;}

  .gallery{grid-template-columns:minmax(0,1fr);}

  .rows > li{
    flex-wrap:wrap;
    gap:6px 10px;
    padding:12px 14px;
  }
  .rnum{display:none;}
  .rtitle{flex:1 1 100%;}
  .rmeta{flex:1 1 100%;gap:10px;}

  /* 사이드 위젯 1열로 복귀 */
  aside.rail{flex-direction:column;}
  aside.rail .widget{flex:1 1 auto;}

  .ticker-inner{gap:10px;}
  .ticker-label{font-size:10px;padding:3px 8px;}

  .hero::after{display:none;}
  .hm-board-view{padding:20px 15px 18px;}
  #bo_vc{padding:6px 15px 8px;}
  #bo_vc_w{padding:16px 15px 18px;}
  .frm_input{max-width:none;flex:1 1 100%;}
  .bo_vc_w_wr{flex-direction:column;align-items:stretch;}
  .btn_confirm{justify-content:space-between;}

  .meta-row{gap:7px;}
  .badge{font-size:10.5px;padding:4px 9px;}

  /* 칩 스트립: 가로 스크롤 */
  .tagcloud{
    flex-wrap:nowrap;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    padding-bottom:4px;
  }
  .chip{flex:0 0 auto;}

  .hm-view-actions{gap:6px;}
  .hm-view-actions a{padding:9px 14px;font-size:13px;}
}

/* 모션 최소화 */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.001ms !important;
    scroll-behavior:auto !important;
  }
  .ticker-track{animation:none;}
  .card:hover{transform:none;}
  .card:hover .thumb img{transform:none;}
}
