/* xNote 테마 변수 */
:root[data-theme="dark"] {
  --bg-primary:   #0f0f0f;
  --bg-secondary: #1a1a1a;
  --bg-panel:     #141414;
  --bg-input:     #1f1f1f;
  --bg-hover:     #242424;
  --text-primary: #e8e8e8;
  --text-secondary: #999;
  --text-muted:   #666;
  --border:       #2a2a2a;
  --border-focus: #4f9cf9;
  --accent:       #4f9cf9;
  --accent-hover: #3d85e0;
  --accent-text:  #fff;
  --danger:       #e55;
  --danger-hover: #c33;
  --success:      #4caf50;
  --shadow:       rgba(0,0,0,.5);
  --overlay:      rgba(0,0,0,.7);
}

:root[data-theme="light"] {
  --bg-primary:   #ffffff;
  --bg-secondary: #f5f5f5;
  --bg-panel:     #fafafa;
  --bg-input:     #fff;
  --bg-hover:     #f0f0f0;
  --text-primary: #1a1a1a;
  --text-secondary: #666;
  --text-muted:   #999;
  --border:       #ddd;
  --border-focus: #2563eb;
  --accent:       #2563eb;
  --accent-hover: #1d4ed8;
  --accent-text:  #fff;
  --danger:       #dc2626;
  --danger-hover: #b91c1c;
  --success:      #16a34a;
  --shadow:       rgba(0,0,0,.12);
  --overlay:      rgba(0,0,0,.5);
}

/* Vue 마운트 전 템플릿 노출 방지 */
[v-cloak] { display: none !important; }

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { font-size: 16px; -webkit-text-size-adjust: 100%; }

body {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Noto Sans KR', sans-serif;
  background: var(--bg-primary);
  color: var(--text-primary);
  line-height: 1.6;
  min-height: 100vh;
  transition: background .2s, color .2s;
}

a { color: var(--text-primary); text-decoration: none; }
a:hover { color: var(--accent-hover); }

button {
  cursor: pointer;
  border: none;
  background: none;
  font: inherit;
  color: inherit;
}

input, textarea, select {
  font: inherit;
  color: var(--text-primary);
  background: var(--bg-input);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: .45rem .7rem;
  outline: none;
  width: 100%;
  transition: border-color .15s;
}
input:focus, textarea:focus, select:focus { border-color: var(--border-focus); }

/* 버튼 */
.btn {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  padding: .5rem 1.1rem;
  border-radius: 6px;
  font-size: .9375rem;
  font-weight: 500;
  transition: background .15s, color .15s;
  white-space: nowrap;
}
.btn-primary { background: var(--accent); color: var(--accent-text); }
.btn-primary:hover { background: var(--accent-hover); }
.btn-ghost { border: 1px solid var(--border); }
.btn-ghost:hover { background: var(--bg-hover); }
.btn-danger { background: var(--danger); color: #fff; }
.btn-danger:hover { background: var(--danger-hover); }
.btn-sm { padding: .35rem .8rem; font-size: .875rem; }

/* 레이아웃 — html/body 고정 높이로 각 패널 독립 스크롤 */
html, body { height: 100%; overflow: hidden; }
#app { display: flex; flex-direction: column; height: 100vh; overflow: hidden; }

/* 헤더 */
#header {
  position: sticky; top: 0; z-index: 100;
  display: flex; align-items: center; gap: .75rem;
  padding: 0 1rem;
  height: 56px;
  background: var(--bg-panel);
  border-bottom: 1px solid var(--border);
}
#header .logo { font-size: 1.15rem; font-weight: 700; color: var(--accent); flex-shrink: 0; }
#header .search-wrap { flex: 1; max-width: 420px; }
#header .search-wrap input { height: 36px; font-size: .9375rem; }
#header .header-right { display: flex; align-items: center; gap: .5rem; margin-left: auto; }
#header .quota-info { font-size: .875rem; color: var(--text-secondary); white-space: nowrap; }

/* 메인 3단 */
#main { display: flex; flex: 1; overflow: hidden; }

#left-panel {
  width: 240px; flex-shrink: 0;
  border-right: 1px solid var(--border);
  overflow-y: auto;
  background: var(--bg-panel);
}
#center { flex: 1; overflow-y: auto; min-width: 0; }
#right-panel {
  width: 240px; flex-shrink: 0;
  border-left: 1px solid var(--border);
  overflow-y: auto;
  background: var(--bg-panel);
}

/* 모바일 */
@media (max-width: 767px) {
  #left-panel, #right-panel { display: none; }
  #header { padding: 0 .5rem; height: 52px; }
  #header .quota-info { display: none; }
  #center { padding-bottom: 60px; }

  #mobile-nav {
    display: flex;
    position: fixed; bottom: 0; left: 0; right: 0;
    height: 60px;
    background: var(--bg-panel);
    border-top: 1px solid var(--border);
    z-index: 100;
  }
  #mobile-nav button {
    flex: 1; display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    gap: 3px; font-size: .75rem; color: var(--text-secondary);
  }
  #mobile-nav button.active { color: var(--accent); }
  #mobile-nav button svg { width: 24px; height: 24px; }
}
@media (min-width: 768px) {
  #mobile-nav { display: none; }
  #main { flex: 1; min-height: 0; }
  .mobile-cat-backdrop { display: none !important; }
}

/* 모바일 카테고리 슬라이드업 패널 */
.mobile-cat-backdrop {
  position: fixed; inset: 0; z-index: 200;
  background: rgba(0,0,0,.5);
  display: flex; flex-direction: column; justify-content: flex-end;
}
.mobile-cat-panel {
  background: var(--bg-secondary);
  border-radius: 16px 16px 0 0;
  max-height: 72vh; overflow-y: auto;
  padding-bottom: 68px;
  animation: slideUp .22s ease;
}
@keyframes slideUp { from{transform:translateY(100%)} to{transform:translateY(0)} }
.mobile-cat-hdr {
  display: flex; align-items: center; justify-content: space-between;
  padding: .85rem 1.1rem .6rem;
  border-bottom: 1px solid var(--border);
  font-size: 1rem; position: sticky; top: 0;
  background: var(--bg-secondary);
}
.mobile-cat-item {
  display: flex; align-items: center; gap: .65rem;
  padding: .75rem 1.1rem; font-size: 1rem;
  border-bottom: 1px solid var(--border);
  cursor: pointer; transition: background .1s;
}
.mobile-cat-item:hover, .mobile-cat-item:active { background: var(--bg-hover); }
@media (max-width: 1279px) {
  #left-panel { width: 200px; }
  #right-panel { display: none; }
}

/* ── 에디터 레이아웃 ─────────────────────────────── */
.editor-wrap {
  display: flex; flex-direction: column;
  height: 100%; overflow: hidden;
}
.editor-header {
  display: flex; align-items: center; gap: .5rem;
  padding: .55rem 1rem;
  border-bottom: 1px solid var(--border);
  background: var(--bg-panel);
  flex-shrink: 0;
}
.editor-meta {
  display: flex; align-items: center; gap: .5rem;
  padding: .55rem 1rem;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.editor-toolbar {
  display: flex; align-items: center; flex-wrap: wrap; gap: .15rem;
  padding: .4rem .75rem;
  border-bottom: 1px solid var(--border);
  background: var(--bg-panel);
  flex-shrink: 0;
}
.tb-group { display: flex; gap: .1rem; }
.tb-sep { width: 1px; height: 20px; background: var(--border); margin: 0 .25rem; }
.tb-btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 30px; height: 30px; border-radius: 4px; font-size: .875rem;
  border: 1px solid transparent; cursor: pointer;
  background: none; color: var(--text-primary);
  transition: background .12s;
}
.tb-btn:hover { background: var(--bg-hover); border-color: var(--border); }
.tb-btn.active { background: var(--bg-hover); color: var(--accent); border-color: var(--accent); }

/* 색상 피커 */
.tb-colorpicker { position: relative; display: inline-flex; }
.tb-color-label {
  display: flex; flex-direction: column; align-items: center; gap: 1px; font-weight: 700; font-size: .85rem;
}
.tb-color-label::after { content: ''; display: block; width: 12px; height: 3px; background: var(--uc, #e55); border-radius: 1px; }
.tb-color-bg-label { font-size: .72rem; font-weight: 600; }
.tb-color-popup {
  position: absolute; top: 100%; left: 0; z-index: 200;
  display: flex; flex-wrap: wrap; gap: 3px; padding: 6px;
  background: var(--bg-secondary); border: 1px solid var(--border);
  border-radius: 8px; box-shadow: 0 4px 16px var(--shadow);
  width: 140px;
}
.tb-clr {
  width: 18px; height: 18px; border-radius: 3px; cursor: pointer;
  border: 1px solid rgba(128,128,128,.25); flex-shrink: 0;
  transition: transform .1s;
}
.tb-clr:hover { transform: scale(1.2); }
.tb-clr-reset { display: flex; align-items: center; justify-content: center; font-size: .65rem; background: var(--bg-primary); }

/* 소스 에디터 */
.editor-source {
  flex: 1 1 0; min-height: 120px; overflow-y: auto;
  padding: 1rem 1.25rem;
  font-family: 'Fira Code', 'Cascadia Code', monospace;
  font-size: .875rem; line-height: 1.6;
  resize: none; border: none; border-radius: 0;
  background: var(--bg-secondary); color: var(--text-primary);
}

.editor-body {
  flex: 1 1 0;
  overflow-y: auto;
  padding: 1.25rem 1.5rem;
  outline: none;
  line-height: 1.8; font-size: 1rem;
  min-height: 120px;
}
.editor-body:empty::before {
  content: attr(placeholder);
  color: var(--text-muted);
  pointer-events: none;
}
.editor-body h1 { font-size: 1.6rem; margin: 1em 0 .4em; }
.editor-body h2 { font-size: 1.3rem; margin: 1em 0 .4em; }
.editor-body h3 { font-size: 1.1rem; margin: .8em 0 .3em; }
.editor-body blockquote { border-left: 3px solid var(--accent); padding-left: .75rem; color: var(--text-secondary); margin: .5em 0; }
.editor-body pre { background: var(--bg-secondary); border: 1px solid var(--border); border-radius: 6px; padding: .75rem 1rem; font-size: .9rem; overflow-x: auto; margin: .5em 0; }
.editor-body code { font-family: 'Fira Code','Cascadia Code',monospace; background: var(--bg-secondary); padding: .1em .35em; border-radius: 3px; font-size: .9em; }
.editor-body pre code { background: none; padding: 0; }
.editor-body img { max-width: 100%; border-radius: 6px; }
.editor-body ul, .editor-body ol { padding-left: 1.75rem; margin: .35em 0; }
.editor-body ul { list-style-type: disc; }
.editor-body ol { list-style-type: decimal; }
.editor-body li { margin: .15em 0; }
.editor-body ul ul { list-style-type: circle; }
.editor-body ul ul ul { list-style-type: square; }
.editor-body hr { border: none; border-top: 1px solid var(--border); margin: 1em 0; }
.editor-body a { color: var(--accent); }
.editor-body table { border-collapse: collapse; width: 100%; margin: .5em 0; }
.editor-body td, .editor-body th { border: 1px solid var(--border); padding: .35rem .6rem; }
.editor-body th { background: var(--bg-secondary); }

.editor-footer {
  border-top: 1px solid var(--border);
  background: var(--bg-panel);
  flex: 0 1 auto;          /* 내용만큼 차지하되 필요 시 줄어듦 */
  min-height: 0;
  max-height: 50vh;        /* 뷰포트 절반 초과 금지 */
  overflow-y: auto;
  padding-bottom: .5rem;   /* 하단 여백 */
}
.editor-section { padding: .65rem 1rem; border-bottom: 1px solid var(--border); }
.editor-section:last-child { border-bottom: none; }
.editor-section-label { font-size: .875rem; font-weight: 600; color: var(--text-muted); text-transform: uppercase; letter-spacing: .04em; margin-bottom: .4rem; }
.tag-editor-chip {
  display: inline-flex; align-items: center;
  padding: .2rem .55rem; background: var(--bg-secondary);
  border: 1px solid var(--border); border-radius: 20px; font-size: .875rem;
}
.file-list { display: flex; flex-direction: column; gap: .35rem; margin-top: .35rem; }
.file-item {
  display: flex; align-items: center; gap: .5rem;
  padding: .35rem .6rem; background: var(--bg-secondary);
  border: 1px solid var(--border); border-radius: 6px;
}
.file-icon { width: 40px; height: 40px; display:flex;align-items:center;justify-content:center; font-size: 1.4rem; flex-shrink:0; }

@media (max-width: 767px) {
  .editor-header { padding: .4rem .5rem; }
  .editor-meta { padding: .4rem .5rem; }
  .editor-body { padding: .75rem .75rem; }
  .editor-section { padding: .5rem .75rem; }
}

/* ── 노트 카드 (좌측 패널) ───────────────────────── */
.note-card {
  padding: .75rem .85rem;
  border-bottom: 1px solid var(--border);
  cursor: pointer;
  transition: background .12s;
}
.note-card:hover, .note-card.active { background: var(--bg-hover); }
/* 썸네일 있을 때 좌우 분할 */
.nc-row { display: flex; gap: .5rem; align-items: flex-start; }
.nc-thumb-sm {
  width: 30%; flex-shrink: 0;
  aspect-ratio: 1 / 1;
  object-fit: cover; border-radius: 5px;
  background: var(--bg-secondary);
}
.nc-info { flex: 1; min-width: 0; }
.note-card .nc-category { font-size: .8125rem; color: var(--accent); margin-bottom: .2rem; display:flex; align-items:center; gap:.3rem; }
.note-card .nc-title { font-size: .9375rem; font-weight: 600; line-height: 1.35; margin-bottom: .25rem;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.note-card .nc-excerpt { font-size: .875rem; color: var(--text-secondary);
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.note-card .nc-date { font-size: .8125rem; color: var(--text-muted); margin-top: .3rem; }
.nc-cmt { color: var(--accent); font-size: .85em; font-weight: 400; margin-left: .15rem; }

/* 우측 패널 */
.panel-section { padding: .85rem .85rem .55rem .85rem; border-bottom: 1px solid var(--border); }
.panel-title { font-size: 1rem; font-weight: 600; color: var(--accent);
  text-transform: uppercase; letter-spacing: .03em; padding-bottom:0.8rem !important;margin-bottom: .55rem; border-bottom: 1px solid var(--border);}
.tag-chip {
  display: inline-block; padding: .25rem .6rem;
  background: var(--bg-secondary); border: 1px solid var(--border);
  border-radius: 20px; font-size: .875rem; margin: .2rem .15rem 0 0;
  cursor: pointer; transition: background .12s;
}
.tag-chip:hover { background: var(--accent); color: var(--accent-text); border-color: var(--accent); }
.skin-badge {
  font-size: .75rem; padding: .1rem .4rem;
  background: var(--accent); color: var(--accent-text);
  border-radius: 10px; flex-shrink: 0;
}

/* 뷰어 / 상세 */
.note-view { padding: 1.25rem 1.75rem; width: 100%; max-width: 100%; }
.note-view h1 { font-size: 1.6rem; line-height: 1.3; margin-bottom: .5rem; }
.note-meta { font-size: .9375rem; color: var(--text-secondary); display: flex; gap: .75rem; flex-wrap: wrap; margin-bottom: 1rem; padding-bottom: 1rem;border-bottom:var(--border) solid 1px;}
.note-content { line-height: 1.8; font-size: 1rem; }
.note-content h1, .note-content h2, .note-content h3 { margin: 1.2em 0 .5em; }
.note-content p { margin-bottom: .8em; }
.note-content pre { background: var(--bg-secondary); border: 1px solid var(--border);
  border-radius: 6px; padding: .75rem 1rem; overflow-x: auto; font-size: .9rem; margin: .8em 0; }
.note-content code { font-family: 'Fira Code', 'Cascadia Code', monospace; }
.note-content blockquote { border-left: 3px solid var(--accent); padding-left: .75rem;
  color: var(--text-secondary); margin: .8em 0; }
.note-content img { max-width: 100%; border-radius: 6px; }
.note-content table { border-collapse: collapse; width: 100%; margin: .8em 0; }
.note-content td, .note-content th { border: 1px solid var(--border); padding: .4rem .6rem; text-align: left; }
.note-content th { background: var(--bg-secondary); }
.note-content ul, .note-content ol { padding-left: 1.75rem; margin: .35em 0; }
.note-content ul { list-style-type: disc; }
.note-content ol { list-style-type: decimal; }
.note-content li { margin: .15em 0; }
.note-content ul ul { list-style-type: circle; }
.note-content ul ul ul { list-style-type: square; }

@media (max-width: 767px) {
  .note-view { padding: .75rem .75rem; }
  .note-view h1 { font-size: 1.3rem; }
}

/* 폼 */
.form-group { margin-bottom: 1.1rem; }
.form-label { display: block; font-size: .9375rem; font-weight: 500; margin-bottom: .4rem; }
.form-hint  { font-size: .875rem; color: var(--text-muted); margin-top: .3rem; }

/* 토스트 */
#toast-container {
  position: fixed; bottom: 70px; left: 50%; transform: translateX(-50%);
  z-index: 9999; display: flex; flex-direction: column; gap: .4rem; align-items: center;
  pointer-events: none;
}
.toast {
  padding: .6rem 1.25rem; border-radius: 20px; font-size: .9375rem;
  background: var(--bg-secondary); border: 1px solid var(--border);
  box-shadow: 0 4px 12px var(--shadow); pointer-events: auto;
  animation: fadeInUp .2s ease;
}
.toast.error { background: var(--danger); color: #fff; border-color: transparent; }
.toast.success { background: var(--success); color: #fff; border-color: transparent; }
@keyframes fadeInUp { from { opacity:0; transform:translateY(8px); } to { opacity:1; transform:translateY(0); } }

/* 모달 */
.modal-bg {
  position: fixed; inset: 0; background: var(--overlay);
  z-index: 500; display: flex; align-items: center; justify-content: center;
  padding: 1rem;
}
.modal {
  background: var(--bg-secondary); border: 1px solid var(--border);
  border-radius: 12px; width: 100%; max-width: 440px;
  padding: 1.5rem; box-shadow: 0 8px 32px var(--shadow);
}
.modal h2 { font-size: 1.15rem; margin-bottom: 1.25rem; }
.modal-actions { display: flex; gap: .5rem; justify-content: flex-end; margin-top: 1.25rem; }

/* 로딩 스피너 */
.spinner {
  width: 36px; height: 36px; border-radius: 50%;
  border: 3px solid var(--border);
  border-top-color: var(--accent);
  animation: spin .7s linear infinite;
  margin: 2rem auto;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* 갤러리 스킨: content 내 인라인 이미지 숨김 (masonry만 표시) */
.note-view.skin-gallery .note-content img { display: none; }

/* ── 노트 내 갤러리 (게시물 단위) ──────────────────── */
.note-gallery {
  columns: 4; column-gap: 5px; margin-top: .5rem;
}
.note-gallery-item {
  break-inside: avoid; margin-bottom: 5px;
  border-radius: 5px; overflow: hidden;
  cursor: zoom-in; background: var(--bg-secondary);
}
.note-gallery-item img { display: block; width: 100%; height: auto; transition: transform .2s; }
.note-gallery-item:hover img { transform: scale(1.02); }
@media (max-width: 767px) { .note-gallery { columns: 2; } }
@media (max-width: 1279px) { .note-gallery { columns: 3; } }

/* ── 스킨 아이콘 (Lucide SVG) ── */
.cat-link {
  display: flex; align-items: center; gap: .5rem;
  font-size: .9375rem; padding: .15rem 0;
  color: var(--text-primary); transition: color .12s;
}
.cat-link:hover { color: var(--accent); }
.cat-link.active { color: var(--accent); font-weight: 600; }

/* 아이콘 고정 너비 컨테이너 */
.cat-icon, .nc-skin-icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 16px; flex-shrink: 0;
}
.cat-icon svg, .nc-skin-icon svg {
  width: 14px; height: 14px;
  stroke: currentColor; vertical-align: middle;
}
.nc-skin-icon { width: 14px; opacity: .7; }

/* ── 갤러리 뷰 ───────────────────────────────────── */
.gallery-wrap { display:flex; flex-direction:column; height:100%; overflow:hidden; }
.gallery-header { padding:.75rem 1.25rem; border-bottom:1px solid var(--border); background:var(--bg-panel); flex-shrink:0; }
.gallery-masonry {
  flex:1; overflow-y:auto; padding:6px;
  columns:6; column-gap:5px;
}
.gallery-item {
  position:relative; break-inside:avoid;
  margin-bottom:5px; cursor:zoom-in;
  border-radius:5px; overflow:hidden;
  background:var(--bg-secondary);
}
.gallery-item img { display:block; width:100%; height:auto; transition:transform .2s; }
.gallery-item:hover img { transform:scale(1.02); }
.gallery-exif {
  position:absolute; bottom:0; left:0; right:0;
  background:linear-gradient(transparent, rgba(0,0,0,.75));
  color:#fff; font-size:.75rem; line-height:1.4;
  padding:.4rem .5rem;
  opacity:0; transition:opacity .2s;
}
.gallery-item:hover .gallery-exif { opacity:1; }

@media (max-width:767px)  { .gallery-masonry { columns:2; } }
@media (max-width:1279px) { .gallery-masonry { columns:4; } }

/* 라이트박스 */
.lightbox {
  position:fixed; inset:0; z-index:9000;
  background:rgba(0,0,0,.9);
  display:flex; align-items:center; justify-content:center;
}
.lightbox-img { max-width:92vw; max-height:88vh; object-fit:contain; border-radius:4px; }
.lightbox-close {
  position:absolute; top:1rem; right:1.25rem;
  font-size:2rem; color:#fff; background:none; border:none; cursor:pointer; line-height:1;
}
.lightbox-nav {
  position:absolute; top:50%; transform:translateY(-50%);
  font-size:2rem; color:#fff; background:rgba(0,0,0,.4); border:none; cursor:pointer;
  padding:.3rem .7rem; border-radius:4px; line-height:1; user-select:none;
}
.lightbox-nav.left { left:.75rem; }
.lightbox-nav.right { right:.75rem; }
.lightbox-info {
  position:absolute; bottom:1.25rem; left:50%; transform:translateX(-50%);
  display:flex; gap:.75rem; flex-wrap:wrap; justify-content:center;
  color:rgba(255,255,255,.85); font-size:.8125rem;
  background:rgba(0,0,0,.5); padding:.35rem .85rem; border-radius:20px;
}

/* ── 플로팅 오디오 플레이어 ──────────────────────── */
.fp-wrap {
  position:fixed; z-index:8000;
  width:380px; background:var(--bg-secondary);
  border:1px solid var(--border); border-radius:12px;
  box-shadow:0 8px 32px rgba(0,0,0,.45);
  overflow:hidden; user-select:none;
}
.fp-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:.55rem .9rem;
  background:var(--bg-panel); border-bottom:1px solid var(--border);
  cursor:grab; font-size:.9375rem; font-weight:600;
}
.fp-header:active { cursor:grabbing; }
.fp-close { font-size:1.4rem; line-height:1; color:var(--text-secondary); background:none; border:none; cursor:pointer; }
.fp-close:hover { color:var(--danger); }
.fp-wave { display:block; width:100%; height:70px; background:var(--bg-primary); }
.fp-track-info { padding:.4rem .9rem .1rem; }
.fp-track-name { font-size:.9rem; font-weight:500; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.fp-track-time { font-size:.8125rem; color:var(--text-muted); margin-top:.1rem; }
.fp-progress-wrap {
  height:5px; background:var(--border); margin:.4rem .9rem; border-radius:3px; cursor:pointer; position:relative;
}
.fp-progress-bar { height:100%; background:var(--accent); border-radius:3px; transition:width .1s linear; }
.fp-controls {
  display:flex; align-items:center; gap:.25rem; padding:.3rem .65rem;
}
.fp-btn {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  min-width:36px; height:36px; border-radius:6px; font-size:1rem;
  border:1px solid transparent; background:none; cursor:pointer; color:var(--text-primary);
  transition:background .12s;
}
.fp-btn:hover { background:var(--bg-hover); }
.fp-btn.active { color:var(--accent); }
.fp-play { font-size:1.3rem; width:44px; height:44px; background:var(--accent); color:#fff; border-radius:50%; }
.fp-play:hover { background:var(--accent-hover); }
.fp-icon-btn {
  display:flex; align-items:center; justify-content:center;
  width:34px; height:34px; border-radius:50%; font-size:1.05rem;
  padding:6px 8px !important;
  border:1px solid transparent; background:var(--accent); cursor:pointer;
  color:var(--text-secondary); transition:background .12s, color .12s;
}
.fp-icon-btn:hover { background:var(--bg-hover); color:var(--text-primary); }
.fp-icon-btn.active { color:var(--accent); background:var(--bg-hover); }
.fp-volume {
  display:flex; align-items:center; gap:.5rem;
  padding:.1rem .9rem .4rem;
}
.fp-playlist { border-top:1px solid var(--border); }
.fp-playlist-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:.45rem .9rem; border-bottom:1px solid var(--border);
}
.fp-list-scroll { height:380px; overflow-y:auto; }

/* 모바일: 플레이어를 화면 중앙에 꽉 채워서 표시 */
@media (max-width: 767px) {
  .fp-wrap {
    left: 8px !important;
    right: 8px !important;
    top: 8px !important;
    bottom: 68px !important;   /* 하단 탭바 위 */
    width: auto !important;
    display: flex;
    flex-direction: column;
    overflow: hidden;
  }
  .fp-list-scroll {
    height: auto !important;   /* 고정 높이 해제 */
    flex: 1;                   /* 남은 공간 모두 사용 */
    min-height: 80px;
  }
}
.fp-list-item {
  display:flex; align-items:center; gap:.5rem;
  padding:.4rem .75rem; cursor:pointer; font-size:.875rem;
  transition:background .1s;
}
.fp-list-item:hover { background:var(--bg-hover); }
.fp-list-item.current { background:var(--bg-hover); color:var(--accent); }
.fp-list-name { flex:1; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; color:var(--text-primary); }
.fp-list-item.current .fp-list-name { color:var(--accent); font-weight:500; }
.fp-list-dur { font-size:.8125rem; color:var(--text-muted); flex-shrink:0; min-width:36px; text-align:right; }

/* ── 카테고리 목록 뷰 ────────────────────────────── */
.cl-wrap { display:flex; flex-direction:column; height:100%; overflow:hidden; }
.cl-header {
  display:flex; align-items:center; gap:.65rem; flex-shrink:0;
  padding:.65rem 1.25rem; border-bottom:1px solid var(--border); background:var(--bg-panel);
}
.cl-cat-name { font-size:1.05rem; font-weight:700; }
.cl-total { font-size:.875rem; color:var(--text-muted); }
.skin-label {
  font-size:.75rem; padding:.15rem .5rem; border-radius:10px;
  background:var(--accent); color:#fff; flex-shrink:0;
}
.cl-body { flex:1; overflow-y:auto; min-height:0; }

/* 기본 테이블형 */
.cl-table { width:100%; border-collapse:collapse; }
.cl-table th { font-size:.8rem; color:var(--text-muted); font-weight:500; padding:.45rem .85rem; border-bottom:2px solid var(--border); text-align:left; white-space:nowrap; background:var(--bg-panel); }
.cl-th-no    { width:52px; text-align:center; }
.cl-th-author{ width:72px; }
.cl-th-date  { width:88px; }
.cl-row { cursor:pointer; transition:background .1s; }
.cl-row:hover { background:var(--bg-hover); }
.cl-row td { border-bottom:1px solid var(--border); padding:.5rem .85rem; vertical-align:top; }
.cl-col-no   { text-align:center; font-size:.8125rem; color:var(--text-muted); padding-top:.65rem !important; }
.cl-title-line { display:flex; align-items:center; gap:.25rem; flex-wrap:wrap; }
.cl-title-text { font-size:.9375rem; font-weight:500; }
.cl-badge  { font-size:.8rem; color:var(--accent); }
.cl-file-ico { font-size:.85rem; color:var(--text-muted); }
.cl-excerpt  {
  font-size:.8125rem; color:var(--text-secondary); margin-top:.2rem;
  display:-webkit-box; -webkit-line-clamp:1; -webkit-box-orient:vertical;
  overflow:hidden; white-space:normal; word-break:break-word;
}
.cl-col-author { font-size:.8125rem; color:var(--text-secondary); white-space:nowrap; padding-top:.65rem !important; }
.cl-col-date   { font-size:.8125rem; color:var(--text-muted); white-space:nowrap; padding-top:.65rem !important; }

/* 갤러리 카드 */
.cl-gallery-grid {
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:1rem; padding:1rem;
}
.cl-card {
  border:1px solid var(--border); border-radius:8px; overflow:hidden;
  background:var(--bg-secondary); cursor:pointer;
  transition:transform .15s, box-shadow .15s;
}
.cl-card:hover { transform:translateY(-3px); box-shadow:0 6px 20px var(--shadow); }
.cl-card-thumb {
  aspect-ratio:16/9; overflow:hidden; background:var(--bg-panel);
  position:relative; display:flex; align-items:center; justify-content:center;
}
.cl-card-thumb img { width:100%; height:100%; object-fit:cover; }
.cl-no-thumb { font-size:2rem; color:var(--text-muted); }
.cl-yt-badge {
  position:absolute; bottom:.4rem; right:.4rem;
  background:rgba(255,0,0,.85); color:#fff; font-size:.7rem;
  padding:.15rem .4rem; border-radius:3px;
}
.cl-card-body { padding:.65rem .75rem; }
.cl-card-title { font-size:.9375rem; font-weight:600; margin-bottom:.2rem;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.cl-card-meta  { font-size:.78rem; color:var(--text-muted); margin-bottom:.25rem; }
.cl-card-excerpt { font-size:.8125rem; color:var(--text-secondary);
  display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; }

/* 웹진형 */
.cl-wz-list { display:flex; flex-direction:column; }
.cl-wz-item {
  display:flex; gap:1rem; padding:.9rem 1.25rem;
  border-bottom:1px solid var(--border); cursor:pointer; transition:background .1s;
}
.cl-wz-item:hover { background:var(--bg-hover); }
.cl-wz-thumb {
  width:200px; flex-shrink:0; aspect-ratio:16/9;
  border-radius:6px; overflow:hidden; background:var(--bg-secondary);
  position:relative; display:flex; align-items:center; justify-content:center;
}
.cl-wz-thumb img { width:100%; height:100%; object-fit:cover; }
.cl-wz-body { flex:1; min-width:0; display:flex; flex-direction:column; gap:.3rem; }
.cl-wz-title { font-size:1rem; font-weight:600;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.cl-wz-excerpt {
  font-size:.875rem; color:var(--text-secondary);
  display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical;
  overflow:hidden; white-space:normal; word-break:break-word;
}
.cl-wz-body-full { width:100%; }
.cl-wz-meta { font-size:.8125rem; color:var(--text-muted); }

/* 페이지네이션 */
.cl-pagination {
  display:flex; align-items:center; justify-content:center; gap:.2rem;
  padding:.7rem 1rem; border-top:1px solid var(--border);
  flex-shrink:0; background:var(--bg-panel); flex-wrap:wrap;
}
.cl-page-btn {
  min-width:32px; height:32px; border-radius:5px; font-size:.875rem; cursor:pointer;
  border:1px solid var(--border); background:none; color:var(--text-primary);
  transition:background .1s; padding:0 .4rem;
}
.cl-page-btn:hover:not(:disabled):not(.active) { background:var(--bg-hover); }
.cl-page-btn.active { background:var(--accent); color:#fff; border-color:var(--accent); font-weight:600; }
.cl-page-btn:disabled { opacity:.35; cursor:default; }

/* 반응형 */
@media (max-width:1279px) { .cl-gallery-grid { grid-template-columns:repeat(2,1fr); } }
@media (max-width:767px) {
  .cl-gallery-grid { grid-template-columns:1fr; padding:.75rem; }
  .cl-wz-thumb { width:110px; }
  .cl-wz-title { font-size:.9375rem; }
  .cl-wz-excerpt { -webkit-line-clamp:2; }
  .cl-th-no, .cl-col-no, .cl-th-author, .cl-col-author { display:none; }
  .cl-th-date, .cl-col-date { width:60px; }
  .cl-header { padding:.5rem .75rem; }
}

/* ── PDF 썸네일 (NoteDetail) ─────────────────────── */
.pdf-section { margin-top:1.5rem; border-top:1px solid var(--border); padding-top:1.25rem; display:flex; flex-direction:column; gap:1.5rem; }
.pdf-item { display:flex; flex-direction:column; align-items:center; gap:.75rem; }
.pdf-thumb-wrap {
  position:relative; cursor:pointer;
  border:1px solid var(--border); border-radius:8px; overflow:hidden;
  background:var(--bg-secondary); width:180px;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 4px 16px var(--shadow);
  transition:box-shadow .2s, transform .2s;
}
.pdf-thumb-wrap:hover { box-shadow:0 8px 28px var(--shadow); transform:translateY(-2px); }
.pdf-thumb-cvs { display:block; width:100%; height:auto; }
.pdf-thumb-overlay {
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  background:rgba(0,0,0,.5); color:#fff; font-size:.9rem; font-weight:600;
  opacity:0; transition:opacity .2s;
}
.pdf-thumb-wrap:hover .pdf-thumb-overlay { opacity:1; }
.pdf-meta { display:flex; flex-direction:column; align-items:center; gap:.35rem; text-align:center; }
.pdf-name { font-size:.9375rem; font-weight:500; word-break:break-all; max-width:260px; }
.pdf-btns { display:flex; gap:.5rem; flex-wrap:wrap; justify-content:center; margin-top:.1rem; }

/* ── 이북 뷰어 ────────────────────────────────────── */
.ev-root {
  position: fixed; inset: 0; z-index: 9500;
  display: flex; flex-direction: column;
  background: #1a1510;
  outline: none;
}
.ev-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: .6rem 1.25rem; height: 52px; flex-shrink: 0;
  background: rgba(0,0,0,.5); border-bottom: 1px solid rgba(255,255,255,.1);
}
.ev-title { font-size: 1rem; font-weight: 600; color: #e8e0d0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 60%; }
.ev-hbtn { padding: .35rem .8rem; border-radius: 5px; font-size: .875rem; background: rgba(255,255,255,.12); color: #ddd; border: 1px solid rgba(255,255,255,.2); cursor: pointer; transition: background .15s; }
.ev-hbtn:hover { background: rgba(255,255,255,.22); }
.ev-hbtn-close { background: rgba(200,50,50,.4); }
.ev-hbtn-close:hover { background: rgba(200,50,50,.7); }

.ev-stage {
  flex: 1; display: flex; align-items: center; justify-content: center;
  overflow: hidden; position: relative;
  background: radial-gradient(ellipse at center, #2c2218 0%, #100d08 100%);
}
.ev-loading { display:flex; flex-direction:column; align-items:center; justify-content:center; }

.ev-book-wrap { display:flex; align-items:center; justify-content:center; }
.ev-book {
  position: relative; display: flex; align-items: stretch;
  box-shadow: 0 20px 60px rgba(0,0,0,.7), 0 8px 20px rgba(0,0,0,.5);
}

.ev-page { position:relative; overflow:hidden; background:#f8f7f2; flex-shrink:0; }
.ev-page canvas { display:block; }
.ev-page-l { border-radius: 2px 0 0 2px; }
.ev-page-r { border-radius: 0 2px 2px 0; }

/* 책등 그라데이션 */
.ev-spine {
  width: 6px; flex-shrink: 0;
  background: linear-gradient(to right, #7a6040, #c8a870, #7a6040);
  box-shadow: inset 2px 0 4px rgba(0,0,0,.3), inset -2px 0 4px rgba(0,0,0,.3);
}

/* 모서리 접기 효과 */
.ev-fold {
  position: absolute; bottom: 0; width: 52px; height: 52px; cursor: pointer; z-index: 5;
}
.ev-fold-r { right: 0; }
.ev-fold-l { left: 0; }
.ev-fold::after {
  content: '';
  position: absolute; bottom: 0;
  width: 0; height: 0;
  border-style: solid;
  transition: border-width .25s cubic-bezier(.4,0,.2,1), opacity .25s;
  opacity: 0;
}
.ev-fold-r::after { right:0; border-width:0; border-color:transparent transparent rgba(210,190,160,.85) transparent; }
.ev-fold-l::after { left:0;  border-width:0; border-color:transparent transparent transparent rgba(210,190,160,.85); }
.ev-fold-r.hover::after { border-width:0 0 46px 46px; opacity:1; }
.ev-fold-l.hover::after { border-width:0 46px 46px 0; opacity:1; }
/* 접기 그림자 */
.ev-fold-r.hover::before { content:''; position:absolute; bottom:0; right:0; width:46px; height:46px;
  background:linear-gradient(135deg,transparent 50%,rgba(0,0,0,.12) 50%); }
.ev-fold-l.hover::before { content:''; position:absolute; bottom:0; left:0; width:46px; height:46px;
  background:linear-gradient(225deg,transparent 50%,rgba(0,0,0,.12) 50%); }

/* 페이지 뒤집기 오버레이 */
.ev-flip-wrap { position:absolute; top:0; overflow:hidden; z-index:10; }
.ev-flip-card { width:100%; height:100%; position:relative; }
.ev-flip-cvs { display:block; }

/* ── 종이 넘김 애니메이션 ─ 자연스러운 book-turn ── */

/* 단일 페이즈 — 덮개(현재 페이지)가 접혀 사라지면 아래 새 페이지가 드러남 */
.ev-flip-out-next {
  transform-origin: left center;
  animation: evFoldNext 0.52s cubic-bezier(0.4, 0, 0.8, 1) forwards;
}
.ev-flip-out-prev {
  transform-origin: right center;
  animation: evFoldPrev 0.52s cubic-bezier(0.4, 0, 0.8, 1) forwards;
}

/* 접힘 키프레임 — 0° → 90° (새 내용은 이미 아래에 있음) */
@keyframes evFoldNext {
  0%   { transform: perspective(2800px) rotateY(0deg); }
  60%  { transform: perspective(2800px) rotateY(-60deg) scaleX(0.98); }
  100% { transform: perspective(2800px) rotateY(-90deg); }
}
@keyframes evFoldPrev {
  0%   { transform: perspective(2800px) rotateY(0deg); }
  60%  { transform: perspective(2800px) rotateY(60deg)  scaleX(0.98); }
  100% { transform: perspective(2800px) rotateY(90deg); }
}

/* 접히면서 어두워지는 음영 */
.ev-flip-out-next::after, .ev-flip-out-prev::after {
  content:''; position:absolute; inset:0; pointer-events:none;
  background:rgba(0,0,0,0.22);
  animation: evShadowIn 0.52s ease-in forwards;
}
@keyframes evShadowIn { from{opacity:0} to{opacity:1} }

/* 하단 네비게이션 */
.ev-nav {
  display: flex; align-items: center; justify-content: center; gap: 1.5rem;
  padding: .65rem 1.5rem; flex-shrink: 0;
  background: rgba(0,0,0,.5); border-top: 1px solid rgba(255,255,255,.1);
}
.ev-nav-btn {
  padding: .4rem 1rem; border-radius: 6px; font-size: .9375rem;
  background: rgba(255,255,255,.1); color: #ddd;
  border: 1px solid rgba(255,255,255,.18); cursor: pointer; transition: background .12s;
}
.ev-nav-btn:hover:not(:disabled) { background: rgba(255,255,255,.22); }
.ev-nav-btn:disabled { opacity: .35; cursor: default; }
.ev-page-info {
  min-width: 120px; text-align: center; font-size: .9375rem; color: #c8bfaf;
  cursor: pointer; padding: .3rem .6rem; border-radius: 5px; border: 1px solid transparent;
  transition: border-color .15s;
}
.ev-page-info:hover { border-color: rgba(255,255,255,.25); }
.ev-page-input {
  width: 80px; text-align: center; padding: .25rem .4rem;
  background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.3);
  border-radius: 4px; color: #e8e0d0; font-size: .9375rem;
}

/* ── 달력 ────────────────────────────────────────── */
.cal-wrap { display:flex; flex-direction:column; height:100%; overflow:hidden; background:var(--bg-primary); }

.cal-header {
  display:flex; align-items:center; gap:.5rem; flex-wrap:wrap;
  padding:.6rem 1rem; border-bottom:1px solid var(--border);
  background:var(--bg-panel); flex-shrink:0;
}
.cal-title { font-size:1.05rem; font-weight:700; min-width:160px; text-align:center; }
.cal-nav { width:30px; height:30px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:.9rem; border:1px solid var(--border); cursor:pointer; transition:background .12s; }
.cal-nav:hover { background:var(--bg-hover); }
.cal-today-btn { padding:.3rem .7rem; border-radius:5px; border:1px solid var(--border); font-size:.875rem; cursor:pointer; transition:background .12s; }
.cal-today-btn:hover { background:var(--bg-hover); }
.cal-view-btns { display:flex; border:1px solid var(--border); border-radius:6px; overflow:hidden; }
.cal-view-btns button { padding:.3rem .65rem; font-size:.875rem; border:none; cursor:pointer; background:none; transition:background .12s; }
.cal-view-btns button.active { background:var(--accent); color:#fff; }
.cal-view-btns button:not(.active):hover { background:var(--bg-hover); }

.cal-dow-row { display:flex; border-bottom:1px solid var(--border); background:var(--bg-panel); flex-shrink:0; }
.cal-dow { flex:1; text-align:center; padding:.35rem 0; font-size:.8125rem; font-weight:600; color:var(--text-secondary); }
.cal-dow.sun { color:var(--danger); }
.cal-dow.sat { color:#4f9cf9; }

.cal-body { flex:1; overflow-y:auto; }

.cal-week-row { display:flex; position:relative; border-bottom:1px solid var(--border); }
.cal-week-body .cal-week-row { min-height:200px; }

.cal-day-cell {
  flex:1; min-width:0; border-right:1px solid var(--border); padding:.2rem .3rem;
  cursor:pointer; transition:background .1s;
}
.cal-day-cell:last-child { border-right:none; }
.cal-day-cell:hover { background:var(--bg-hover); }
.cal-day-cell.other { opacity:.4; }
.cal-day-cell.today .cal-day-num { background:var(--accent); color:#fff !important; border-radius:50%; width:24px; height:24px; display:inline-flex; align-items:center; justify-content:center; }
.cal-day-cell.sun .cal-day-num { color:var(--danger); }
.cal-day-cell.sat .cal-day-num { color:#4f9cf9; }
.cal-day-cell.hol .cal-day-num { color:var(--danger); }

.cal-day-top { display:flex; align-items:center; gap:.25rem; min-height:24px; }
.cal-day-num { font-size:.875rem; font-weight:500; flex-shrink:0; }
.cal-lunar { font-size:.72rem; color:var(--text-muted); }
.cal-hol-name { font-size:.68rem; color:var(--danger); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:60px; }

/* 이벤트 바 */
.cal-week-events { position:absolute; inset:0; pointer-events:none; }
.cal-ev-bar {
  position:absolute; height:20px; line-height:20px;
  color:#fff; font-size:.78rem; cursor:pointer;
  pointer-events:all; overflow:hidden; white-space:nowrap;
  transition:opacity .12s;
}
.cal-ev-bar:hover { opacity:.85; }
.cal-ev-title { overflow:hidden; text-overflow:ellipsis; white-space:nowrap; display:block; }

/* 일간 뷰 */
.cal-day-ev-item {
  padding:.65rem .85rem; border-left:4px solid var(--accent);
  background:var(--bg-secondary); border-radius:0 6px 6px 0;
  margin-bottom:.5rem; cursor:pointer; transition:background .12s;
}
.cal-day-ev-item:hover { background:var(--bg-hover); }

/* ── 스크롤바 */
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--border); border-radius: 10px; }

/* 테마 토글 */
.theme-toggle {
  width: 34px; height: 34px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  border: 1px solid var(--border); transition: background .15s;
}
.theme-toggle:hover { background: var(--bg-hover); }
