/* 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);
  --grad-main:   linear-gradient(135deg, #6366f1 0%, #8b5cf6 50%, #06b6d4 100%);
}

: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);
  --grad-main:   linear-gradient(135deg, #6366f1 0%, #8b5cf6 50%, #06b6d4 100%);
}

/* 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; }
.user-info { display:flex; align-items:center; gap:.35rem; white-space:nowrap; font-size:.875rem; color:var(--text-secondary); }
.user-icon { font-size:1rem; }
.user-name { font-weight:600; color:var(--text-primary); }
.user-sep  { color:var(--border); }
@media (max-width: 767px) { .user-info { display:none; } }

.nav-logo {
  display: flex; align-items: center; gap: 10px;
  margin-top:6px;
  text-decoration: none;
}
.nav-logo-mark {
  float:left;
  margin-right:0px;
  width: 30px; height: 30px; border-radius: 9px;
  font-size:24px !important;
  padding:0px 3px 4px 3px;
  background: var(--grad-main);
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: 18px; color: #fff;
  box-shadow: 0 2px 12px rgba(99,102,241,0.5);
}
.nav-logo-mark .sup {font-size:12px !important;vertical-align: super !important;}
.nav-logo-text { font-size: 22px !important; font-weight: 700; color: var(--accent); margin-right:20px}
.nav-logo-text span { color: var(--text-primary); }  

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

#left-panel {
  width: 260px; 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; }
/* source 스킨 뷰: center를 overflow:hidden + note-view를 full height flex */
#center.source-view-active { overflow: hidden; display: flex; flex-direction: column; }
#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 제거됨 — 하단 액션 바로 이동 */
.editor-action-bar {
  border-top: 1px solid var(--border);
  background: var(--bg-panel);
  flex-shrink: 0;
  padding: .55rem 1rem;
  display: flex; justify-content: flex-end;
}
.editor-action-box {
  display: flex; align-items: center; gap: .5rem;
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: .45rem .65rem;
}
.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) !important; margin: 1em 0 !important; }
hr { border: none; border-top: 1px solid var(--border) !important; margin: 1em 0 !important; }
.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); }
/* 썸네일: 상단 좌우 분할, 하단 내용 100% */
.nc-row { display: flex; gap: .6rem; align-items: flex-start; margin-bottom: .15rem; }
.nc-thumb-sm {
  width: 36%; flex-shrink: 0;
  aspect-ratio: 4 / 2.5;
  object-fit: cover; border-radius: 5px;
  margin-bottom:6px;
  background: var(--bg-secondary);
}
.nc-info-top { flex: 1; min-width: 0; }
.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: .9rem; 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);line-height: 1.2;
  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: .2rem; }
.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%; }
/* source 스킨: 소스뷰어 높이 */
/* source 스킨 note-view: 남은 공간 전체 차지, 내부 flex */
.note-view.skin-source {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
  overflow: hidden;
}
/* source 스킨 note-view 내부 스크롤 영역 (제목+메타 제외) */
.note-view.skin-source .note-source-body {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
}
/* 소스 탐색기: 남은 높이 전체 */
.note-source-viewer {
  flex: 1;
  min-height: 200px;
  margin: .5rem 0 0;
  border: 1px solid var(--border);
  border-radius: 8px;
  overflow: hidden;
}
/* 댓글+버튼 고정 하단 영역 */
.note-source-footer {
  flex-shrink: 0;
  overflow-y: auto;
  max-height: 40vh;
  border-top: 1px solid var(--border);
  padding-top: .75rem;
  margin-top: .5rem;
}
.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; }

/* 모바일: 90% 너비 중앙, 하단 탭바 위에 자연스럽게 */
@media (max-width: 767px) {
  .fp-wrap {
    left: 5% !important;
    right: 5% !important;
    width: auto !important;
    bottom: 68px !important;     /* 탭바 바로 위 */
    top: auto !important;        /* 높이 자동 */
    transform: none !important;
    max-height: calc(100vh - 80px); /* 화면 크기 초과 방지 */
    display: flex;
    flex-direction: column;
    overflow: hidden;
  }
  /* 웨이브폼 높이 줄임 */
  .fp-wrap .fp-wave { height: 50px !important; }
  /* 목록: 10곡 기준 고정, 초과분 스크롤 */
  .fp-wrap .fp-list-scroll {
    height: 340px !important;
    overflow-y: auto;
  }
}
.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; }

/* ── 우측 패널 최근 이미지 ──────────────────────── */
.recent-img-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5px;
}
.recent-img-item {
  cursor: pointer;
  border-radius: 5px;
  overflow: hidden;
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  transition: transform .15s;
}
.recent-img-item:hover { transform: scale(1.02); }
.recent-img-item img {
  width: 100%; aspect-ratio: 1/1;
  object-fit: cover; display: block;
}
.recent-img-title {
  font-size: .75rem; padding: .2rem .35rem;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  color: var(--text-secondary);
  border-top: 1px solid var(--border);
}

/* ── 카테고리 목록 뷰 ────────────────────────────── */
.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-ebook-grid {
  display: grid; grid-template-columns: repeat(6, 1fr);
  gap: 1.25rem; padding: 1.25rem;
}
.cl-ebook-card {
  cursor: pointer; transition: transform .15s, box-shadow .15s;
  display: flex; flex-direction: column;
}
.cl-ebook-card:hover { transform: translateY(-4px); }
.cl-ebook-cover {
  aspect-ratio: 2 / 3; overflow: hidden;
  border-radius: 4px 8px 8px 4px;  /* 책등 효과 */
  background: var(--bg-secondary);
  box-shadow: -3px 3px 10px rgba(0,0,0,.35), 2px 2px 4px rgba(0,0,0,.2);
  display: flex; align-items: center; justify-content: center;
  position: relative;
}
.cl-ebook-cover img { width:100%; height:100%; object-fit:cover; }
.cl-ebook-cover::before {  /* 책등 그림자 */
  content:''; position:absolute; left:0; top:0; bottom:0; width:8px;
  background:linear-gradient(to right, rgba(0,0,0,.25), transparent);
  z-index:1;
}
.cl-ebook-info { padding: .5rem .25rem 0; }
.cl-ebook-title { font-size:.875rem; font-weight:600; line-height:1.3;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.cl-ebook-meta { font-size:.78rem; color:var(--text-muted); margin-top:.2rem; }

@media (max-width:1279px) { .cl-ebook-grid { grid-template-columns:repeat(4,1fr); } }
@media (max-width:767px)  { .cl-ebook-grid { grid-template-columns:repeat(2,1fr); gap:.75rem; padding:.75rem; } }

/* 갤러리 카드 */
.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-pdf-thumb-wrap { width:100%; height:100%; overflow:hidden; }
.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:300px;
  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; gap: 0; background: #f8f7f2; overflow: hidden;
  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-l::after {
  content:''; position:absolute; top:0; right:0; bottom:0; width:60px;
  background:linear-gradient(to left, rgba(0,0,0,0.09), transparent);
  pointer-events:none; z-index:1;
}
.ev-page-r { border-radius: 0 2px 2px 0; }
.ev-page-r::before {
  content:''; position:absolute; top:0; left:0; bottom:0; width:60px;
  background:linear-gradient(to right, rgba(0,0,0,0.09), transparent);
  pointer-events:none; z-index:1;
}



/* 모서리 접기 효과 */
.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; z-index:10; }
.ev-flip-card { width:100%; height:100%; position:relative; transform-style:preserve-3d; }
.ev-flip-cvs { display:block; }
.ev-flip-front { backface-visibility:hidden; -webkit-backface-visibility:hidden; }
.ev-flip-back {
  position:absolute; top:0; left:0;
  backface-visibility:hidden; -webkit-backface-visibility:hidden;
  transform:rotateY(180deg);
}

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

/* 단일 페이즈 — 덮개(현재 페이지)가 접혀 사라지면 아래 새 페이지가 드러남 */
.ev-flip-out-next {
  transform-origin: left center;
  animation: evFlipNext 0.55s cubic-bezier(0.42, 0, 0.58, 1) forwards;
}
.ev-flip-out-prev {
  transform-origin: right center;
  animation: evFlipPrev 0.55s cubic-bezier(0.42, 0, 0.58, 1) forwards;
}
@keyframes evFlipNext {
  0%   { transform: perspective(1400px) rotateY(0deg); }
  100% { transform: perspective(1400px) rotateY(-180deg); }
}
@keyframes evFlipPrev {
  0%   { transform: perspective(1400px) rotateY(0deg); }
  100% { transform: perspective(1400px) rotateY(180deg); }
}
.ev-flip-out-next::before, .ev-flip-out-prev::before {
  content:''; position:absolute; inset:0; pointer-events:none; z-index:1;
  background:rgba(0,0,0,0.18);
  animation: evShadowPulse 0.55s ease-in-out forwards;
}
@keyframes evShadowPulse { 0%{opacity:0} 50%{opacity:1} 100%{opacity:0} }

/* 하단 네비게이션 */
.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); }

/* ── 카테고리 관리 패널 ── */
.cat-mgr-panel{margin:.35rem 0 .5rem;display:flex;flex-direction:column;gap:.45rem;}
/* 박스 공통 */
.cat-mgr-box{padding:.55rem .6rem;background:var(--bg-secondary);border-radius:7px;border:1px solid var(--border);}
.cat-mgr-box-title{font-size:.72rem;font-weight:600;letter-spacing:.04em;color:var(--text-muted);text-transform:uppercase;margin-bottom:.4rem;}
/* 두 줄 입력 레이아웃 */
.cat-full-input{width:100%;height:30px;font-size:.82rem;margin-bottom:.35rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:5px;padding:0 .5rem;color:var(--text-primary);}
.cat-full-input:focus{border-color:var(--primary,#5b9cf6);outline:none;}
.cat-row2{display:flex;align-items:center;gap:.3rem;}
.cat-skin-sel{flex:1;height:28px;font-size:.78rem;padding:0 .25rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:4px;color:var(--text-muted);cursor:pointer;}
.cat-ok-btn{padding:.28rem .7rem;border-radius:5px;background:var(--primary,#5b9cf6);color:#fff;border:none;font-size:.78rem;cursor:pointer;white-space:nowrap;flex-shrink:0;}
.cat-ok-btn:hover{opacity:.88;}
.cat-cancel-btn{padding:.28rem .55rem;border-radius:5px;background:none;border:1px solid var(--border);color:var(--text-muted);font-size:.78rem;cursor:pointer;flex-shrink:0;}
/* 편집 행 */
.cat-edit-row{padding:.3rem 0;border-bottom:1px solid var(--border);}
/* 목록 아이템 */
.cat-list-item{display:flex;align-items:center;gap:.25rem;padding:.3rem 0;border-bottom:1px solid var(--border);}
.cat-list-item:last-child{border-bottom:none;}
.cat-li-icon{width:13px;height:13px;display:inline-flex;align-items:center;flex-shrink:0;color:var(--text-muted);}
.cat-li-name{flex:1;font-size:.82rem;color:var(--text-primary);overflow:hidden;white-space:nowrap;text-overflow:ellipsis;}
.cat-li-skin{font-size:.68rem;color:var(--text-muted);background:var(--bg-primary);padding:1px 4px;border-radius:3px;flex-shrink:0;white-space:nowrap;}
.cat-li-owner{font-size:.7rem;color:var(--text-muted);flex-shrink:0;}
.cat-li-btn{width:22px;height:22px;border:none;background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-muted);border-radius:3px;flex-shrink:0;padding:0;transition:all .12s;}
.cat-li-btn svg{width:13px;height:13px;}
.cat-li-btn:hover{background:var(--bg-primary);color:var(--text-primary);}
.cat-li-btn.shared svg{stroke:var(--primary,#5b9cf6);}
.cat-li-btn:hover.shared,
.cat-li-btn.shared:hover{color:var(--primary,#5b9cf6);}
.cat-li-del:hover{color:var(--danger,#f06666)!important;}
/* 공유받은 섹션 */
.cat-shared-section{margin-top:.4rem;padding-top:.4rem;border-top:1px solid var(--border);}
.cat-shared-lbl{font-size:.72rem;color:var(--text-muted);margin-bottom:.25rem;}
/* 메시지 */
.cat-msg{font-size:.78rem;margin:.1rem 0;}
.cat-msg.success{color:var(--success,#5ec98a);}
.cat-msg.error{color:var(--danger,#f06666);}

/* ── 공유 박스 ── */
.share-box{position:relative;margin:.25rem 0 .5rem;padding:.55rem;background:var(--bg-secondary);border:1px solid var(--primary,#5b9cf6);border-radius:7px;}
.share-box-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.4rem;font-size:.82rem;font-weight:500;}
.share-box-head button{background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:.9rem;}
.share-search-row{display:flex;gap:.3rem;margin-bottom:.35rem;}
.share-user-list{max-height:140px;overflow-y:auto;border:1px solid var(--border);border-radius:5px;background:var(--bg-primary);}
.share-user-item{display:flex;align-items:center;gap:.5rem;padding:.35rem .5rem;cursor:pointer;border-bottom:1px solid var(--border);transition:background .1s;}
.share-user-item:last-child{border-bottom:none;}
.share-user-item:hover{background:var(--bg-secondary);}
.share-user-item.selected{background:rgba(91,156,246,.12);}
.share-user-avatar{width:26px;height:26px;border-radius:50%;background:rgba(91,156,246,.15);display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:600;color:var(--primary,#5b9cf6);flex-shrink:0;}
.share-box-foot{display:flex;justify-content:flex-end;margin-top:.35rem;}

/* ── 공유 수락 요청 ── */
.share-pending-list{margin:.3rem 0;padding:.45rem .55rem;background:rgba(91,156,246,.07);border:1px solid rgba(91,156,246,.25);border-radius:6px;}
.share-pending-item{padding:.25rem 0;border-bottom:1px solid var(--border);}
.share-pending-item:last-child{border-bottom:none;}

/* ── 삭제 확인 모달 ── */
.del-modal-backdrop{position:fixed;inset:0;z-index:900;background:rgba(0,0,0,.55);display:flex;align-items:center;justify-content:center;}
.del-modal{background:var(--bg-primary);border:1px solid var(--border);border-radius:12px;padding:1.5rem;width:360px;max-width:90vw;box-shadow:0 16px 40px rgba(0,0,0,.4);}
.del-modal-title{font-size:1rem;font-weight:700;color:var(--text-primary);margin-bottom:.85rem;display:flex;align-items:center;gap:.5rem;}
.del-modal-title::before{content:'🗑';font-size:.95rem;}
.del-modal-body{font-size:.9rem;color:var(--text-secondary);line-height:1.65;margin-bottom:1.25rem;padding:.75rem;background:var(--bg-secondary);border-radius:7px;border:1px solid var(--border);}
.del-modal-body strong{color:var(--text-primary);display:block;margin-bottom:.3rem;}
.del-modal-foot{display:flex;gap:.5rem;justify-content:flex-end;}

/* ── 소스관리 에디터 모드 힌트 ── */
.editor-source-mode{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0;}
.editor-source-hint{display:flex;align-items:center;gap:.5rem;padding:.5rem .85rem;font-size:.82rem;color:var(--primary,#5b9cf6);background:rgba(91,156,246,.08);border-bottom:1px solid rgba(91,156,246,.2);flex-shrink:0;}
.editor-source-hint svg{flex-shrink:0;}

/* ── 이북뷰어 모바일: 단일 페이지 꽉 차게 ── */
@media (max-width: 767px) {
  .ev-page-l { display: none !important; }
  .ev-book-wrap { align-items: flex-start !important; padding: 0 !important; }
  .ev-book { margin: 0 !important; border-radius: 0 !important; box-shadow: none !important; }
  .ev-page { border-radius: 0 !important; }
  .ev-page canvas { width: 100vw !important; }
  .ev-stage { padding: 0 !important; }
}
