/* =====================================================
   QABoard — Apple-inspired stylesheet
   라이트 + 다크모드 자동 (prefers-color-scheme + data-theme)
   ===================================================== */

/* ─── 디자인 토큰 ────────────────────────────────────── */
:root{
  /* 라이트 */
  --bg:        #fbfbfd;
  --bg-elev:   #ffffff;
  --bg-soft:   #f5f5f7;
  --bg-tint:   #f0f0f3;

  --ink-1:     #1d1d1f;
  --ink-2:     #424245;
  --ink-3:     #6e6e73;
  --ink-4:     #86868b;
  --ink-5:     #a1a1a6;

  --line:      rgba(0,0,0,.08);
  --line-2:    rgba(0,0,0,.14);

  --accent:        #0071e3;
  --accent-hover:  #0077ed;
  --accent-soft:   #e8f0fe;
  --accent-2:      #5e5ce6;

  --header-bg: rgba(251,251,253,.78);

  --shadow-1: 0 1px 2px rgba(0,0,0,.04), 0 4px 12px rgba(0,0,0,.04);
  --shadow-2: 0 2px 6px rgba(0,0,0,.06), 0 12px 32px rgba(0,0,0,.06);
  --shadow-3: 0 8px 28px rgba(0,0,0,.10), 0 24px 64px rgba(0,0,0,.08);

  --radius-sm: 10px;
  --radius:    16px;
  --radius-lg: 22px;
  --radius-xl: 28px;

  --grad-1: linear-gradient(135deg,#0071e3 0%,#5e5ce6 100%);
  --grad-2: linear-gradient(135deg,#ff7a18 0%,#af0048 100%);
  --grad-3: linear-gradient(135deg,#11998e 0%,#38ef7d 100%);
  --grad-4: linear-gradient(135deg,#ee0979 0%,#ff6a00 100%);
  --grad-5: linear-gradient(135deg,#7f00ff 0%,#e100ff 100%);

  /* 카테고리별 액센트 (10개 기본 카테고리) */
  --cat-1: #0071e3;
  --cat-2: #5e5ce6;
  --cat-3: #34c759;
  --cat-4: #ff3b30;
  --cat-5: #ff9500;
  --cat-6: #af52de;
  --cat-7: #ff2d55;
  --cat-8: #5ac8fa;
  --cat-9: #ffcc00;
  --cat-10:#8e8e93;
}

/* 다크모드 — prefers-color-scheme 자동 OR data-theme="dark" 수동 */
@media (prefers-color-scheme: dark){
  :root:not([data-theme="light"]){
    --bg:        #000000;
    --bg-elev:   #1c1c1e;
    --bg-soft:   #2c2c2e;
    --bg-tint:   #3a3a3c;

    --ink-1:     #f5f5f7;
    --ink-2:     #d1d1d6;
    --ink-3:     #98989d;
    --ink-4:     #8e8e93;
    --ink-5:     #636366;

    --line:      rgba(255,255,255,.10);
    --line-2:    rgba(255,255,255,.16);

    --accent:        #0a84ff;
    --accent-hover:  #409cff;
    --accent-soft:   rgba(10,132,255,.16);

    --header-bg: rgba(0,0,0,.72);

    --shadow-1: 0 1px 2px rgba(0,0,0,.5), 0 4px 12px rgba(0,0,0,.4);
    --shadow-2: 0 2px 6px rgba(0,0,0,.6), 0 12px 32px rgba(0,0,0,.5);
    --shadow-3: 0 8px 28px rgba(0,0,0,.7), 0 24px 64px rgba(0,0,0,.6);
  }
}

:root[data-theme="dark"]{
  --bg:        #000000;
  --bg-elev:   #1c1c1e;
  --bg-soft:   #2c2c2e;
  --bg-tint:   #3a3a3c;

  --ink-1:     #f5f5f7;
  --ink-2:     #d1d1d6;
  --ink-3:     #98989d;
  --ink-4:     #8e8e93;
  --ink-5:     #636366;

  --line:      rgba(255,255,255,.10);
  --line-2:    rgba(255,255,255,.16);

  --accent:        #0a84ff;
  --accent-hover:  #409cff;
  --accent-soft:   rgba(10,132,255,.16);

  --header-bg: rgba(0,0,0,.72);

  --shadow-1: 0 1px 2px rgba(0,0,0,.5), 0 4px 12px rgba(0,0,0,.4);
  --shadow-2: 0 2px 6px rgba(0,0,0,.6), 0 12px 32px rgba(0,0,0,.5);
  --shadow-3: 0 8px 28px rgba(0,0,0,.7), 0 24px 64px rgba(0,0,0,.6);
}

/* ─── 리셋 ─────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{
  background:var(--bg);
  color:var(--ink-1);
  font-family:'Pretendard','-apple-system',BlinkMacSystemFont,'SF Pro Display','SF Pro Text','Apple SD Gothic Neo',system-ui,sans-serif;
  font-size:16px;
  line-height:1.55;
  letter-spacing:-.011em;
  word-break:keep-all;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  transition:background .25s ease, color .25s ease;
}
html{scroll-behavior:smooth}
a{color:inherit;text-decoration:none;transition:color .15s}
a:hover{color:var(--accent)}
img{max-width:100%;height:auto;display:block}
button{font-family:inherit;cursor:pointer}
::selection{background:var(--accent);color:#fff}

/* ─── 타이포 스케일 ───────────────── */
.t-display{
  font-size:clamp(26px, 3.6vw, 40px);
  font-weight:700;
  line-height:1.18;
  letter-spacing:-.022em;
  color:var(--ink-1);
}
.t-headline{
  font-size:clamp(22px, 2.8vw, 32px);
  font-weight:700;
  line-height:1.22;
  letter-spacing:-.02em;
  color:var(--ink-1);
}
.t-title{
  font-size:clamp(18px, 2vw, 22px);
  font-weight:700;
  line-height:1.3;
  letter-spacing:-.018em;
  color:var(--ink-1);
}
.t-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 14px;border-radius:999px;
  background:var(--accent-soft);color:var(--accent);
  font-size:12.5px;font-weight:600;letter-spacing:.01em;
}
.t-eyebrow::before{content:"";width:5px;height:5px;border-radius:50%;background:currentColor}
.t-grad{
  background:var(--grad-1);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}

/* ─── 레이아웃 ──────────────────────────────────── */
.wrap{max-width:1200px;margin:0 auto;padding:0 24px}
.section{padding:clamp(64px,10vw,120px) 0}
.section-tight{padding:clamp(48px,7vw,80px) 0}

/* ─── 헤더 ──────────────────────────────────────── */
.header{
  position:sticky;top:0;z-index:100;
  background:var(--header-bg);
  backdrop-filter:saturate(180%) blur(20px);
  -webkit-backdrop-filter:saturate(180%) blur(20px);
  border-bottom:1px solid var(--line);
  padding:14px 24px;
  transition:background .25s ease, border-color .25s ease;
}
.header-inner{
  max-width:1200px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.logo{
  font-size:19px;font-weight:700;letter-spacing:-.02em;
  display:flex;align-items:center;gap:10px;color:var(--ink-1);
}
.logo:hover{color:var(--ink-1)}
.logo-dot{
  width:8px;height:8px;border-radius:50%;background:var(--accent);
  box-shadow:0 0 0 4px var(--accent-soft);
}
.search-mini{
  flex:1;max-width:420px;display:flex;align-items:center;
  background:var(--bg-soft);border:1px solid transparent;
  border-radius:12px;padding:5px 5px 5px 16px;
  transition:all .18s;
}
.search-mini:focus-within{
  background:var(--bg-elev);
  border-color:var(--accent);
  box-shadow:0 0 0 3px var(--accent-soft);
}
.search-mini input{
  flex:1;min-width:0;background:transparent;border:none;outline:none;
  padding:9px 4px;font:inherit;font-size:14.5px;color:var(--ink-1);
}
.search-mini input::placeholder{color:var(--ink-4)}
.search-mini button{
  background:var(--ink-1);color:var(--bg);border:none;
  padding:8px 16px;border-radius:8px;
  font-size:13px;font-weight:600;flex-shrink:0;
  transition:background .15s;
}
.search-mini button:hover{background:var(--accent)}

/* 다크모드 토글 */
.theme-toggle{
  width:38px;height:38px;border-radius:50%;
  background:var(--bg-soft);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;
  color:var(--ink-2);transition:all .18s;flex-shrink:0;
}
.theme-toggle:hover{background:var(--bg-tint);color:var(--ink-1);transform:scale(1.05)}
.theme-toggle .icon-sun{display:none}
.theme-toggle .icon-moon{display:block}
:root[data-theme="dark"] .theme-toggle .icon-sun{display:block}
:root[data-theme="dark"] .theme-toggle .icon-moon{display:none}
@media (prefers-color-scheme: dark){
  :root:not([data-theme="light"]) .theme-toggle .icon-sun{display:block}
  :root:not([data-theme="light"]) .theme-toggle .icon-moon{display:none}
}

/* ─── 카테고리 네비 (suburl) ───────────────────── */
.cat-nav{
  background:var(--bg-elev);
  border-bottom:1px solid var(--line);
  padding:12px 0;overflow-x:auto;scrollbar-width:none;
  transition:background .25s ease;
}
.cat-nav::-webkit-scrollbar{display:none}
.cat-nav-inner{
  max-width:1200px;margin:0 auto;padding:0 24px;
  display:flex;gap:6px;white-space:nowrap;
}
.cat-nav a{
  padding:8px 16px;border-radius:999px;
  background:var(--bg-soft);font-size:13.5px;font-weight:500;
  color:var(--ink-2);transition:all .15s;
}
.cat-nav a:hover,.cat-nav a.active{
  background:var(--ink-1);color:var(--bg);
}

/* ─── HERO ─────────────────────────────────────── */
.hero{
  padding:clamp(32px,5vw,56px) 0 clamp(24px,4vw,40px);
  text-align:center;position:relative;
}
.hero::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:radial-gradient(ellipse at top, var(--accent-soft) 0%, transparent 55%);
  opacity:.5;
}
.hero h1{margin:14px 0 12px}
.hero p.lead{
  font-size:clamp(14.5px,1.5vw,17px);
  color:var(--ink-3);max-width:560px;margin:0 auto;
  line-height:1.55;letter-spacing:-.012em;
}
.hero .stats{
  display:inline-flex;gap:6px;margin-top:16px;
  font-size:13px;color:var(--ink-4);font-weight:500;
}
.hero .stats b{color:var(--accent);font-weight:700}

/* ─── 메인 그리드 ───────────────────────────── */
.main-grid{
  display:grid;grid-template-columns:1fr 340px;gap:40px;
  margin-bottom:64px;
}

/* ─── 섹션 ──────────────────────────────────── */
.section-card{
  background:var(--bg-elev);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  overflow:hidden;
  transition:background .25s ease, border-color .25s ease;
}
.section-card+.section-card{margin-top:24px}
.section-card-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 26px 18px;border-bottom:1px solid var(--line);
}
.section-card-head h2{
  font-size:18px;font-weight:700;letter-spacing:-.018em;color:var(--ink-1);
}
.section-card-head .more{font-size:13px;color:var(--ink-3);font-weight:500}
.section-card-head .more:hover{color:var(--accent)}

/* ─── Q&A 리스트 ───────────────────────────── */
.qa-list{list-style:none}
.qa-item{
  padding:16px 26px;border-bottom:1px solid var(--line);
  display:flex;gap:14px;align-items:flex-start;
  transition:background .12s;
}
.qa-item:last-child{border-bottom:none}
.qa-item:hover{background:var(--bg-soft)}
.qa-cate{
  flex-shrink:0;font-size:11.5px;font-weight:700;letter-spacing:.02em;
  color:var(--accent);background:var(--accent-soft);padding:4px 10px;border-radius:6px;
  white-space:nowrap;line-height:1.5;
}
.qa-body{flex:1;min-width:0}
.qa-title{
  font-size:15.5px;font-weight:600;color:var(--ink-1);line-height:1.45;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
  letter-spacing:-.013em;
}
.qa-meta{
  font-size:12.5px;color:var(--ink-4);margin-top:6px;
  display:flex;gap:10px;align-items:center;
}
.qa-meta .dot{color:var(--ink-5)}

/* ─── 카테고리 컬러 박스 그리드 (apple.com 식 그라데이션 카드) ─── */
.cat-grid{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:20px;margin:32px 0 64px;
}
.cat-card{
  position:relative;overflow:hidden;
  border-radius:var(--radius-xl);
  padding:28px 26px;
  background:var(--bg-elev);
  border:1px solid var(--line);
  transition:transform .25s, box-shadow .25s, border-color .25s;
}
.cat-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-3);
  border-color:transparent;
}
.cat-card .cat-card-head{
  display:flex;align-items:center;justify-content:space-between;
  padding-bottom:14px;margin-bottom:14px;
  border-bottom:1px solid var(--line);
}
.cat-card .cat-card-head h3{
  font-size:18px;font-weight:700;letter-spacing:-.02em;
  display:flex;align-items:center;gap:10px;
}
.cat-card .cat-card-head .badge{
  font-size:12px;font-weight:600;color:var(--ink-4);
  background:var(--bg-soft);padding:4px 10px;border-radius:999px;
}
.cat-card .cat-mark{
  width:10px;height:10px;border-radius:50%;background:var(--cat-1);
  box-shadow:0 0 0 4px color-mix(in srgb, var(--cat-1) 18%, transparent);
}
.cat-card ul{list-style:none}
.cat-card li{padding:8px 0;font-size:14px;border-bottom:1px solid var(--line)}
.cat-card li:last-child{border-bottom:none}
.cat-card li a{
  color:var(--ink-2);
  display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;
}
.cat-card li a:hover{color:var(--accent)}
.cat-card .empty{color:var(--ink-4);font-size:13px;padding:8px 0}

/* 카테고리별 액센트 (id 모듈로 순환) */
.cat-card[data-cate="1"]  .cat-mark{background:var(--cat-1); box-shadow:0 0 0 4px color-mix(in srgb,var(--cat-1) 18%,transparent)}
.cat-card[data-cate="2"]  .cat-mark{background:var(--cat-2); box-shadow:0 0 0 4px color-mix(in srgb,var(--cat-2) 18%,transparent)}
.cat-card[data-cate="3"]  .cat-mark{background:var(--cat-3); box-shadow:0 0 0 4px color-mix(in srgb,var(--cat-3) 18%,transparent)}
.cat-card[data-cate="4"]  .cat-mark{background:var(--cat-4); box-shadow:0 0 0 4px color-mix(in srgb,var(--cat-4) 18%,transparent)}
.cat-card[data-cate="5"]  .cat-mark{background:var(--cat-5); box-shadow:0 0 0 4px color-mix(in srgb,var(--cat-5) 18%,transparent)}
.cat-card[data-cate="6"]  .cat-mark{background:var(--cat-6); box-shadow:0 0 0 4px color-mix(in srgb,var(--cat-6) 18%,transparent)}
.cat-card[data-cate="7"]  .cat-mark{background:var(--cat-7); box-shadow:0 0 0 4px color-mix(in srgb,var(--cat-7) 18%,transparent)}
.cat-card[data-cate="8"]  .cat-mark{background:var(--cat-8); box-shadow:0 0 0 4px color-mix(in srgb,var(--cat-8) 18%,transparent)}
.cat-card[data-cate="9"]  .cat-mark{background:var(--cat-9); box-shadow:0 0 0 4px color-mix(in srgb,var(--cat-9) 18%,transparent)}
.cat-card[data-cate="10"] .cat-mark{background:var(--cat-10);box-shadow:0 0 0 4px color-mix(in srgb,var(--cat-10) 18%,transparent)}

/* ─── Feature 카드 (apple.com hero card 스타일) ─── */
.feature-card{
  position:relative;overflow:hidden;
  border-radius:var(--radius-xl);
  padding:48px;color:#fff;
  background:var(--grad-1);
  min-height:280px;display:flex;flex-direction:column;justify-content:space-between;
  margin-bottom:32px;
}
.feature-card .eyebrow{
  font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:rgba(255,255,255,.78);margin-bottom:14px;
  display:flex;align-items:center;gap:10px;
}
.feature-card .eyebrow::before{content:"";width:20px;height:1px;background:rgba(255,255,255,.6)}
.feature-card h3{
  font-size:clamp(28px,3.4vw,40px);
  font-weight:700;letter-spacing:-.025em;line-height:1.1;
  margin-bottom:16px;
}
.feature-card p{
  font-size:16px;line-height:1.55;color:rgba(255,255,255,.9);
  max-width:520px;margin-bottom:auto;
}
.feature-card .stats{
  margin-top:22px;display:flex;gap:24px;
  padding-top:22px;border-top:1px solid rgba(255,255,255,.22);
  font-size:14px;color:rgba(255,255,255,.86);font-weight:500;
}
.feature-card .stats b{color:#fff;font-weight:700;margin-right:4px}

/* ─── 사이드 (인기) ───────────────────────── */
.side{position:sticky;top:84px}
.popular-list{list-style:none;counter-reset:rk}
.popular-list li{
  counter-increment:rk;padding:13px 26px;
  border-bottom:1px solid var(--line);
  display:flex;gap:14px;align-items:flex-start;
}
.popular-list li:last-child{border-bottom:none}
.popular-list li::before{
  content:counter(rk);flex-shrink:0;
  font-size:14px;font-weight:700;color:var(--ink-4);width:20px;line-height:1.4;
}
.popular-list li:nth-child(-n+3)::before{color:var(--accent)}
.popular-list a{
  font-size:14px;color:var(--ink-2);line-height:1.45;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.popular-list a:hover{color:var(--accent)}

/* ─── 사이드 박스 ─────────────────────────── */
.side-box{
  background:var(--bg-elev);border:1px solid var(--line);
  border-radius:var(--radius-lg);padding:22px;margin-bottom:20px;
  transition:background .25s ease;
}
.side-box h3{font-size:14px;font-weight:700;color:var(--ink-1);margin-bottom:14px;letter-spacing:-.018em}
.side-box ul{list-style:none}
.side-box li{padding:8px 0;font-size:13.5px;border-bottom:1px solid var(--line)}
.side-box li:last-child{border-bottom:none}
.side-box a{
  color:var(--ink-2);
  display:flex;justify-content:space-between;align-items:center;gap:8px;
}
.side-box a:hover{color:var(--accent)}
.side-box .num{color:var(--ink-4);font-size:11.5px}

/* ─── 광고 슬롯 ───────────────────────────── */
.ad-slot{
  margin:24px 0;padding:18px;
  background:var(--bg-elev);border:1px dashed var(--line-2);
  border-radius:var(--radius);
  text-align:center;color:var(--ink-4);font-size:12.5px;
  min-height:90px;display:flex;align-items:center;justify-content:center;
}

/* ─── 빵부스러기 ──────────────────────────── */
.crumb{
  padding:24px 0 12px;font-size:13.5px;color:var(--ink-3);
  display:flex;align-items:center;gap:6px;flex-wrap:wrap;
}
.crumb a:hover{color:var(--accent)}
.crumb .sep{color:var(--ink-5)}

/* ─── 카테고리 헤더 ───────────────────────── */
.cate-head{
  padding:24px 0 28px;border-bottom:1px solid var(--line);margin-bottom:24px;
  text-align:left;
}
.cate-head .t-eyebrow{margin-bottom:12px;font-size:11.5px;padding:5px 12px}
.cate-head h1{font-size:clamp(22px,3vw,32px);font-weight:700;line-height:1.18;letter-spacing:-.02em;color:var(--ink-1);margin-bottom:6px}
.cate-head .desc{font-size:14.5px;color:var(--ink-3);max-width:680px;line-height:1.55}
.cate-head .cnt{display:inline-block;margin-top:10px;font-size:13px;color:var(--ink-4);font-weight:500}
.cate-head .cnt b{color:var(--accent);font-weight:700}

/* ─── 큰 Q&A 리스트 (카테고리·검색) ───── */
.qa-list-large{
  background:var(--bg-elev);border:1px solid var(--line);
  border-radius:var(--radius-lg);overflow:hidden;list-style:none;
}
.qa-list-large .qa-item{padding:22px 26px}
.qa-list-large .qa-title{font-size:17px;line-height:1.45;margin-bottom:8px;display:block}
.qa-list-large .qa-desc{
  font-size:14px;color:var(--ink-3);line-height:1.6;margin-bottom:10px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}

/* ─── 페이지네이션 ───────────────────────── */
.pager{
  display:flex;justify-content:center;gap:8px;margin:40px 0;flex-wrap:wrap;
}
.pager a,.pager span{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:42px;height:42px;padding:0 14px;border-radius:10px;
  border:1px solid var(--line);background:var(--bg-elev);
  font-size:14px;font-weight:500;color:var(--ink-2);
  transition:all .15s;
}
.pager a:hover{background:var(--bg-soft);color:var(--accent);border-color:var(--accent)}
.pager .current{background:var(--ink-1);color:var(--bg);border-color:var(--ink-1);font-weight:700}
.pager .ellipsis{border:none;background:transparent;color:var(--ink-4)}

/* ─── 글 상세 (article.post) ───────────── */
article.post{
  background:var(--bg-elev);border:1px solid var(--line);
  border-radius:var(--radius-xl);padding:48px clamp(24px,4vw,56px);
  transition:background .25s ease;
}
.post-cate{
  display:inline-block;font-size:12px;font-weight:700;letter-spacing:.04em;
  color:var(--accent);background:var(--accent-soft);padding:5px 12px;border-radius:6px;
  margin-bottom:18px;text-transform:uppercase;
}
.post h1{
  font-size:clamp(26px,3.4vw,40px);font-weight:700;letter-spacing:-.025em;
  line-height:1.18;color:var(--ink-1);margin-bottom:18px;
}
.post-meta{
  display:flex;gap:14px;font-size:13.5px;color:var(--ink-4);
  padding-bottom:28px;border-bottom:1px solid var(--line);margin-bottom:36px;
}
.qa-block{margin-bottom:32px}
.qa-block .qa-row{display:flex;align-items:flex-start;gap:14px}
.qa-block .qlabel,.qa-block .alabel{
  display:inline-flex;align-items:center;justify-content:center;
  width:32px;height:32px;border-radius:50%;
  font-weight:700;font-size:14px;flex-shrink:0;
  margin-top:2px;
}
.qa-block .qlabel{background:var(--accent);color:#fff}
.qa-block .alabel{background:var(--ink-1);color:var(--bg)}
.qa-content{
  flex:1;min-width:0;
  color:var(--ink-2);
  font-size:16px;line-height:1.78;letter-spacing:-.011em;
}
.qa-block .qa-row.answer .qa-content{color:var(--ink-1)}
.qa-content p{margin-bottom:14px}
.qa-content p:last-child{margin-bottom:0}

.tags{
  margin-top:28px;padding-top:24px;border-top:1px solid var(--line);
  display:flex;flex-wrap:wrap;gap:8px;
}
.tag{
  font-size:12.5px;font-weight:500;color:var(--ink-3);
  background:var(--bg-soft);padding:6px 12px;border-radius:999px;
  transition:all .15s;
}
.tag:hover{background:var(--accent-soft);color:var(--accent)}

.prevnext{
  display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:32px;
}
.prevnext a{
  padding:18px 22px;background:var(--bg-elev);border:1px solid var(--line);
  border-radius:var(--radius);transition:all .18s;
  display:flex;flex-direction:column;gap:6px;
}
.prevnext a:hover{border-color:var(--accent);background:var(--accent-soft);transform:translateY(-2px)}
.prevnext .label{
  font-size:11.5px;font-weight:700;color:var(--ink-4);letter-spacing:.05em;text-transform:uppercase;
}
.prevnext .ttl{font-size:14.5px;color:var(--ink-1);font-weight:500;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}
.prevnext .next{text-align:right}

.related{
  background:var(--bg-elev);border:1px solid var(--line);
  border-radius:var(--radius-lg);padding:26px;margin-top:32px;
}
.related h3{font-size:16px;font-weight:700;color:var(--ink-1);margin-bottom:14px;letter-spacing:-.018em}
.related ul{list-style:none}
.related li{padding:11px 0;border-bottom:1px solid var(--line);font-size:14.5px}
.related li:last-child{border-bottom:none}
.related a{color:var(--ink-2);display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}
.related a:hover{color:var(--accent)}

.layout-2col{display:grid;grid-template-columns:1fr 340px;gap:40px;margin-bottom:64px}

/* ─── 빈 상태 ──────────────────────────────── */
.empty{
  padding:96px 28px;text-align:center;color:var(--ink-4);font-size:15px;
}
.empty small{display:block;margin-top:8px;font-size:13px;color:var(--ink-5)}

/* ─── 푸터 ────────────────────────────────── */
.footer{
  background:var(--bg-soft);border-top:1px solid var(--line);
  padding:48px 0 24px;margin-top:80px;color:var(--ink-2);
  transition:background .25s ease;
}
.footer-grid{
  max-width:1200px;margin:0 auto;padding:0 24px;
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:36px;margin-bottom:32px;
}
.footer-brand{font-size:22px;font-weight:700;letter-spacing:-.022em;color:var(--ink-1);margin-bottom:10px}
.footer-brand .grad{background:var(--grad-1);-webkit-background-clip:text;background-clip:text;color:transparent}
.footer-brand-sub{font-size:14px;color:var(--ink-3);max-width:320px;line-height:1.55}
.footer h4{font-size:13px;font-weight:700;color:var(--ink-1);margin-bottom:12px;letter-spacing:-.011em}
.footer ul{list-style:none}
.footer li{margin-bottom:8px}
.footer a{color:var(--ink-3);font-size:13.5px}
.footer a:hover{color:var(--ink-1)}
.footer-bottom{
  border-top:1px solid var(--line);padding:18px 24px 0;
  max-width:1200px;margin:0 auto;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
  font-size:12.5px;color:var(--ink-4);
}
.footer-bottom a{color:var(--ink-4)}
.footer-bottom a:hover{color:var(--ink-2)}

/* ─── 검색 페이지 ──────────────────────── */
.search-page{max-width:1000px;margin:0 auto;padding:32px 24px 64px}
.search-summary{font-size:15px;color:var(--ink-3);margin-bottom:22px}
.search-summary b{color:var(--accent);font-weight:700}
.search-page .search-form{
  display:flex;background:var(--bg-soft);border-radius:14px;padding:7px 7px 7px 18px;
  margin-bottom:32px;border:1px solid transparent;transition:all .18s;
}
.search-page .search-form:focus-within{
  background:var(--bg-elev);border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft);
}
.search-page .search-form input{
  flex:1;background:transparent;border:none;outline:none;
  padding:11px 4px;font:inherit;font-size:16px;color:var(--ink-1);
}
.search-page .search-form button{
  background:var(--ink-1);color:var(--bg);border:none;
  padding:10px 22px;border-radius:9px;font:inherit;font-weight:600;
}

/* ─── 페이드인 애니메이션 ─────────────── */
.fade-in{opacity:0;transform:translateY(16px);transition:opacity .6s ease, transform .6s ease}
.fade-in.is-visible{opacity:1;transform:translateY(0)}
@media (prefers-reduced-motion: reduce){
  .fade-in,html{transition:none !important;animation:none !important}
  .fade-in{opacity:1;transform:none}
}

/* ─── 반응형 ─────────────────────────── */
@media(max-width:1000px){
  .main-grid,.layout-2col{grid-template-columns:1fr;gap:32px}
  .side{position:static}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .header{padding:12px 16px}
  .header-inner .search-mini{display:none}
  .wrap{padding:0 16px}
  .cat-grid{grid-template-columns:1fr}
  article.post{padding:28px 22px}
  .qa-block .qa-row{gap:10px}
  .qa-block .qlabel,.qa-block .alabel{width:28px;height:28px;font-size:13px}
  .footer-grid{grid-template-columns:1fr;gap:24px}
  .footer{padding:36px 0 20px}
  .prevnext{grid-template-columns:1fr}
}

/* ─── 시각 보정 (다크모드 광고/카드) ─── */
:root[data-theme="dark"] .feature-card,
@media (prefers-color-scheme: dark){:root:not([data-theme="light"]) .feature-card{}}
