/* Theme: Sunset Gradient Wander (site 046 — juicyburlesque.com) — from design-system sample */
:root{
  --background:#FCF3EC; --surface:#FEFCFA; --surface-alt:#E8E5F6;
  --text:#15142A; --muted:#505672; --border:#BFB8DF;
  --accent:#9D4516; --accent-2:#3A29A3; --accent-3:#317354;
  --horizon-ink:#0E0D20; --danger:#B83329;
  --horizon:linear-gradient(90deg,hsl(21 80% 56%) 0%,hsl(11 78% 52%) 26%,hsl(330 56% 52%) 58%,hsl(251 58% 48%) 100%);
  --font-body:"Gowun Dodum",Pretendard,"Malgun Gothic",sans-serif;
  --font-display:"Outfit","Gowun Dodum",sans-serif;
  --font-mono:"IBM Plex Mono",ui-monospace,monospace;
  --ease:cubic-bezier(0.22,1,0.36,1);
  --feed:620px;
  --s1:4px; --s2:8px; --s3:16px; --s4:24px; --s5:32px; --s6:48px; --s7:64px;
}
*{box-sizing:border-box;}
html,body{margin:0;}
body{
  background:var(--background); color:var(--text);
  font-family:var(--font-body); font-size:16px; line-height:1.7;
  letter-spacing:-0.005em; -webkit-text-size-adjust:100%;
  overflow-x:hidden;
}
a{color:var(--accent); text-decoration:none;}
a:hover{text-decoration:underline;}
a:visited{color:var(--accent-2);}
:focus-visible{outline:2px solid var(--accent-2); outline-offset:2px;}
img,svg{display:block; max-width:100%;}
.feed-col{max-width:var(--feed); margin-inline:auto; padding-inline:var(--s3);}
.horizon-band{height:3px; background:var(--horizon);}
.skip{position:absolute; left:-999px; top:0;}
.skip:focus{left:8px; top:8px; z-index:50; background:var(--surface); color:var(--accent);
  padding:8px 12px; border:1px solid var(--border);}

/* ---------- HEADER (2-row center logo, row1 = horizon band) ---------- */
.site-header{background:var(--surface); border-bottom:1px solid var(--border);}
.hb-row{height:56px; background:var(--horizon); display:flex; align-items:center; justify-content:center;}
.hb-logo{font-family:var(--font-display); font-weight:600; font-size:22px; letter-spacing:0.02em;
  color:#fff; text-shadow:0 1px 0 rgba(14,13,32,.4);}
.hb-logo .mono{font-family:var(--font-mono); font-size:13px; opacity:.92; margin-left:6px;}
.nav-row{display:flex; align-items:center; justify-content:space-between; gap:var(--s3);
  min-height:52px; padding-block:var(--s2); position:relative;}
.nav-row nav{display:flex; gap:var(--s1);}
.nav-row nav a{font-family:var(--font-display); font-weight:500; font-size:13px;
  text-transform:uppercase; letter-spacing:0.04em; color:var(--text);
  padding:10px 12px; min-height:44px; display:inline-flex; align-items:center;
  border-bottom:2px solid transparent; transition:background .16s var(--ease),color .16s var(--ease);}
.nav-row nav a:hover{background:var(--surface-alt); text-decoration:none;}
.nav-row nav a[aria-current="page"]{color:var(--accent); border-bottom-color:var(--accent);}
.search{display:flex; align-items:center; gap:var(--s2);}
.search input{font-family:var(--font-body); font-size:14px; color:var(--text);
  background:var(--surface); border:1px solid var(--border); border-radius:2px;
  padding:10px 12px; min-height:44px; width:160px; transition:border-color .16s var(--ease);}
.search input::placeholder{color:var(--muted);}
.search input:focus{border-color:var(--accent); border-bottom-width:2px; outline:none;}
.menu-toggle{display:none;}

/* ---------- POPULAR GALLERY STRIP (horizontal scroll snap) ---------- */
.strip-sec{padding-block:var(--s5) 0;}
.strip-head{display:flex; align-items:baseline; justify-content:space-between; margin-bottom:var(--s3);}
.strip-head h2{font-family:var(--font-body); font-weight:700; font-size:25px; line-height:1.25; margin:0;}
.strip-head .more{font-family:var(--font-display); font-size:13px; text-transform:uppercase; letter-spacing:0.04em;}
.strip{display:flex; gap:var(--s3); overflow-x:auto; scroll-snap-type:x mandatory;
  padding-bottom:var(--s2); scrollbar-width:none; -ms-overflow-style:none;}
.strip::-webkit-scrollbar{display:none;}
.mini{flex:0 0 220px; scroll-snap-align:start; background:var(--surface);
  border:1px solid var(--border); border-radius:2px; box-shadow:0 1px 0 hsl(251 34% 78%);
  overflow:hidden; position:relative;}
.corner-label{position:absolute; top:12px; right:-30px; transform:rotate(45deg);
  background:var(--accent-2); color:#fff; font-family:var(--font-display); font-weight:500;
  font-size:11px; letter-spacing:0.02em; padding:3px 34px; z-index:2;
  transition:transform .16s var(--ease);}
.mini:hover .corner-label{transform:rotate(45deg) scale(1.02);}
.thumb{aspect-ratio:4/3; width:100%; height:auto;}
.mini-body{padding:var(--s3);}
.mini-body h3{font-family:var(--font-body); font-weight:700; font-size:16px; line-height:1.3; margin:0 0 var(--s2);}
.mini-body h3 a{color:var(--accent);}
.mini-meta{font-family:var(--font-mono); font-size:13px; color:var(--muted);}

/* ---------- STICKY FILTER CHIPS ---------- */
.chipbar-wrap{position:sticky; top:0; z-index:20; background:var(--surface);
  border-bottom:1px solid var(--border); margin-top:var(--s5);}
.chipbar{display:flex; gap:var(--s2); overflow-x:auto; padding-block:var(--s2);
  scrollbar-width:none; -ms-overflow-style:none;}
.chipbar::-webkit-scrollbar{display:none;}
.chip{flex:0 0 auto; font-family:var(--font-display); font-weight:500; font-size:13px;
  letter-spacing:0.02em; background:var(--surface); border:1px solid var(--border);
  color:var(--text); border-radius:2px; padding:10px 16px; min-height:44px;
  cursor:pointer; transition:background .16s var(--ease),color .16s var(--ease);}
.chip:hover{background:var(--surface-alt);}
.chip[aria-pressed="true"]{background:var(--accent); color:#fff; border-color:var(--accent);}

/* ---------- FEED (single 1-col card timeline) ---------- */
.feed{padding-block:var(--s5) var(--s6); display:flex; flex-direction:column; gap:var(--s4);}
.post{background:var(--surface); border:1px solid var(--border); border-radius:2px;
  box-shadow:0 1px 0 hsl(251 34% 78%); overflow:hidden; position:relative;}
.post-head{display:flex; align-items:center; gap:var(--s2); padding:var(--s3) var(--s3) var(--s2);}
.avatar{width:40px; height:40px; border-radius:50%; flex:0 0 40px; overflow:hidden; border:1px solid var(--border);}
.post-who{display:flex; flex-direction:column; line-height:1.25;}
.post-who .nick{font-weight:700; font-size:15px;}
.post-who .when{font-family:var(--font-mono); font-size:13px; color:var(--muted);}
.post-media{position:relative;}
.post-media .corner-label{top:14px; padding:4px 36px;}
.post:hover .post-media .corner-label{transform:rotate(45deg) scale(1.02);}
.post-body{padding:var(--s3);}
.post-body h2{margin:0 0 var(--s2); font-family:var(--font-body); font-weight:700;
  font-size:25px; line-height:1.25; letter-spacing:-0.01em;}
.post-body h2 a{color:var(--accent);}
.post-body p{margin:0 0 var(--s3); color:var(--text);}
.tags{display:flex; flex-wrap:wrap; gap:var(--s1); margin-bottom:var(--s3);}
.tag{font-family:var(--font-display); font-size:11px; font-weight:500; letter-spacing:0.02em;
  color:#fff; background:var(--accent-3); border-radius:2px; padding:4px 8px;}
.tag.hot{background:var(--accent);}
.actions{display:flex; gap:var(--s2); border-top:1px solid var(--border); padding-top:var(--s3);}
.act{display:inline-flex; align-items:center; gap:6px; min-height:44px; padding:8px 12px;
  font-family:var(--font-display); font-size:13px; letter-spacing:0.02em; font-weight:500;
  background:none; border:none; color:var(--muted); cursor:pointer; border-radius:2px;
  transition:background .16s var(--ease),color .16s var(--ease);}
.act:hover{background:var(--surface-alt); color:var(--accent);}
.act svg{width:18px; height:18px;}

/* ---------- PAGINATION ---------- */
.pager{display:flex; gap:var(--s2); justify-content:center; align-items:center; padding-top:var(--s4);}
.pager a,.pager span{min-width:44px; min-height:44px;
  display:inline-flex; align-items:center; justify-content:center;
  font-family:var(--font-display); font-size:14px; border:1px solid var(--border);
  background:var(--surface); color:var(--text); border-radius:2px;}
.pager a:hover{background:var(--surface-alt); text-decoration:none;}
.pager [aria-current="page"]{background:var(--accent); color:#fff; border-color:var(--accent);}

/* ---------- SHORTCUTS ---------- */
.shortcuts{background:var(--surface-alt); border:1px solid var(--border); border-radius:2px;
  padding:var(--s4); margin-bottom:var(--s6);}
.shortcuts h2{font-family:var(--font-body); font-weight:700; font-size:20px; margin:0 0 var(--s3);}
.shortcuts ul{list-style:none; margin:0; padding:0; display:flex; flex-wrap:wrap; gap:var(--s2);}
.shortcuts li a{display:inline-flex; min-height:44px; align-items:center; padding:8px 14px;
  background:var(--surface); border:1px solid var(--border); border-radius:2px; font-size:14px;}

/* ---------- FOOTER (horizon band on top) ---------- */
.site-footer .horizon-band{height:3px;}
.footer-inner{background:var(--horizon-ink); color:#fff;}
.footer-inner .feed-col{padding-block:var(--s5);}
.footer-inner a{color:#fff; text-decoration:underline;}
.footer-cols{display:flex; flex-wrap:wrap; gap:var(--s5); margin-bottom:var(--s4);}
.footer-cols h3{font-family:var(--font-display); font-size:13px; text-transform:uppercase;
  letter-spacing:0.04em; margin:0 0 var(--s2); color:#fff;}
.footer-cols ul{list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:6px;}
.footer-cols a{font-size:14px;}
.footer-label{font-family:var(--font-mono); font-size:13px; color:#fff; opacity:.95;
  border-top:1px solid rgba(255,255,255,.18); padding-top:var(--s3);}

.intro-h1{font-family:var(--font-display); font-weight:600; font-size:39px; line-height:1.15;
  letter-spacing:-0.01em; margin:var(--s5) auto var(--s2);}
.intro-p{color:var(--muted); margin:0 auto var(--s2); max-width:var(--feed);}

/* ---------- RESPONSIVE ---------- */
@media (max-width:1024px){
  :root{--feed:600px;}
}
@media (max-width:768px){
  :root{--feed:100%;}
  .hb-row{height:40px;}
  .hb-logo{font-size:18px;}
  .nav-row nav{display:none;}
  .nav-row nav.open{display:flex; position:absolute; flex-direction:column; left:0; right:0; top:100%;
    background:var(--surface); border-bottom:1px solid var(--border); z-index:30; padding:var(--s2);}
  .menu-toggle{display:inline-flex; align-items:center; justify-content:center;
    min-width:44px; min-height:44px; font-size:18px; background:var(--surface); border:1px solid var(--border);
    border-radius:2px; color:var(--text); cursor:pointer;}
  .search input{width:120px;}
  .strip-head h2{font-size:22px;}
  .post-body h2{font-size:22px;}
  .intro-h1{font-size:31px;}
}
@media (max-width:480px){
  .mini{flex-basis:78%;}
  .corner-label{font-size:10px;}
  .actions{gap:0;}
  .act{padding:8px;}
  .search{display:none;}
  .footer-cols{gap:var(--s4);}
}
@media (prefers-reduced-motion:reduce){
  *{transition:none !important;}
  .mini:hover .corner-label,.post:hover .post-media .corner-label{transform:rotate(45deg);}
}

/* ============ view page additional blocks (재사용 list 컴포넌트 래퍼) ============ */
/* view-block: spacing wrapper for post-body sections (list5, pager, recommended) */
.view-block{margin-top:var(--s5);}
/* view pager: feed-col + pager already supply layout; pad-top via view-block */
.feed-col.pager{padding-top:var(--s4); flex-wrap:wrap;}

/* ============ gnuboard dynamic supplements (Sunset Gradient Wander) ============ */
/* thumbnail images inside thumb wrappers */
.mini .thumb img,.post-media img{width:100%;height:100%;object-fit:cover;display:block;}
.post-media img{aspect-ratio:4/3;}
/* pager: gnuboard outputs <strong> or class=now for current page */
.pager strong,.pager .now{min-width:44px;min-height:44px;display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:14px;background:var(--accent);color:#fff;border:1px solid var(--accent);border-radius:2px;font-weight:700;}
/* board list heading row */
.board-list-head{display:flex;align-items:center;justify-content:space-between;gap:var(--s3);margin-bottom:var(--s3);padding-bottom:var(--s2);border-bottom:2px solid var(--border);}
.board-list-head h1{font-family:var(--font-display);font-weight:700;font-size:28px;line-height:1.2;margin:0;color:var(--text);}
.board-list-head .total{font-family:var(--font-mono);font-size:13px;color:var(--muted);}
/* board search + write bar */
.board-actions{display:flex;justify-content:space-between;align-items:center;gap:var(--s3);flex-wrap:wrap;margin-top:var(--s4);padding-top:var(--s3);border-top:1px solid var(--border);}
.board-search{display:flex;gap:var(--s2);align-items:center;flex-wrap:wrap;}
.board-search select,.board-search input[type=text]{height:44px;padding:0 12px;font-family:var(--font-body);font-size:14px;background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:2px;}
.btn-write,.btn-search{display:inline-flex;align-items:center;min-height:44px;padding:0 18px;font-family:var(--font-display);font-weight:500;font-size:13px;letter-spacing:0.04em;border-radius:2px;border:1px solid var(--border);cursor:pointer;text-decoration:none;}
.btn-write{background:var(--accent);color:#fff;border-color:var(--accent);}
.btn-write:hover{background:var(--accent-2);border-color:var(--accent-2);text-decoration:none;color:#fff;}
.btn-search{background:var(--surface);color:var(--text);}
.btn-search:hover{background:var(--surface-alt);text-decoration:none;}
/* board view (.hm-board-view*) using Sunset palette */
.hm-board-view{background:var(--surface);border:1px solid var(--border);border-radius:2px;box-shadow:0 1px 0 hsl(251 34% 78%);padding:var(--s5);margin:var(--s5) auto var(--s4);max-width:var(--feed);}
.hm-view-head{border-bottom:2px solid var(--text);padding-bottom:var(--s3);margin-bottom:var(--s4);}
.hm-view-head .hm-board-kicker{font-family:var(--font-mono);font-size:12px;letter-spacing:0.08em;text-transform:uppercase;color:var(--accent-2);margin:0 0 var(--s2);}
.hm-view-head h1{font-family:var(--font-body);font-weight:700;font-size:26px;line-height:1.25;color:var(--text);margin:0;}
.hm-view-meta{display:flex;gap:var(--s4);margin-top:var(--s2);font-family:var(--font-mono);font-size:13px;color:var(--muted);flex-wrap:wrap;}
.hm-view-content{font-size:16px;line-height:1.8;color:var(--text);padding:var(--s2) 0 var(--s4);border-bottom:1px solid var(--border);}
.hm-view-content img{max-width:100%;height:auto;border-radius:2px;margin-block:var(--s3);}
.hm-view-content p{margin:0 0 var(--s3);}
.hm-view-files{display:flex;flex-wrap:wrap;gap:var(--s2);margin:var(--s3) 0;}
.hm-view-files a{font-family:var(--font-mono);font-size:13px;border:1px solid var(--border);border-radius:2px;padding:6px 12px;color:var(--accent-2);background:var(--surface);}
.hm-view-neighbor{display:flex;flex-direction:column;gap:var(--s2);margin:var(--s4) 0;}
.hm-view-neighbor a{display:flex;gap:var(--s3);padding:10px var(--s3);border:1px solid var(--border);border-radius:2px;background:var(--surface-alt);}
.hm-view-neighbor span{font-family:var(--font-mono);font-size:12px;color:var(--muted);flex:0 0 auto;}
.hm-view-neighbor strong{font-weight:500;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.hm-view-actions{display:flex;gap:var(--s2);flex-wrap:wrap;margin-top:var(--s4);}
.hm-view-actions a{min-height:40px;display:inline-flex;align-items:center;padding:0 16px;border:1px solid var(--border);border-radius:2px;font-family:var(--font-display);font-weight:500;font-size:14px;color:var(--text);background:var(--surface);}
.hm-view-actions a:hover{background:var(--surface-alt);text-decoration:none;}
.hm-view-actions a.is-primary{background:var(--accent);color:#fff;border-color:var(--accent);}
.hm-view-actions a.is-primary:hover{background:var(--accent-2);border-color:var(--accent-2);}
.hm-view-vote{display:flex;gap:var(--s2);margin:var(--s3) 0;}
.hm-view-vote a{padding:8px 16px;border:1px solid var(--border);border-radius:2px;color:var(--text);font-family:var(--font-mono);font-size:13px;}
