/* ================================================================
   Blank — Editorial Tistory Skin  |  Final
   ================================================================ */

/* ─── Variables ─── */
:root {
  --bg:#F9F8F6; --surface:#FFFFFF; --surface-2:#F3F2F0;
  --text:#18181B; --text-2:#3F3F46; --text-3:#71717A; --text-4:#A1A1AA;
  --accent:#18181B; --accent-fg:#FFFFFF;
  --border:#E4E4E7; --border-2:#D4D4D8; --hover:#F4F4F5;
  --f-serif:'Noto Serif KR',Georgia,serif;
  --f-sans:'Noto Sans KR','Apple SD Gothic Neo',sans-serif;
  --sp-2:.5rem; --sp-3:.75rem; --sp-4:1rem; --sp-5:1.25rem;
  --sp-6:1.5rem; --sp-8:2rem; --sp-10:2.5rem; --sp-12:3rem; --sp-16:4rem;
  --max-w:1160px; --sb-w:268px; --gutter:40px; --header-h:60px;
  --r:4px; --r2:8px; --r3:12px;
  --tr:200ms cubic-bezier(.4,0,.2,1);
  --sh:0 1px 4px rgba(0,0,0,.06),0 4px 12px rgba(0,0,0,.05);
  --sh-lg:0 8px 32px rgba(0,0,0,.10);
  --slide-ov:linear-gradient(to top,rgba(0,0,0,.84) 0%,rgba(0,0,0,.38) 48%,rgba(0,0,0,.04) 100%);
}
[data-theme="dark"] {
  --bg:#0F0F11; --surface:#1A1A1F; --surface-2:#26262D;
  --text:#FAFAFA; --text-2:#D4D4D8; --text-3:#A1A1AA; --text-4:#71717A;
  --accent:#FAFAFA; --accent-fg:#0F0F11;
  --border:#2C2C35; --border-2:#3A3A45; --hover:#26262D;
  --sh:0 1px 4px rgba(0,0,0,.4),0 4px 12px rgba(0,0,0,.3);
  --sh-lg:0 8px 32px rgba(0,0,0,.5);
  --slide-ov:linear-gradient(to top,rgba(0,0,0,.92) 0%,rgba(0,0,0,.55) 48%,rgba(0,0,0,.08) 100%);
}

/* ── Tistory 자동 삽입 요소 강제 숨김 ──────────────────────────────
   이 요소들은 Tistory가 포스트 페이지에 자동으로 주입합니다.
   스킨에서 제어 불가능하므로 CSS로 숨깁니다.
   ─────────────────────────────────────────────────────────── */

/* 작성자 프로필 카드 (Namecard) */
[data-tistory-react-app="Namecard"],
.tt_box_namecard,
.tt_box_namecard * { display: none !important; }

/* 카테고리 다른글 리스트 (another_category) */
.another_category,
.another_category_color_gray,
.another_category * { display: none !important; }

/* ─── Reset ─── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{font-family:var(--f-sans);color:var(--text);background:var(--bg);line-height:1.75;word-break:keep-all;overflow-wrap:break-word;-webkit-font-smoothing:antialiased;transition:background var(--tr),color var(--tr);}
img,video{max-width:100%;height:auto;display:block;}
a{color:inherit;text-decoration:none;}
ul,ol{list-style:none;}
button{cursor:pointer;background:none;border:none;font:inherit;color:inherit;}
.skip-link{position:absolute;top:-100%;left:1rem;padding:.5rem 1rem;background:var(--accent);color:var(--accent-fg);border-radius:var(--r);font-size:.875rem;z-index:9999;transition:top var(--tr);}
.skip-link:focus{top:1rem;}

/* ─── Header ─── */
.site-header{position:sticky;top:0;z-index:200;height:var(--header-h);background:color-mix(in srgb,var(--bg) 90%,transparent);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid transparent;transition:border-color var(--tr),box-shadow var(--tr),background var(--tr);}
.site-header.is-scrolled{border-color:var(--border);box-shadow:0 1px 8px rgba(0,0,0,.06);}
.header-inner{max-width:var(--max-w);margin:0 auto;padding:0 var(--gutter);height:100%;display:flex;align-items:center;gap:var(--sp-6);}
.site-brand{flex-shrink:0;}
.brand-text{font-family:var(--f-serif);font-size:1.125rem;font-weight:600;letter-spacing:-.03em;line-height:1;margin:0;transition:opacity var(--tr);}
.site-brand:hover .brand-text{opacity:.6;}

/* ─── 헤더 nav — tt_category 구조 대응 ─── */
.site-nav{display:flex;align-items:center;flex:1;overflow:hidden;gap:2px;}
.nav-home-link{display:inline-block;padding:var(--sp-2) var(--sp-3);font-size:.8125rem;font-weight:600;color:var(--text);border-radius:var(--r);white-space:nowrap;flex-shrink:0;transition:background var(--tr);}
.nav-home-link:hover{background:var(--hover);}

/* ul.tt_category → flex, 최상위 link_tit + 서브 category_list 모두 표시 */
.site-nav .tt_category{display:flex;flex-wrap:wrap;align-items:center;gap:2px;list-style:none;}
.site-nav .tt_category > li{display:flex;align-items:center;flex-wrap:wrap;gap:2px;}
.site-nav .category_list{display:flex;flex-wrap:wrap;align-items:center;gap:2px;list-style:none;}
.site-nav .category_list li{display:block;}

/* 공통 링크 스타일 */
.site-nav .link_tit,
.site-nav .link_item{
  display:inline-flex;align-items:center;gap:3px;
  padding:var(--sp-2) var(--sp-3);
  font-size:.8125rem;font-weight:500;
  color:var(--text-3);border-radius:var(--r);
  white-space:nowrap;
  transition:background var(--tr),color var(--tr);
}
.site-nav .link_tit:hover,.site-nav .link_item:hover,
.site-nav .link_tit.on,.site-nav .link_item.on,
.site-nav .link_tit.selected,.site-nav .link_item.selected{background:var(--hover);color:var(--text);font-weight:600;}

/* 헤더에서 count 숨김 */
.site-nav .c_cnt{display:none;}
/* 헤더에서 Tistory 기본 img 뱃지 숨김 (JS가 처리하지만 CSS 안전망) */
.site-nav .tt_category img[alt="N"]{display:none;}

/* 헤더 액션 */
.header-actions{margin-left:auto;display:flex;align-items:center;gap:var(--sp-2);flex-shrink:0;}
.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:var(--r2);color:var(--text-3);transition:background var(--tr),color var(--tr);}
.btn-icon:hover{background:var(--hover);color:var(--text);}
.ico-moon{display:block;} .ico-sun{display:none;}
[data-theme="dark"] .ico-moon{display:none;} [data-theme="dark"] .ico-sun{display:block;}
.nav-toggle{display:none;flex-direction:column;gap:5px;padding:8px;}
.hbar{display:block;width:18px;height:1.5px;background:var(--text-3);border-radius:2px;transition:transform var(--tr),opacity var(--tr);}
.nav-toggle.is-open .hbar:nth-child(1){transform:translateY(6.5px) rotate(45deg);}
.nav-toggle.is-open .hbar:nth-child(2){opacity:0;}
.nav-toggle.is-open .hbar:nth-child(3){transform:translateY(-6.5px) rotate(-45deg);}

@media(max-width:768px){
  .header-inner{padding:0 var(--sp-5);gap:0;}
  .nav-toggle{display:flex;}
  .site-nav{position:fixed;top:var(--header-h);left:0;right:0;background:var(--surface);border-bottom:1px solid var(--border);padding:var(--sp-4) var(--sp-5) var(--sp-5);box-shadow:var(--sh-lg);transform:translateY(-8px);opacity:0;pointer-events:none;flex-direction:column;align-items:flex-start;overflow:visible;gap:2px;transition:transform 250ms ease,opacity 250ms ease;}
  .site-nav.is-open{transform:translateY(0);opacity:1;pointer-events:auto;}
  .site-nav .tt_category,.site-nav .category_list{flex-direction:column;align-items:flex-start;width:100%;}
  .site-nav .tt_category > li{flex-direction:column;align-items:flex-start;width:100%;}
  .site-nav .link_tit,.site-nav .link_item,.nav-home-link{width:100%;padding:var(--sp-3) var(--sp-3);font-size:.9375rem;}
  .site-nav .category_list li{padding-left:var(--sp-4);}
}

/* ── 캐러셀: CSS로 표시/숨김 제어 (JS 타이밍 문제 없음) ── */
.hero-outer { display: none !important; }
body#tt-body-index .hero-outer { display: block !important; }

/* ─── Hero Carousel ─── */
.hero-outer{max-width:var(--max-w);margin:var(--sp-8) auto 0;padding:0 var(--gutter);}
.carousel-wrap{position:relative;width:100%;overflow:hidden;border-radius:var(--r3);box-shadow:var(--sh-lg);}
.carousel-track{position:relative;width:100%;aspect-ratio:16/6.5;min-height:240px;}
.c-slide{position:absolute;inset:0;opacity:0;transition:opacity 900ms cubic-bezier(.4,0,.2,1);pointer-events:none;}
.c-slide.is-on{opacity:1;pointer-events:auto;z-index:1;}
.c-slide-inner{display:block;position:relative;width:100%;height:100%;overflow:hidden;}
/* 캐러셀 배경 — 폴백 그라디언트 위에 실제 썸네일 이미지 레이어 */
.c-slide-bg{position:absolute;inset:0;background:linear-gradient(135deg,#1a1a2e,#2d3561);background-size:cover;background-position:center;transform:scale(1.04);transition:transform 6000ms ease;}
.c-slide.is-on .c-slide-bg{transform:scale(1);}
/* 썸네일 이미지 레이어 (s_rctps_rep_thumbnail 있을 때만 렌더링) */
.c-slide-bg-img{position:absolute;inset:0;background-size:cover;background-position:center;transform:inherit;}
.c-slide:nth-child(2) .c-slide-bg{background:linear-gradient(135deg,#1a2a1a,#2d5030);background-size:cover;background-position:center;}
.c-slide:nth-child(3) .c-slide-bg{background:linear-gradient(135deg,#2a1a1a,#5c2d2d);background-size:cover;background-position:center;}
.c-slide:nth-child(4) .c-slide-bg{background:linear-gradient(135deg,#1a1030,#3d2a60);background-size:cover;background-position:center;}
.c-slide:nth-child(5) .c-slide-bg{background:linear-gradient(135deg,#1f1a10,#4a3820);background-size:cover;background-position:center;}
.c-slide-overlay{position:absolute;inset:0;background:var(--slide-ov);}
.c-slide-content{position:absolute;bottom:0;left:0;right:0;padding:var(--sp-8) var(--sp-8) var(--sp-10);z-index:2;opacity:0;transform:translateY(8px);transition:opacity 700ms 200ms ease,transform 700ms 200ms ease;}
.c-slide.is-on .c-slide-content{opacity:1;transform:translateY(0);}
.c-slide-date{display:block;font-size:.75rem;font-weight:500;color:rgba(255,255,255,.65);letter-spacing:.06em;margin-bottom:var(--sp-3);}
.c-slide-title{font-family:var(--f-serif);font-size:clamp(1.125rem,3vw,1.875rem);font-weight:600;line-height:1.35;letter-spacing:-.025em;color:#fff;text-shadow:0 2px 16px rgba(0,0,0,.3);max-width:640px;margin-bottom:var(--sp-4);}
.c-slide-cta{display:inline-block;font-size:.8125rem;font-weight:500;color:rgba(255,255,255,.8);border-bottom:1px solid rgba(255,255,255,.4);padding-bottom:1px;transition:color var(--tr),border-color var(--tr);}
.c-slide-inner:hover .c-slide-cta{color:#fff;border-color:rgba(255,255,255,.9);}
.c-btn{position:absolute;top:50%;transform:translateY(-50%);z-index:10;width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.18);backdrop-filter:blur(6px);color:#fff;display:flex;align-items:center;justify-content:center;transition:background var(--tr),transform 150ms ease;}
.c-btn:hover{background:rgba(255,255,255,.32);transform:translateY(-50%) scale(1.06);}
.c-prev{left:var(--sp-4);} .c-next{right:var(--sp-4);}
.c-dots{position:absolute;bottom:var(--sp-4);left:50%;transform:translateX(-50%);z-index:10;display:flex;gap:var(--sp-2);}
.c-dot{width:24px;height:3px;border-radius:2px;background:rgba(255,255,255,.35);transition:background var(--tr),width var(--tr);}
.c-dot.is-on{background:rgba(255,255,255,.95);width:38px;}
@media(max-width:768px){.hero-outer{padding:0 var(--sp-5);margin-top:var(--sp-6);}}
@media(max-width:640px){.hero-outer{padding:0 var(--sp-4);}.carousel-track{aspect-ratio:4/3;min-height:0;}.carousel-wrap{border-radius:var(--r2);}.c-slide-content{padding:var(--sp-5) var(--sp-5) var(--sp-8);}}

/* ─── Page Layout ─── */
.page-layout{max-width:var(--max-w);margin:0 auto;padding:var(--sp-10) var(--gutter) var(--sp-16);display:grid;grid-template-columns:1fr var(--sb-w);gap:var(--sp-10);align-items:start;}
.site-main{min-width:0;}
@media(max-width:960px){.page-layout{grid-template-columns:1fr;gap:var(--sp-8);padding:var(--sp-8) var(--sp-5) var(--sp-12);}}
@media(max-width:640px){.page-layout{padding:var(--sp-6) var(--sp-4) var(--sp-10);}}

/* ── 인덱스: site-main을 2열 grid container로 ──────────────────────
   s_index_article_rep 카드가 site-main 직접 자식으로 렌더링됨.
   JS wrapper 대신 CSS grid로 처리: 타이밍 문제 없이 즉시 적용됨.
   ─────────────────────────────────────────────────────────────── */
body#tt-body-index .site-main {
  display: grid;
  grid-template-columns: 1fr 1fr;
  column-gap: var(--sp-5);
  align-items: start;
}
/* list-header, article-list(s_list), pagination → 전체 2열 span */
body#tt-body-index .site-main > .list-header,
body#tt-body-index .site-main > section,
body#tt-body-index .site-main > nav { grid-column: 1 / -1; }

/* s_list가 만든 section.article-list 숨김 (s_index_article_rep 카드만 표시) */
body#tt-body-index .site-main > section.article-list { display: none !important; }
body#tt-body-index .site-main > .list-header ~ .list-header { display: none !important; }

/* 카드 수직 간격 */
body#tt-body-index .site-main > .article-card { margin-bottom: var(--sp-5); }

@media(max-width:680px){
  body#tt-body-index .site-main { grid-template-columns: 1fr; }
}

/* ── List Header ──
   인덱스: JS가 article-card를 article-list로 감싼 뒤 listHeader 표시
   카테고리/검색: s_list 내부의 list-header만 표시 */
.list-header{display:none;}
body#tt-body-index #listHeader{display:flex;align-items:center;gap:var(--sp-5);margin-bottom:var(--sp-6);}
.article-list .list-header,
.site-main > .article-list ~ .list-header{display:flex!important;align-items:center;gap:var(--sp-5);margin-bottom:var(--sp-6);}
.list-label{font-size:.6875rem;font-weight:700;letter-spacing:.13em;color:var(--text-4);white-space:nowrap;}
.list-divider{flex:1;height:1px;background:var(--border);}

/* ── 중복 카드 숨김 ──
   s_article_rep > s_index_article_rep 카드가 카테고리/검색/태그에서도 렌더링됨
   비인덱스 페이지에서 .site-main 직접 자식 article 카드 숨김 */
body#tt-body-category .site-main > .article-card,
body#tt-body-search   .site-main > .article-card,
body#tt-body-tag      .site-main > .article-card { display: none !important; }
/* 카드 없을 때 listHeader도 숨김 */
body#tt-body-category #listHeader,
body#tt-body-search   #listHeader,
body#tt-body-tag      #listHeader { display: none !important; }

/* ─── Article Card Grid ─── */
.article-list{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--sp-5);}
@media(max-width:680px){.article-list{grid-template-columns:1fr;gap:var(--sp-4);}}

/* ── 카테고리/검색/태그 리스트 페이지: 가로형 카드 (사진 1 : 내용 2) ── */
body#tt-body-category .article-list,
body#tt-body-search   .article-list,
body#tt-body-tag      .article-list {
  grid-template-columns: 1fr;   /* 1열 */
  gap: var(--sp-5);
}

body#tt-body-category .article-card,
body#tt-body-search   .article-card,
body#tt-body-tag      .article-card {
  flex-direction: row;           /* 가로 배치 */
}

/* 썸네일: 1/3 고정 */
body#tt-body-category .card-thumb-link,
body#tt-body-search   .card-thumb-link,
body#tt-body-tag      .card-thumb-link {
  flex: 0 0 33.33%;
  max-width: 33.33%;
}
body#tt-body-category .card-thumb,
body#tt-body-search   .card-thumb,
body#tt-body-tag      .card-thumb {
  width: 100%;
  height: 100%;
  aspect-ratio: unset;           /* 가로 카드에서는 부모 height에 맞춤 */
  min-height: 140px;
}

/* 카드 본문: 2/3 */
body#tt-body-category .card-body,
body#tt-body-search   .card-body,
body#tt-body-tag      .card-body {
  flex: 1 1 66.67%;
  min-width: 0;
}

/* hover 시 썸네일 scale (가로형) */
body#tt-body-category .article-card:hover .card-thumb,
body#tt-body-search   .article-card:hover .card-thumb,
body#tt-body-tag      .article-card:hover .card-thumb {
  transform: scale(1.04);
}

/* 모바일: 가로형도 세로로 전환 */
@media(max-width:600px) {
  body#tt-body-category .article-card,
  body#tt-body-search   .article-card,
  body#tt-body-tag      .article-card { flex-direction: column; }

  body#tt-body-category .card-thumb-link,
  body#tt-body-search   .card-thumb-link,
  body#tt-body-tag      .card-thumb-link { flex: unset; max-width: 100%; }

  body#tt-body-category .card-thumb,
  body#tt-body-search   .card-thumb,
  body#tt-body-tag      .card-thumb { aspect-ratio: 16/9; min-height: unset; height: auto; }
}
.article-card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:var(--r3);overflow:hidden;transition:box-shadow 280ms ease,transform 280ms ease,border-color var(--tr),background var(--tr);}
.article-card:hover{box-shadow:var(--sh-lg);transform:translateY(-3px);border-color:var(--border-2);}
.anim-card{opacity:0;transform:translateY(20px);transition:opacity 480ms ease,transform 480ms ease,box-shadow 280ms ease,background var(--tr),border-color var(--tr);}
.anim-card.is-visible{opacity:1;transform:translateY(0);}
.anim-card:nth-child(2){transition-delay:60ms;} .anim-card:nth-child(3){transition-delay:120ms;} .anim-card:nth-child(4){transition-delay:180ms;}
.card-thumb-link{display:block;overflow:hidden;}
.card-thumb{width:100%;aspect-ratio:16/9;flex-shrink:0;background:var(--surface-2);background-size:cover;background-position:center;transition:transform 500ms ease;}
.article-card:hover .card-thumb{transform:scale(1.04);}
.card-body{padding:var(--sp-5) var(--sp-5) var(--sp-4);display:flex;flex-direction:column;flex:1;}
.card-meta{display:flex;align-items:center;gap:var(--sp-3);margin-bottom:var(--sp-3);}
.card-cat{font-size:.6875rem;font-weight:500;letter-spacing:.07em;text-transform:uppercase;color:var(--text-4);border:1px solid var(--border);border-radius:999px;padding:2px 8px;transition:color var(--tr),border-color var(--tr),background var(--tr);}
.card-cat:hover{color:var(--text);border-color:var(--text-3);background:var(--hover);}
.card-date{font-size:.75rem;color:var(--text-4);}
.card-title{font-family:var(--f-serif);font-size:1rem;font-weight:500;line-height:1.5;letter-spacing:-.025em;margin-bottom:var(--sp-2);}
.card-title a{transition:color var(--tr);}
.card-title a:hover{color:var(--text-3);}
.card-excerpt{font-size:.8125rem;color:var(--text-3);line-height:1.65;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;flex:1;margin-bottom:var(--sp-4);}
.card-foot{display:flex;align-items:center;justify-content:space-between;padding-top:var(--sp-3);border-top:1px solid var(--border);margin-top:auto;}
.card-cmtcnt{display:flex;align-items:center;gap:4px;font-size:.75rem;color:var(--text-4);}
.card-more{font-size:.75rem;font-weight:500;color:var(--text-4);transition:color var(--tr);}
.article-card:hover .card-more{color:var(--text-2);}
.empty-state{padding:var(--sp-12) 0;text-align:center;font-size:.9375rem;color:var(--text-3);}

.card-inline-tags{display:flex;flex-wrap:wrap;gap:4px;margin-left:auto;}
.card-inline-tag{font-size:.6875rem;font-weight:500;color:var(--text-3);background:var(--surface-2);border:1px solid var(--border);border-radius:999px;padding:1px 7px;white-space:nowrap;}

/* ─── Entry (포스트 본문) ─── */
.entry-wrap{width:100%;}
.entry-header{margin-bottom:var(--sp-8);padding-bottom:var(--sp-6);border-bottom:1px solid var(--border);}
.entry-title{font-family:var(--f-serif);font-size:clamp(1.5rem,3.5vw,2.125rem);font-weight:700;line-height:1.3;letter-spacing:-.03em;margin-bottom:var(--sp-4);color:var(--text);}
.entry-meta{display:flex;flex-wrap:wrap;gap:var(--sp-3);font-size:.8125rem;color:var(--text-3);}
.entry-notice-badge{display:inline-block;font-size:.6875rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;background:var(--accent);color:var(--accent-fg);border-radius:var(--r);padding:2px 8px;margin-bottom:var(--sp-4);}

/* 본문 */
.entry-content,.area_view{font-family:var(--f-serif);font-size:1.0625rem;line-height:1.9;color:var(--text-2);}
.entry-content h1,.entry-content h2,.entry-content h3,.entry-content h4,
.area_view h1,.area_view h2,.area_view h3,.area_view h4{font-family:var(--f-serif);font-weight:600;letter-spacing:-.025em;line-height:1.35;margin:2.5em 0 .75em;color:var(--text);}
.entry-content h2,.area_view h2{font-size:1.5rem;} .entry-content h3,.area_view h3{font-size:1.25rem;} .entry-content h4,.area_view h4{font-size:1.0625rem;}
.entry-content p,.area_view p{margin-bottom:1.6em;}
.entry-content a,.area_view a{color:var(--text);text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--border-2);transition:text-decoration-color var(--tr);}
.entry-content a:hover,.area_view a:hover{text-decoration-color:var(--text);}
.entry-content blockquote,.area_view blockquote{border-left:3px solid var(--border-2);padding:var(--sp-2) 0 var(--sp-2) var(--sp-6);margin:var(--sp-8) 0;color:var(--text-3);font-style:italic;}
.entry-content code,.area_view code{font-family:'Menlo','Consolas',monospace;font-size:.875em;background:var(--surface-2);padding:2px 6px;border-radius:var(--r);border:1px solid var(--border);}
.entry-content pre,.area_view pre{background:var(--surface-2);border:1px solid var(--border);padding:var(--sp-6);border-radius:var(--r2);overflow-x:auto;margin:var(--sp-8) 0;font-size:.875rem;line-height:1.6;}
[data-theme="dark"] .entry-content pre,[data-theme="dark"] .area_view pre{background:#0a0a0d;}

/* ── 다크모드: Tistory 인라인 color:#000 강제 override ──────────────
   .tt_article_useless_p_margin, .contents_style 내부에
   Tistory가 color:#000000 인라인 스타일을 직접 삽입하여
   CSS 변수가 무시됨. !important로 강제 재정의. */
[data-theme="dark"] .entry-content,
[data-theme="dark"] .area_view,
[data-theme="dark"] .tt_article_useless_p_margin,
[data-theme="dark"] .contents_style {
  color: var(--text-2) !important;
}
[data-theme="dark"] .entry-content *:not(pre):not(code):not(a):not(th),
[data-theme="dark"] .area_view *:not(pre):not(code):not(a):not(th),
[data-theme="dark"] .tt_article_useless_p_margin *:not(pre):not(code):not(a):not(th),
[data-theme="dark"] .contents_style *:not(pre):not(code):not(a):not(th) {
  color: inherit !important;
  background-color: transparent !important;
}
/* 예외 복원 */
[data-theme="dark"] .entry-content pre,
[data-theme="dark"] .area_view pre,
[data-theme="dark"] .tt_article_useless_p_margin pre { background-color: #0a0a0d !important; }
[data-theme="dark"] .entry-content code,
[data-theme="dark"] .area_view code { background-color: var(--surface-2) !important; }
[data-theme="dark"] .entry-content a,
[data-theme="dark"] .area_view a { color: var(--text) !important; }
[data-theme="dark"] .entry-content th,
[data-theme="dark"] .area_view th { background-color: var(--surface-2) !important; }

/* ── 다크모드: Tistory가 삽입한 인라인 color:#000 강제 override ──
   .tt_article_useless_p_margin, .contents_style 등에
   color:#000000 인라인 스타일이 직접 들어와 CSS 변수가 먹히지 않음 */
[data-theme="dark"] .entry-content *,
[data-theme="dark"] .area_view *,
[data-theme="dark"] .tt_article_useless_p_margin *,
[data-theme="dark"] .contents_style * {
  color: inherit !important;
  background-color: transparent !important;
}
/* 예외: 배경색이 필요한 요소들은 다시 지정 */
[data-theme="dark"] .entry-content pre,
[data-theme="dark"] .area_view pre,
[data-theme="dark"] .tt_article_useless_p_margin pre { background-color: #0a0a0d !important; }

[data-theme="dark"] .entry-content code,
[data-theme="dark"] .area_view code,
[data-theme="dark"] .tt_article_useless_p_margin code { background-color: var(--surface-2) !important; }

[data-theme="dark"] .entry-content th,
[data-theme="dark"] .area_view th { background-color: var(--surface-2) !important; }

/* 다크모드 루트 본문 색상 명시 */
[data-theme="dark"] .entry-content,
[data-theme="dark"] .area_view,
[data-theme="dark"] .tt_article_useless_p_margin { color: var(--text-2) !important; }
.entry-content pre code,.area_view pre code{background:none;border:none;padding:0;}
.entry-content ul,.area_view ul{list-style:disc;padding-left:1.5em;margin-bottom:1.5em;}
.entry-content ol,.area_view ol{list-style:decimal;padding-left:1.5em;margin-bottom:1.5em;}
.entry-content li,.area_view li{margin-bottom:.5em;}
.entry-content img,.area_view img{border-radius:var(--r2);margin:var(--sp-8) auto;max-width:100%;}
.entry-content hr,.area_view hr{border:none;border-top:1px solid var(--border);margin:var(--sp-12) 0;}
.entry-content table,.area_view table{width:100%;border-collapse:collapse;margin:var(--sp-8) 0;font-size:.875rem;}
.entry-content th,.entry-content td,.area_view th,.area_view td{padding:var(--sp-2) var(--sp-4);border:1px solid var(--border);text-align:left;}
.entry-content th,.area_view th{background:var(--surface-2);font-weight:500;}

/* 8. 태그 — 쉼표 없이 마진으로만 구분 */
.entry-tags{display:flex;flex-wrap:wrap;align-items:center;gap:var(--sp-2);margin:var(--sp-6) 0;}
/* [##_tag_label_rep_##] 는 <a> 태그를 직접 렌더링 */
.entry-tags a{
  font-size:.8125rem;color:var(--text-3);
  background:var(--surface-2);
  border:1px solid var(--border);border-radius:999px;
  padding:3px 12px;
  transition:background var(--tr),color var(--tr),border-color var(--tr);
  white-space:nowrap;
}
.entry-tags a:hover{background:var(--accent);color:var(--accent-fg);border-color:var(--accent);}
/* Tistory 기본 태그 쉼표 제거 */
.entry-tags a+a::before{content:none!important;}

/* 9. 관련 글 — 캐러셀 */
/* Tistory 기본 관련글 리스트 완전 숨김 */
.area_related { display: none !important; }

.related-posts{margin:var(--sp-8) 0;}
.related-header{display:flex;align-items:center;gap:var(--sp-5);margin-bottom:var(--sp-6);}
.related-label{font-size:.6875rem;font-weight:700;letter-spacing:.13em;color:var(--text-4);white-space:nowrap;}

/* 캐러셀 래퍼 */
.related-carousel-wrap{
  position:relative;
  display:flex;
  align-items:center;
  gap:var(--sp-3);
}
.related-track{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:var(--sp-4);
  flex:1;
  min-width:0;
}
@media(max-width:640px){ .related-track{ grid-template-columns:1fr; } }

/* 화살표 버튼 */
.related-arrow{
  flex-shrink:0;
  width:34px; height:34px;
  border-radius:50%;
  background:var(--surface-2);
  border:1px solid var(--border);
  color:var(--text-3);
  display:flex; align-items:center; justify-content:center;
  transition:background var(--tr),color var(--tr),opacity var(--tr);
}
.related-arrow:hover:not(:disabled){ background:var(--hover); color:var(--text); }
.related-arrow:disabled{ opacity:.3; cursor:not-allowed; }

.related-card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:var(--r2);overflow:hidden;transition:box-shadow 250ms ease,transform 250ms ease,border-color var(--tr);}
.related-card:hover{box-shadow:var(--sh-lg);transform:translateY(-2px);border-color:var(--border-2);}
.related-thumb{width:100%;aspect-ratio:16/9;background:var(--surface-2);background-size:cover;background-position:center;}
.related-info{padding:var(--sp-3) var(--sp-4);}
.related-title{font-family:var(--f-serif);font-size:.875rem;font-weight:500;line-height:1.45;color:var(--text);margin-bottom:var(--sp-2);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.related-card:hover .related-title{color:var(--text-3);}
.related-date{font-size:.75rem;color:var(--text-4);}

/* 3. 댓글 버튼 기본 숨김 — JS가 클래스별로 토글 */
/* 댓글 버튼: JS가 제어 — CSS는 기본 숨김만 담당
   실제 클래스: rp_admin(관리자), rp_general(일반), rp_secret(비밀), hiddenComment */
.btn-edit-del { display: none; }
.btn-del-only { display: none; }
/* rp_admin = 블로그 주인 댓글: 수정/삭제 표시 */
.reply-item.rp_admin .btn-edit-del { display: inline; }
/* rp_general/rp_secret: 삭제 버튼 표시 */
.reply-item.rp_general .btn-del-only,
.reply-item.rp_secret  .btn-del-only { display: inline; }

/* 이전/다음 글 */
.entry-nav{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-4);margin:var(--sp-8) 0;}
.entry-nav.has-top-border{padding-top:var(--sp-8);border-top:1px solid var(--border);}
.entry-nav-prev,.entry-nav-next{padding:var(--sp-4);background:var(--surface);border:1px solid var(--border);border-radius:var(--r2);transition:background var(--tr),border-color var(--tr);}
.entry-nav-prev:hover,.entry-nav-next:hover{background:var(--hover);border-color:var(--border-2);}
.entry-nav-next{text-align:right;}
.entry-nav-dir{display:block;font-size:.6875rem;font-weight:500;letter-spacing:.05em;color:var(--text-4);margin-bottom:var(--sp-2);}
.entry-nav-title{font-family:var(--f-serif);font-size:.9375rem;font-weight:500;line-height:1.45;color:var(--text-2);display:block;}
.entry-nav-title:hover{color:var(--text);}

/* 7. 댓글 */
.comments-section{margin-top:var(--sp-8);padding-top:var(--sp-4);}
.comments-header{margin-bottom:var(--sp-6);}
.comments-count{font-size:.8125rem;font-weight:600;color:var(--text-3);}
.reply-list{display:flex;flex-direction:column;}
.reply-item{display:flex;gap:var(--sp-4);padding:var(--sp-5) 0;border-bottom:1px solid var(--border);}
.reply-item--nested{padding-left:var(--sp-8);}
.reply-avatar{width:38px;height:38px;border-radius:50%;background:var(--surface-2);background-size:cover;background-position:center;flex-shrink:0;border:1px solid var(--border);}
.reply-body{flex:1;min-width:0;}
.reply-meta{display:flex;flex-wrap:wrap;align-items:center;gap:var(--sp-3);margin-bottom:var(--sp-2);}
.reply-name{font-size:.9rem;font-weight:600;color:var(--text);}
.reply-date{font-size:.75rem;color:var(--text-4);}
.reply-actions{display:flex;gap:var(--sp-2);margin-left:auto;}
.reply-action-btn{font-size:.75rem;color:var(--text-4);transition:color var(--tr);}
.reply-action-btn:hover{color:var(--text-2);}
.reply-text{font-size:.9375rem;color:var(--text-2);line-height:1.65;}

/* 댓글 입력 폼 */
.reply-form-wrap{margin-top:var(--sp-8);padding-top:var(--sp-8);border-top:1px solid var(--border);}
.reply-form-title{font-size:.875rem;font-weight:600;color:var(--text-3);margin-bottom:var(--sp-5);}
.reply-guest-fields{display:flex;gap:var(--sp-3);margin-bottom:var(--sp-3);}
.reply-input{flex:1;padding:var(--sp-2) var(--sp-4);border:1px solid var(--border);border-radius:var(--r);background:var(--surface);color:var(--text);font-size:.875rem;font-family:var(--f-sans);outline:none;transition:border-color var(--tr);}
.reply-input:focus{border-color:var(--text-3);}
.reply-secret-wrap{display:flex;align-items:center;gap:var(--sp-2);margin-bottom:var(--sp-3);}
.reply-secret-chk{accent-color:var(--accent);}
.reply-secret-label{font-size:.8125rem;color:var(--text-3);}
.reply-textarea{width:100%;min-height:100px;padding:var(--sp-4);border:1px solid var(--border);border-radius:var(--r);background:var(--surface);color:var(--text);font-family:var(--f-serif);font-size:.9375rem;resize:vertical;outline:none;transition:border-color var(--tr);}
.reply-textarea:focus{border-color:var(--text-3);}
.reply-form-footer{display:flex;justify-content:flex-end;margin-top:var(--sp-3);}
.reply-submit{padding:var(--sp-2) var(--sp-6);background:var(--accent);color:var(--accent-fg);border-radius:var(--r);font-size:.875rem;font-weight:500;transition:opacity var(--tr);}
.reply-submit:hover{opacity:.85;}

/* 보호글 */
.entry-protected{padding:var(--sp-12) 0;text-align:center;}
.entry-protected p{font-size:.9375rem;color:var(--text-3);margin-bottom:var(--sp-6);}
.protected-form{display:flex;gap:var(--sp-3);justify-content:center;}
.protected-form input[type="password"]{padding:var(--sp-2) var(--sp-4);border:1px solid var(--border);border-radius:var(--r);background:var(--surface);color:var(--text);font-size:.875rem;outline:none;}
.btn-submit{padding:var(--sp-2) var(--sp-5);background:var(--accent);color:var(--accent-fg);border-radius:var(--r);font-size:.875rem;font-weight:500;}

/* ─── Pagination ─── */
.pagination{display:flex;justify-content:center;align-items:center;gap:var(--sp-2);padding:var(--sp-10) 0 var(--sp-4);}
.page-btn{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 var(--sp-3);font-size:.875rem;border:1px solid var(--border);border-radius:var(--r3);transition:background var(--tr),border-color var(--tr),color var(--tr);}
.page-btn:hover{background:var(--hover);border-color:var(--border-2);}
.page-btn.disabled,.no_more_prev,.no_more_next{opacity:.35;pointer-events:none;}

/* ─── Tag Cloud ─── */
.tag-cloud{display:flex;flex-wrap:wrap;gap:var(--sp-2);padding:var(--sp-2) 0;}
.tag-item{font-size:.8125rem;color:var(--text-3);border:1px solid var(--border);border-radius:999px;padding:3px 12px;transition:background var(--tr),color var(--tr),border-color var(--tr);}
.tag-item:hover{background:var(--accent);color:var(--accent-fg);border-color:var(--accent);}

/* ─── Guestbook ─── */
.guest-form{margin-bottom:var(--sp-8);}

/* ─── Sidebar ─── */
.site-sidebar{display:flex;flex-direction:column;gap:var(--sp-5);position:sticky;top:calc(var(--header-h) + var(--sp-4));}
@media(max-width:960px){.site-sidebar{position:static;}}

/* 프로필 카드 */
.sb-profile-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r3);padding:var(--sp-6);text-align:center;transition:background var(--tr),border-color var(--tr);}
.sb-avatar{width:72px;height:72px;border-radius:50%;background:var(--surface-2);background-size:cover;background-position:center;margin:0 auto var(--sp-4);border:2px solid var(--border);}
.sb-profile-info{margin-bottom:var(--sp-4);}
.sb-blog-name{display:block;font-family:var(--f-serif);font-size:1rem;font-weight:600;margin-bottom:var(--sp-2);color:var(--text);}
.sb-blog-name a:hover{opacity:.7;}
/* 6. 소개글 좌측 정렬 */
.sb-blog-desc{font-size:.8125rem;color:var(--text-3);line-height:1.6;text-align:left;}
.sb-home-btn{display:inline-flex;align-items:center;justify-content:center;gap:5px;width:100%;padding:var(--sp-2) var(--sp-4);font-size:.8125rem;font-weight:500;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r2);color:var(--text-3);transition:background var(--tr),color var(--tr),border-color var(--tr);}
.sb-home-btn:hover{background:var(--accent);color:var(--accent-fg);border-color:var(--accent);}

/* 카테고리 카드 */
.sb-cats-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r3);padding:var(--sp-5);transition:background var(--tr),border-color var(--tr);}
.sb-cats-title{font-size:.6875rem;font-weight:700;letter-spacing:.12em;color:var(--text-4);margin-bottom:var(--sp-4);}

/* ─── 1. 사이드바 카테고리 스타일 ─── */
.sb-cats{display:block;}
.sb-cats .tt_category,.sb-cats .category_list{display:block;list-style:none;}
.sb-cats .tt_category li,.sb-cats .category_list li{display:block;}

/* 최상위 링크 (link_tit) */
.sb-cats .link_tit{
  display:flex;align-items:center;
  padding:var(--sp-2) var(--sp-3);border-radius:var(--r2);
  font-size:.875rem;color:var(--text-2);
  transition:background var(--tr),color var(--tr);
  white-space:nowrap; overflow:hidden;
}
.sb-cats .link_tit:hover{background:var(--hover);color:var(--text);}
.sb-cats .link_tit.on{background:var(--hover);color:var(--text);font-weight:500;}

/* 서브카테고리 링크 (link_item) */
.sb-cats .link_item{
  display:flex;align-items:center;
  padding:var(--sp-2) var(--sp-3);padding-left:var(--sp-6);
  border-radius:var(--r2);
  font-size:.8125rem;color:var(--text-3);
  transition:background var(--tr),color var(--tr);
  white-space:nowrap; overflow:hidden;
}
.sb-cats .link_item:hover{background:var(--hover);color:var(--text-2);}
.sb-cats .link_item.on{background:var(--hover);font-weight:500;}

/* count 뱃지 */
.sb-cats .c_cnt{
  font-size:.6875rem;color:var(--text-4);
  background:var(--surface-2);border-radius:999px;
  padding:1px 6px;
  margin-left:auto; flex-shrink:0;
}

/* 1. NEW 뱃지 — 이름 바로 뒤, count 앞 / 줄바꿈 방지 */
.cat-new-badge{
  display:inline-block;
  font-size:.6rem;font-weight:700;
  background:#EF4444;color:#fff;
  border-radius:3px;padding:1px 4px;
  margin-left:4px;
  flex-shrink:0;
  line-height:1.4;
  vertical-align:middle;
}
/* link_tit/link_item flex로 badge 위치 고정 */
.sb-cats .link_tit,
.sb-cats .link_item{
  display:flex;align-items:center;gap:4px;
  flex-wrap:nowrap; /* 줄바꿈 방지 */
}
/* 텍스트 노드 부분만 min-width:0으로 축소 방지 */
.sb-cats .link_tit .cat-text,
.sb-cats .link_item .cat-text{flex-shrink:1;min-width:0;overflow:hidden;text-overflow:ellipsis;}

/* ─── Footer ─── */
.site-footer{border-top:1px solid var(--border);padding:var(--sp-8) 0;}
.footer-inner{max-width:var(--max-w);margin:0 auto;padding:0 var(--gutter);display:flex;justify-content:space-between;align-items:center;gap:var(--sp-4);}
.footer-brand{font-family:var(--f-serif);font-size:.9375rem;font-weight:500;}
.footer-brand a:hover{opacity:.6;}
.footer-info{font-size:.8125rem;color:var(--text-4);}
.footer-info a:hover{color:var(--text-3);}
@media(max-width:640px){.footer-inner{flex-direction:column;text-align:center;padding:0 var(--sp-5);}}

/* ─── Print ─── */
@media print{.site-header,.site-footer,.hero-outer,.site-sidebar,.pagination,.skip-link,.btn-theme,.nav-toggle{display:none!important;}.page-layout{grid-template-columns:1fr!important;}body{background:#fff;color:#000;}}
