/* =========================
   Font
========================= */
@font-face{
  font-family:'Pretendard Variable';
  src: local('Pretendard Variable'), local('Pretendard-Regular');
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}

/* =========================
   Design Tokens
========================= */
:root{
  --bg:#F3F1EC;
  --ink:#212121;
  --sub:#6b6b6b;
  --paper:#fff;
  --line:#e8e2d9;
  --brand:#0F8BFF;
  --chip:#ece7df;
  --radius:18px;
  --shadow: 0 6px 16px rgba(0,0,0,.08);
  --tabbar-h:56px; /* 하단 탭바 높이 */
}

/* =========================
   Base
========================= */
*{ box-sizing:border-box; }

html,body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:'Pretendard Variable', -apple-system, BlinkMacSystemFont, 'Apple SD Gothic Neo', 'Malgun Gothic', Segoe UI, Roboto, system-ui, sans-serif;
  -webkit-text-size-adjust: 100%;
}

/* =========================
   Header
========================= */
.tg-header{
  position:sticky; top:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  padding:12px 14px;
  padding-top: calc(12px + env(safe-area-inset-top)); /* iOS notch 대응 */
  background:#ebe7df; border-bottom:1px solid var(--line);
}
.brand{ margin:0; font-size:18px; letter-spacing:.4px; }
.icon-btn{ border:0; background:transparent; font-size:20px; }

/* =========================
   Layout
========================= */
main{
  padding:12px;
  padding-bottom: calc(var(--tabbar-h) + env(safe-area-inset-bottom)); /* 탭바 공간 확보 */
}

.row-head{
  display:flex; align-items:center; justify-content:space-between;
  margin:6px 2px;
}
.row-title{ margin:0; font-size:16px; font-weight:800; }
.row-more{ text-decoration:none; color:#4a4a4a; font-size:13px; }

/* =========================
   Horizontal Scroller
========================= */
.row.scroller{
  display:grid; grid-auto-flow:column; grid-auto-columns: 48%; /* ↓ 절반 수준으로 축소 */
  gap:12px; overflow-x:auto; padding:8px 2px 2px;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  scrollbar-width: none;           /* Firefox */
}
.row.scroller::-webkit-scrollbar{ display:none; } /* Chrome/Safari */

@media (min-width:460px){
  .row.scroller{ grid-auto-columns: 32%; } /* 데스크탑/태블릿에서도 더 작게 */
}

/* =========================
   Card
========================= */
.card{
  scroll-snap-align:start;
  position:relative;
  border-radius:var(--radius);
  background:var(--paper);
  box-shadow:var(--shadow);
  overflow:hidden;
  transition: transform .12s ease, box-shadow .12s ease; /* touch feedback */
}
.card:active{
  transform: scale(.98);
  box-shadow: 0 4px 12px rgba(0,0,0,.06);
}

.card-img{
  width:100%;
  aspect-ratio: 1 / 1;   /* 1:1 정사각형 */
  height:auto;
  object-fit:cover;
  display:block;
  background:linear-gradient(135deg,#ececec,#e2e2e2);
}

/* 히어로 배너도 동일하게 정사각형으로 */
.hero-row .row.scroller .card-img{
  aspect-ratio: 1 / 1;
}

.card-body{ padding:10px 12px 12px; }

.card-cat{
  display:inline-flex; align-items:center; gap:6px;
  font-size:11px; color:#555;
  background:#f3f3f3;
  border-radius:999px; padding:6px 8px;
  margin-bottom:8px;
}

.card-title{
  margin:0 0 6px;
  font-size:15px; font-weight:800; color:var(--ink);
  line-height:1.35;
}

/* -------------------------
   Excerpt (2줄 말줄임)
------------------------- */
/* 기본(모든 브라우저) – 2줄 높이만큼 잘라내기 */
.card-excerpt{
  margin: 0;
  font-size: 13px;
  color: #595959;
  line-height: 1.45;
  max-height: calc(1.45em * 2);
  overflow: hidden;
}

/* WebKit 계열 line-clamp (VSCode 경고 회피: block-overflow 사용 안 함) */
@supports (-webkit-line-clamp: 2) {
  .card-excerpt{
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
  }
}

/* =========================
   Pager (dots)
========================= */
.pager{
  display:flex;
  justify-content:center; /* ← 가운데 정렬 */
  align-items:center;
  gap:6px;
  padding:8px 0 10px;
  width:100%;
}
.pager .dot{
  width:8px; height:8px; border-radius:999px; background:#cdc8c0;
  transition: all .2s ease;
}
.pager .dot.is-active{
  width:22px; background:#222;
}

/* =========================
   Tab Bar
========================= */
.tabbar{
  position:fixed; left:0; right:0; bottom:0; z-index:60;
  display:grid; grid-template-columns:repeat(5,1fr);
  background:#fff; border-top:1px solid var(--line);
  height: var(--tabbar-h);
  padding-bottom: env(safe-area-inset-bottom); /* iOS home indicator */
}
.tab{
  text-decoration:none; color:#777;
  padding:8px 0 10px;
  display:flex; flex-direction:column; align-items:center; gap:4px;
  font-size:12px;
}
.tab span{ font-size:18px; }
.tab.is-active{ color:#111; font-weight:700; }

/* =========================
   Ad
========================= */
.ad-wrap{ margin:14px 0; }
/* 광고 로드 안 됐을 때 빈 공간 제거 */
.ad-wrap:has(ins.adsbygoogle:empty){ display:none; }

/* =========================
   Footer
========================= */
footer{
  text-align:center; color:#8a867e; font-size:12px;
  padding:18px 12px 16px; /* 하단 공간 축소 */
}
.email-link{ color:#6a88ff; text-decoration:underline; }

/* =========================
   Dark Mode (optional)
========================= */
@media (prefers-color-scheme: dark){
  :root{
    --bg:#141414;
    --paper:#1c1c1c;
    --ink:#f0f0f0;
    --sub:#b8b8b8;
    --line:#2a2a2a;
  }
  .tg-header{ background:#1b1b1b; border-bottom-color: var(--line); }
  .tabbar{ background:#1b1b1b; border-top-color: var(--line); }
  .card-cat{ background:#2a2a2a; color:#ccc; }
  .pager .dot{ background:#444; }
  .pager .dot.is-active{ background:#ddd; }
}

/* =========================
   SNS Split Links (Instagram / YouTube)
========================= */
/* 헤더 전체 레이아웃 */
/* ========== Header ========== */
.tg-header{
  position: sticky; top: 0; z-index: 50;
  display: flex; align-items: center; justify-content: space-between;
  gap: 10px; height: 56px; padding: 0 14px;

  /* 글래스 + 은은한 그라데이션 */
  background:
    linear-gradient(180deg, rgba(255,255,255,.85), rgba(255,255,255,.65));
  backdrop-filter: saturate(140%) blur(8px);
  -webkit-backdrop-filter: saturate(140%) blur(8px);

  border-bottom: 1px solid rgba(0,0,0,0.06);
  box-shadow: 0 2px 14px rgba(0,0,0,.06);
}

/* 좌우 균형용 빈 박스 (타이틀 중앙정렬 유지) */
.tg-header .spacer{ width: 72px; }

/* 타이틀 */
.tg-header .brand{
  margin: 0; flex: 1; text-align: center;
  font-size: 18px; font-weight: 800; letter-spacing: .2px;
}
.tg-header .brand a{
  color: #0f172a; text-decoration: none;
}

/* 오른쪽 SNS 버튼 */
.header-sns{ display: flex; gap: 8px; }
.sns-btn{
  width: 32px; height: 32px; display: grid; place-items: center;
  font-size: 18px; border-radius: 10px;
  background: #f6f7fb; border: 1px solid rgba(0,0,0,.06);
  transition: transform .08s ease, background .2s ease, border-color .2s ease;
  text-decoration: none; color: #0f172a;
}
.sns-btn.insta{ background: #f4f6ff; }
.sns-btn.yt   { background: #fff5f5; }
.sns-btn:hover, .sns-btn:focus-visible{
  transform: translateY(-1px);
  border-color: rgba(0,0,0,.12);
  outline: none;
}

/* 다크모드 살짝 보정 (선택) */
@media (prefers-color-scheme: dark){
  .tg-header{
    background: linear-gradient(180deg, rgba(20,24,32,.75), rgba(20,24,32,.6));
    border-bottom: 1px solid rgba(255,255,255,.06);
    box-shadow: 0 2px 14px rgba(0,0,0,.3);
  }
  .tg-header .brand a{ color: #e5e7eb; }
  .sns-btn{ background: #202633; color: #e5e7eb; border-color: rgba(255,255,255,.06); }
  .sns-btn.insta{ background:#23293a; }
  .sns-btn.yt   { background:#2b1f1f; }
}

/* 데스크탑(정밀 포인터)에서는 가로 스크롤바 표시 */
@media (hover:hover) and (pointer:fine){
  .row.scroller{ scrollbar-width: thin; }
  .row.scroller::-webkit-scrollbar{ height:8px; display: initial; }
  .row.scroller::-webkit-scrollbar-thumb{
    background: #c4c0b8; border-radius: 8px;
  }
  .row.scroller::-webkit-scrollbar-track{
    background: transparent;
  }
}

/* =========================
   Category List Page
========================= */
.page-header{
  position:sticky; top:0; z-index:50;
  background:#ebe7df; border-bottom:1px solid var(--line);
  padding:12px 14px;
}
.page-title{ margin:0; font-size:18px; font-weight:800; }

.breadcrumb{ padding:10px 14px 0; color:#666; font-size:12px; }
.breadcrumb a{ color:#666; text-decoration:none; }

.toolbar{ display:flex; gap:8px; padding:10px 12px; background:var(--bg); position:sticky; top:52px; z-index:40; }
.tool-input,.tool-select{
  flex:1; padding:10px 12px;
  border-radius:12px; border:1px solid #ded8cf;
  background:#fff; font-size:14px;
}

.grid{
  display:grid; grid-template-columns: repeat(2, 1fr);
  gap:12px; padding:12px;
}
@media (min-width:700px){
  .grid{ grid-template-columns: repeat(3, 1fr); }
}
.grid .card-img{ aspect-ratio: 1 / 1; }
.grid .card{ box-shadow: var(--shadow); }
.empty{ padding:28px 14px; color:#777; font-size:14px; }

/* =========================
   Post Page
========================= */
.post-header{ padding:16px 14px 8px; background:#ebe7df; border-bottom:1px solid var(--line); }
.post-title{ margin:0 0 6px; font-size:22px; line-height:1.3; }
.post-meta{ color:#777; font-size:12px; }

.post-hero{ margin:12px; border-radius:18px; overflow:hidden; box-shadow:var(--shadow); background:#ddd; }
.post-hero img, .post-hero video{
  width:100%; display:block; object-fit:cover;
  aspect-ratio: 1/1; /* 1:1 정사각형 */
  background:#eee;
}

.post-body{ padding: 0 14px 14px; }
.post-body h2{ font-size:18px; margin:18px 0 8px; }
.post-body p{ margin:10px 0; font-size:15px; color:#333; line-height:1.68; }
.post-body img{ width:100%; border-radius:12px; margin:12px 0; object-fit:cover; background:#eee; }

.post-tags{ display:flex; gap:8px; flex-wrap:wrap; padding:12px 14px 0; }
.tag{ font-size:12px; background:#f1eee7; border:1px solid #e7e1d9; padding:6px 10px; border-radius:999px; color:#444; }

.share{ display:flex; gap:8px; padding:8px 14px; }
.share a{ text-decoration:none; border:1px solid #ded8cf; background:#fff; padding:8px 12px; border-radius:10px; font-size:13px; color:#333; }

.post-nav{ display:flex; justify-content:space-between; gap:8px; padding:12px 14px 20px; }
.post-nav a{ flex:1; text-decoration:none; background:#fff; border:1px solid #e2dbd2; border-radius:12px; padding:10px; color:#333; text-align:center; }

.related{ padding:10px 12px 24px; }
.related .row.scroller{ grid-auto-columns: 48%; } /* related도 동일 축소감 */
.related .card-img{ aspect-ratio:1/1; }

/* =========================
   Star Badge on Thumbnails
========================= */
.star-badge{
  position:absolute;
  top:8px; right:8px;
  z-index:2;
  display:inline-flex;       /* flex로 변경 */
  gap:0;                     /* 별 간격 강제 0 */
  padding:6px 8px;
  border-radius:999px;
  background:rgba(0,0,0,.55);
  color:#fff;
  font-size:12px;            /* 다시 부모에서도 정상 폰트 크기 유지 */
  line-height:1;
  box-shadow:0 4px 12px rgba(0,0,0,.25);
  -webkit-backdrop-filter: blur(3px);
  backdrop-filter: blur(3px);
}

.star-badge .star {
  display:inline-block;
  font-size:12px;            /* 별 크기 */
  margin:0;                  /* 간격 제거 */
  padding:0;
}

.star-badge .star.filled { color: gold; }
.star-badge .star.empty  { color: #ddd; }

.star-badge .score{ display:none; }