/* ============================================================
   PRIVACY NOTICE — SHARED THEME
   모든 화면이 이 파일을 import. files.html의 토큰과 동일.
   Thymeleaf:  <link rel="stylesheet" th:href="@{/css/theme.css}">
   ============================================================ */
:root {
  /* Brand */
  --brand-50:#eef0ff; --brand-100:#e0e3ff; --brand-200:#c7ccfe;
  --brand-500:#6366f1; --brand-600:#5558e6; --brand-700:#4338ca;
  --brand-fg:#fff;

  /* Neutrals */
  --bg:#fafbfc; --bg-elev:#fff; --bg-sunken:#f4f5f8; --bg-hover:#f6f7f9;
  --bg-row-folder:#fdfcf6; --bg-row-folder-hover:#fbf8ec;
  --border:#e6e8ec; --border-strong:#d4d7dd; --border-soft:#eef0f3;
  --text:#0f172a; --text-muted:#64748b; --text-faint:#94a3b8; --text-strong:#020617;

  /* Semantic — 모두 5단계 (50/100/500/600/700) 통일 */
  --success-50:#ecfdf5; --success-100:#d1fae5; --success-500:#10b981; --success-600:#059669; --success-700:#047857;
  --warn-50:#fef9ec;    --warn-100:#fef3c7;    --warn-500:#f59e0b;    --warn-600:#b45309;    --warn-700:#92400e;
  --danger-50:#fef2f2;  --danger-100:#fee2e2;  --danger-500:#ef4444;  --danger-600:#dc2626;  --danger-700:#b91c1c;
  --neutral-50:#f8fafc; --neutral-100:#f1f5f9; --neutral-500:#64748b; --neutral-600:#475569; --neutral-700:#334155;

  /* File-type icon colors (확장자 → fg/bg 매핑. 모자라면 file-other 사용) */
  --ft-pdf-fg:#dc2626;  --ft-pdf-bg:#fef2f2;
  --ft-doc-fg:#2563eb;  --ft-doc-bg:#eff6ff;
  --ft-xls-fg:#059669;  --ft-xls-bg:#ecfdf5;
  --ft-img-fg:#7c3aed;  --ft-img-bg:#f5f3ff;
  --ft-zip-fg:#92400e;  --ft-zip-bg:#fef3c7;
  --ft-other-fg:#64748b; --ft-other-bg:#f1f5f9;

  /* Folder accent */
  --folder-icon-fg:#d4a017; --folder-icon-bg:#fef3c7;
  --file-icon-fg:#64748b;   --file-icon-bg:#f1f5f9;

  /* Type */
  --font-sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --font-mono:ui-monospace,'SF Mono','JetBrains Mono',Menlo,monospace;
  --fs-xs:11px; --fs-sm:12px; --fs-base:13px; --fs-md:14px; --fs-lg:16px;
  --fs-xl:20px; --fs-2xl:24px; --fs-3xl:30px;
  --lh-tight:1.2; --lh-snug:1.35; --lh-normal:1.5; --lh-relaxed:1.65;
  --fw-regular:400; --fw-medium:500; --fw-semibold:600; --fw-bold:700;

  /* Spacing 4pt */
  --sp-1:4px; --sp-2:8px; --sp-3:12px; --sp-4:16px; --sp-5:20px;
  --sp-6:24px; --sp-7:32px; --sp-8:40px; --sp-9:56px; --sp-10:72px;

  /* Radius */
  --r-xs:4px; --r-sm:6px; --r-md:8px; --r-lg:10px; --r-xl:14px; --r-2xl:20px; --r-pill:999px;

  /* Shadow */
  --shadow-xs:0 1px 1px rgba(15,23,42,.04);
  --shadow-sm:0 1px 2px rgba(15,23,42,.04),0 1px 1px rgba(15,23,42,.02);
  --shadow-md:0 4px 12px -2px rgba(15,23,42,.05),0 2px 4px -1px rgba(15,23,42,.04);
  --shadow-lg:0 12px 32px -8px rgba(15,23,42,.10),0 4px 8px -2px rgba(15,23,42,.04);
  --shadow-focus:0 0 0 3px rgba(99,102,241,.18);
  --shadow-focus-danger:0 0 0 3px rgba(239,68,68,.18);

  /* Layout */
  --sidebar-w:240px; --topbar-h:52px; --content-max:1280px;

  /* Motion */
  --ease:cubic-bezier(.2,.7,.2,1); --dur-fast:120ms; --dur:180ms;
}

/* ============================================================
   RESET / BASE
   ============================================================ */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--font-sans); font-size:var(--fs-base); line-height:var(--lh-normal);
  color:var(--text); background:var(--bg);
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
button{font:inherit;cursor:pointer}
a{color:inherit;text-decoration:none}
input,button,select,textarea{font-family:inherit}
::selection{background:var(--brand-100);color:var(--brand-700)}
svg{display:inline-block;vertical-align:middle}

/* ============================================================
   APP SHELL
   ============================================================ */
.shell{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh}
.sidebar{background:var(--bg-elev);border-right:1px solid var(--border-soft);display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.sb-brand{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-4) var(--sp-5);height:var(--topbar-h);border-bottom:1px solid var(--border-soft)}
.brand-mark{width:28px;height:28px;border-radius:7px;background:linear-gradient(135deg,#7c7ff7 0%,#5558e6 100%);color:#fff;font-weight:700;font-size:11px;letter-spacing:.02em;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 1px 2px rgba(85,88,230,.25)}
.brand-name{font-weight:600;font-size:var(--fs-md);color:var(--text-strong);letter-spacing:-.01em}

.sb-section{padding:var(--sp-4) var(--sp-3);display:flex;flex-direction:column;gap:1px}
.sb-section+.sb-section{border-top:1px solid var(--border-soft)}
.sb-label{font-size:var(--fs-xs);font-weight:600;color:var(--text-faint);text-transform:uppercase;letter-spacing:.06em;padding:var(--sp-2) var(--sp-3) var(--sp-1)}
.sb-link{display:flex;align-items:center;gap:10px;padding:6px 10px;border-radius:var(--r-sm);font-size:var(--fs-base);color:var(--text-muted);font-weight:500;line-height:1;height:30px;transition:background var(--dur-fast) var(--ease),color var(--dur-fast) var(--ease)}
.sb-link svg{width:15px;height:15px;color:var(--text-faint);flex-shrink:0}
.sb-link:hover{background:var(--bg-hover);color:var(--text-strong)}
.sb-link:hover svg{color:var(--text-muted)}
.sb-link.active{background:var(--brand-50);color:var(--brand-700)}
.sb-link.active svg{color:var(--brand-600)}
.avatar{width:24px;height:24px;border-radius:50%;background:var(--brand-100);color:var(--brand-700);font-weight:600;font-size:11px;display:flex;align-items:center;justify-content:center;flex-shrink:0}

/* ——— Topbar ——— */
.topbar{height:var(--topbar-h);border-bottom:1px solid var(--border-soft);background:var(--bg-elev);display:flex;align-items:center;gap:var(--sp-3);padding:0 var(--sp-6);position:sticky;top:0;z-index:20}
.crumbs{display:flex;align-items:center;gap:6px;font-size:var(--fs-base);color:var(--text-muted);min-width:0;flex:1}
.crumbs a:hover{color:var(--text-strong)}
.crumbs .sep{color:var(--text-faint)}
.crumbs .here{color:var(--text-strong);font-weight:500}

/* ——— Topbar user (우측 프로필 드롭다운) ——— */
.topbar-user{position:relative;display:flex;align-items:center;flex-shrink:0;margin-left:auto}
.topbar-user-btn{display:flex;align-items:center;gap:var(--sp-2);padding:4px 8px;border:none;background:none;border-radius:var(--r-md);cursor:pointer;transition:background var(--dur-fast) var(--ease)}
.topbar-user-btn:hover{background:var(--bg-hover)}
.topbar-user-btn:focus-visible{outline:none;box-shadow:var(--shadow-focus)}
.topbar-user-name{font-size:var(--fs-sm);font-weight:500;color:var(--text-strong);white-space:nowrap}
.topbar-user-caret{width:12px;height:12px;color:var(--text-faint);transition:transform var(--dur-fast) var(--ease)}
.topbar-user.open .topbar-user-caret{transform:rotate(180deg)}
.user-menu{position:absolute;top:calc(100% + 6px);right:0;min-width:200px;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:var(--sp-2);z-index:60;opacity:0;pointer-events:none;transform:translateY(-4px);transition:opacity var(--dur-fast) var(--ease),transform var(--dur-fast) var(--ease)}
.topbar-user.open .user-menu{opacity:1;pointer-events:auto;transform:none}
.user-menu-head{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3) var(--sp-3);margin-bottom:var(--sp-1);border-bottom:1px solid var(--border-soft)}
.user-menu-name{font-size:var(--fs-base);font-weight:500;color:var(--text-strong);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-menu-role{font-size:var(--fs-xs);color:var(--text-faint)}
.user-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:7px 10px;border:none;background:none;border-radius:var(--r-sm);font-size:var(--fs-base);color:var(--text-muted);font-weight:500;cursor:pointer;text-align:left;transition:background var(--dur-fast) var(--ease),color var(--dur-fast) var(--ease)}
.user-menu-item svg{width:15px;height:15px;color:var(--text-faint);flex-shrink:0}
.user-menu-item:hover{background:var(--bg-hover);color:var(--text-strong)}
.user-menu-item:hover svg{color:var(--text-muted)}
.user-menu-sep{height:1px;background:var(--border-soft);margin:var(--sp-1) 0}

.container{max-width:var(--content-max);margin:0 auto;padding:var(--sp-7) var(--sp-6);display:flex;flex-direction:column;gap:var(--sp-6)}

/* ============================================================
   TYPOGRAPHY
   ============================================================ */
.h1{font-size:var(--fs-2xl);font-weight:600;color:var(--text-strong);letter-spacing:-.02em;margin:0;line-height:var(--lh-tight)}
.h2{font-size:var(--fs-xl);font-weight:600;color:var(--text-strong);letter-spacing:-.015em;margin:0;line-height:var(--lh-snug)}
.h3{font-size:var(--fs-lg);font-weight:600;color:var(--text-strong);letter-spacing:-.01em;margin:0;line-height:var(--lh-snug)}
.h4{font-size:var(--fs-md);font-weight:600;color:var(--text-strong);margin:0;line-height:var(--lh-snug)}
.body{font-size:var(--fs-base);color:var(--text);margin:0;line-height:var(--lh-normal)}
.body-sm{font-size:var(--fs-sm);color:var(--text-muted);margin:0;line-height:var(--lh-normal)}
.caption{font-size:var(--fs-xs);color:var(--text-faint);text-transform:uppercase;letter-spacing:.06em;font-weight:600;margin:0}
.mono{font-family:var(--font-mono)}

.page-title{font-size:var(--fs-2xl);font-weight:600;color:var(--text-strong);letter-spacing:-.02em;margin:0}
.page-desc{font-size:var(--fs-md);color:var(--text-muted);margin:4px 0 0}

/* ============================================================
   CARD / SURFACE
   ============================================================ */
.card{background:var(--bg-elev);border:1px solid var(--border-soft);border-radius:var(--r-xl);overflow:hidden}
.card-pad{padding:var(--sp-5)}
.card-head{padding:var(--sp-4) var(--sp-5);border-bottom:1px solid var(--border-soft);display:flex;align-items:center;justify-content:space-between;gap:var(--sp-3)}
.card-foot{padding:var(--sp-4) var(--sp-5);border-top:1px solid var(--border-soft);display:flex;align-items:center;justify-content:flex-end;gap:var(--sp-2);background:var(--bg-sunken)}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:32px;padding:0 12px;border-radius:var(--r-sm);font-size:var(--fs-base);font-weight:500;border:1px solid transparent;background:transparent;color:var(--text);transition:all var(--dur-fast) var(--ease);white-space:nowrap;line-height:1}
.btn svg{width:14px;height:14px}
.btn:focus-visible{outline:none;box-shadow:var(--shadow-focus)}
.btn:disabled,.btn[aria-disabled="true"]{opacity:.5;cursor:not-allowed;pointer-events:none}
.btn.is-loading{position:relative;color:transparent}
.btn.is-loading::after{content:"";position:absolute;width:14px;height:14px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;color:inherit;animation:spin .7s linear infinite;left:calc(50% - 7px);top:calc(50% - 7px)}
@keyframes spin{to{transform:rotate(360deg)}}

.btn-primary{background:var(--brand-600);color:var(--brand-fg);border-color:var(--brand-600)}
.btn-primary:hover{background:var(--brand-700);border-color:var(--brand-700)}
.btn-default{background:var(--bg-elev);border-color:var(--border);color:var(--text-strong)}
.btn-default:hover{background:var(--bg-hover);border-color:var(--border-strong)}
.btn-ghost{background:transparent;color:var(--text-muted)}
.btn-ghost:hover{background:var(--bg-hover);color:var(--text-strong)}
.btn-danger{background:var(--danger-600);color:#fff;border-color:var(--danger-600)}
.btn-danger:hover{background:var(--danger-700);border-color:var(--danger-700)}
.btn-danger:focus-visible{box-shadow:var(--shadow-focus-danger)}
.btn-danger-ghost{background:transparent;color:var(--text-faint)}
.btn-danger-ghost:hover{background:var(--danger-50);color:var(--danger-600)}

.btn-sm{height:28px;padding:0 10px;font-size:var(--fs-sm);border-radius:var(--r-xs)}
.btn-sm svg{width:13px;height:13px}
.btn-lg{height:40px;padding:0 18px;font-size:var(--fs-md);border-radius:var(--r-md)}
.btn-icon{width:28px;height:28px;padding:0;border-radius:var(--r-xs)}
.btn-icon svg{width:14px;height:14px}
/* 기간 프리셋 버튼 — 현재 from/to 값과 일치하면 강조 */
.js-range-preset.active{background:var(--brand-50);border-color:var(--brand-200);color:var(--brand-700);font-weight:600}
.btn-block{width:100%}

/* ============================================================
   FORM CONTROLS
   ============================================================ */
.field{display:flex;flex-direction:column;gap:6px}
.label{font-size:var(--fs-sm);font-weight:500;color:var(--text-strong)}
.label .req{color:var(--danger-600);margin-left:2px}
.help{font-size:var(--fs-xs);color:var(--text-faint)}
.help-error{color:var(--danger-600)}

.input,.select,.textarea{
  height:32px;padding:0 12px;border:1px solid var(--border);border-radius:var(--r-sm);
  background:var(--bg-elev);color:var(--text);font-size:var(--fs-base);
  transition:border-color var(--dur-fast) var(--ease),box-shadow var(--dur-fast) var(--ease);
  width:100%;
}
.input:hover,.select:hover,.textarea:hover{border-color:var(--border-strong)}
.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--brand-500);box-shadow:var(--shadow-focus)}
.input::placeholder{color:var(--text-faint)}
.textarea{height:auto;padding:8px 12px;line-height:var(--lh-normal);resize:vertical;min-height:80px}
.input-lg{height:40px;font-size:var(--fs-md);border-radius:var(--r-md)}
.input.is-error,.textarea.is-error{border-color:var(--danger-500)}
.input.is-error:focus{box-shadow:var(--shadow-focus-danger)}
.input:disabled{background:var(--bg-sunken);color:var(--text-muted);cursor:not-allowed}

.checkbox{width:16px;height:16px;accent-color:var(--brand-600);cursor:pointer;margin:0}
.radio{width:16px;height:16px;accent-color:var(--brand-600);cursor:pointer;margin:0}

/* ============================================================
   LABEL CHIPS
   ============================================================ */
.label-chip{
  display:inline-flex;align-items:center;gap:6px;height:22px;padding:0 9px;
  border-radius:var(--r-pill);font-size:var(--fs-xs);font-weight:500;
  background:var(--lc-bg,#f1f5f9);color:var(--lc-fg,#475569);
  border:1px solid var(--lc-bd,#e2e8f0);line-height:1;letter-spacing:0;
}
.label-chip::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--lc,#94a3b8);flex-shrink:0}
.label-chip.no-dot::before{display:none}

.label-add{
  display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;
  border:1px dashed var(--border-strong);background:transparent;border-radius:50%;
  color:var(--text-faint);transition:all var(--dur-fast) var(--ease);padding:0;
}
.label-add:hover{border-color:var(--brand-500);color:var(--brand-600);background:var(--brand-50);border-style:solid}
.label-add svg{width:12px;height:12px}

.label-overflow{
  display:inline-flex;align-items:center;height:22px;padding:0 8px;
  border:1px solid var(--border);background:var(--bg-elev);border-radius:var(--r-pill);
  font-size:var(--fs-xs);font-weight:600;color:var(--text-muted);
  cursor:pointer;transition:all var(--dur-fast) var(--ease);
}
.label-overflow:hover{color:var(--text-strong);border-color:var(--border-strong);background:var(--bg-hover)}

/* ============================================================
   ROLE BADGES
   ============================================================ */
.role-badge{display:inline-flex;align-items:center;gap:4px;padding:1px 7px;border-radius:var(--r-pill);font-size:var(--fs-xs);font-weight:600}
.role-super{background:var(--brand-50);color:var(--brand-700);border:1px solid var(--brand-100)}
.role-admin{background:#ede9fe;color:#6d28d9;border:1px solid #ddd6fe}
.role-user{background:var(--success-50);color:var(--success-600);border:1px solid var(--success-100)}

/* ============================================================
   ICON TILES
   ============================================================ */
.icon-tile{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--r-sm);flex-shrink:0;background:var(--file-icon-bg);color:var(--file-icon-fg)}
.icon-tile svg{width:16px;height:16px}
.icon-tile.folder{background:var(--folder-icon-bg);color:var(--folder-icon-fg)}
.icon-tile.file{background:var(--file-icon-bg);color:var(--file-icon-fg)}
.icon-tile.pdf{background:var(--ft-pdf-bg);color:var(--ft-pdf-fg)}
.icon-tile.doc{background:var(--ft-doc-bg);color:var(--ft-doc-fg)}
.icon-tile.xls{background:var(--ft-xls-bg);color:var(--ft-xls-fg)}
.icon-tile.img{background:var(--ft-img-bg);color:var(--ft-img-fg)}
.icon-tile.zip{background:var(--ft-zip-bg);color:var(--ft-zip-fg)}
/* 파일명 왼쪽 클릭 동작 힌트(미리보기/다운로드) */
.action-hint{display:inline-flex;align-items:center;color:var(--text-faint);flex-shrink:0;cursor:help}
.action-hint svg{width:13px;height:13px}

/* ============================================================
   BULK SELECTION BAR — 자료 목록에서 항목 선택 시 등장
   ============================================================ */
.bulk-bar{display:inline-flex;align-items:center;gap:var(--sp-2);height:32px;padding:0 var(--sp-2) 0 var(--sp-3);background:var(--brand-50);border:1px solid var(--brand-100);border-radius:var(--r-pill);color:var(--brand-700);font-size:var(--fs-sm);font-weight:500;animation:bulk-in .16s var(--ease)}
.bulk-bar[hidden]{display:none}
.bulk-bar .bulk-sep{width:1px;height:14px;background:var(--brand-200)}
@keyframes bulk-in{from{opacity:0;transform:translateY(-3px)}to{opacity:1;transform:none}}

/* ============================================================
   DIALOG / MODAL
   ============================================================ */
.modal-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.4);opacity:0;pointer-events:none;transition:opacity var(--dur) var(--ease);z-index:80}
.modal-backdrop.open{opacity:1;pointer-events:auto}
.modal{position:fixed;top:50%;left:50%;transform:translate(-50%,calc(-50% + 8px));background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);width:min(440px,calc(100vw - 32px));z-index:90;opacity:0;pointer-events:none;transition:opacity var(--dur) var(--ease),transform var(--dur) var(--ease);display:flex;flex-direction:column;max-height:calc(100vh - 64px)}
.modal.open{opacity:1;pointer-events:auto;transform:translate(-50%,-50%)}
.modal-head{padding:var(--sp-5) var(--sp-5) var(--sp-3);display:flex;align-items:flex-start;gap:var(--sp-3)}
.modal-icon{width:40px;height:40px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.modal-icon.danger{background:var(--danger-50);color:var(--danger-600)}
.modal-icon.warn{background:var(--warn-50);color:var(--warn-600)}
.modal-icon.brand{background:var(--brand-50);color:var(--brand-600)}
.modal-icon svg{width:20px;height:20px}
.modal-title{font-size:var(--fs-lg);font-weight:600;color:var(--text-strong);margin:0;letter-spacing:-.01em}
.modal-desc{font-size:var(--fs-base);color:var(--text-muted);margin:6px 0 0;line-height:var(--lh-normal)}
.modal-body{padding:0 var(--sp-5) var(--sp-4);overflow-y:auto}
.modal-foot{padding:var(--sp-3) var(--sp-5) var(--sp-5);display:flex;justify-content:flex-end;gap:var(--sp-2)}
.modal-lg{width:min(640px,calc(100vw - 32px))}
.modal-xl{width:min(880px,calc(100vw - 32px))}
.modal-close{position:absolute;top:14px;right:14px;width:28px;height:28px;border:0;background:transparent;border-radius:var(--r-sm);color:var(--text-faint);display:flex;align-items:center;justify-content:center}
.modal-close:hover{background:var(--bg-hover);color:var(--text)}

/* ============================================================
   FILE PREVIEW MODAL — 파일명 클릭 인라인 미리보기
   ============================================================ */
.preview-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.55);opacity:0;pointer-events:none;transition:opacity var(--dur) var(--ease);z-index:80}
.preview-backdrop.open{opacity:1;pointer-events:auto}
.preview-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,calc(-50% + 8px));width:min(960px,calc(100vw - 48px));height:min(86vh,900px);background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);z-index:90;display:flex;flex-direction:column;opacity:0;pointer-events:none;transition:opacity var(--dur) var(--ease),transform var(--dur) var(--ease)}
.preview-modal.open{opacity:1;pointer-events:auto;transform:translate(-50%,-50%)}
.preview-head{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-3);padding:var(--sp-2) var(--sp-3) var(--sp-2) var(--sp-4);border-bottom:1px solid var(--border-soft)}
.preview-title{font-size:var(--fs-base);font-weight:600;color:var(--text-strong);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.preview-body{flex:1;min-height:0;background:var(--bg-sunken);border-radius:0 0 var(--r-xl) var(--r-xl);display:flex;align-items:center;justify-content:center;overflow:auto}
.preview-body iframe{width:100%;height:100%;border:0}
.preview-body img{max-width:100%;max-height:100%;object-fit:contain}

/* ============================================================
   TOAST  (variants: success/error/warn/info)
   ============================================================ */
.toast-stack{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;gap:8px;z-index:100;pointer-events:none}
.toast{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:var(--r-md);font-size:var(--fs-sm);font-weight:500;box-shadow:var(--shadow-lg);background:#0f172a;color:#fff;pointer-events:auto;min-width:240px;max-width:420px}
.toast svg{width:16px;height:16px;flex-shrink:0}
.toast.success{background:#064e3b;color:#d1fae5}
.toast.error  {background:#7f1d1d;color:#fee2e2}
.toast.warn   {background:#78350f;color:#fef3c7}
.toast.info   {background:#0f172a;color:#fff}

/* ============================================================
   EMPTY STATE
   ============================================================ */
.empty-state{padding:64px var(--sp-4);text-align:center;color:var(--text-muted);display:flex;flex-direction:column;align-items:center;gap:var(--sp-3)}
.empty-state-icon{width:56px;height:56px;border-radius:var(--r-lg);background:var(--bg-sunken);border:1px dashed var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-faint)}
.empty-state-icon svg{width:24px;height:24px}
.empty-state-title{font-size:var(--fs-base);font-weight:600;color:var(--text-strong);margin:0}
.empty-state-desc{font-size:var(--fs-sm);color:var(--text-muted);margin:0;max-width:360px;line-height:1.5}
.empty-state-cta{margin-top:var(--sp-2);display:inline-flex;gap:var(--sp-2)}

/* ============================================================
   PROGRESS BAR (업로드 등)
   ============================================================ */
.progress{height:6px;background:var(--bg-sunken);border-radius:var(--r-pill);overflow:hidden}
.progress-bar{height:100%;background:var(--brand-600);border-radius:var(--r-pill);transition:width 200ms var(--ease)}
.progress.error .progress-bar{background:var(--danger-500)}
.progress.success .progress-bar{background:var(--success-500)}

/* ============================================================
   TABLE
   ============================================================ */
.table-card{background:var(--bg-elev);border:1px solid var(--border-soft);border-radius:var(--r-xl);overflow:hidden}
.data{width:100%;border-collapse:collapse;font-size:var(--fs-base)}
.data thead th{font-size:var(--fs-xs);font-weight:600;color:var(--text-faint);text-transform:uppercase;letter-spacing:.06em;text-align:left;padding:var(--sp-3) var(--sp-4);height:36px;background:var(--bg-sunken);border-bottom:1px solid var(--border-soft);white-space:nowrap;user-select:none}
.data tbody td{padding:0 var(--sp-4);height:52px;border-bottom:1px solid var(--border-soft);vertical-align:middle;color:var(--text);white-space:nowrap}
.data tbody tr:last-child td{border-bottom:0}
.data tbody tr{transition:background var(--dur-fast) var(--ease)}
.data tbody tr:hover{background:var(--bg-hover)}
.cell-muted{color:var(--text-muted);font-size:var(--fs-sm)}
.cell-em-dash{color:var(--text-faint)}

/* ============================================================
   UTILS
   ============================================================ */
.flex{display:flex}
.flex-col{display:flex;flex-direction:column}
.row{display:flex;align-items:center;gap:var(--sp-2)}
.row-between{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-3)}
.gap-1{gap:var(--sp-1)} .gap-2{gap:var(--sp-2)} .gap-3{gap:var(--sp-3)} .gap-4{gap:var(--sp-4)} .gap-5{gap:var(--sp-5)} .gap-6{gap:var(--sp-6)}
.grid{display:grid}
.grow{flex:1;min-width:0}
.text-muted{color:var(--text-muted)}
.text-faint{color:var(--text-faint)}
.text-strong{color:var(--text-strong)}
.text-danger{color:var(--danger-600)}
.text-success{color:var(--success-600)}
.text-center{text-align:center}
.mono{font-family:var(--font-mono)}
.divider{height:1px;background:var(--border-soft);border:0;margin:var(--sp-4) 0}

/* ============================================================
   DRAWER — 우측에서 슬라이드 인 (모바일은 바닥 시트)
   ============================================================ */
.drawer-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.32);opacity:0;pointer-events:none;transition:opacity var(--dur) var(--ease);z-index:40}
.drawer-backdrop.open{opacity:1;pointer-events:auto}
.drawer{
    position:fixed;top:0;right:0;bottom:0;
    width:min(480px,100vw);
    background:var(--bg-elev);
    border-left:1px solid var(--border-soft);
    box-shadow:var(--shadow-lg);
    transform:translateX(100%);
    transition:transform var(--dur) var(--ease);
    display:flex;flex-direction:column;
    z-index:50;
}
.drawer.open{transform:translateX(0)}
.drawer-head{
    display:flex;align-items:flex-start;justify-content:space-between;
    gap:var(--sp-4);
    padding:var(--sp-5) var(--sp-5) var(--sp-4);
    border-bottom:1px solid var(--border-soft);
}
.drawer-title{font-size:var(--fs-lg);font-weight:600;color:var(--text-strong);margin:0 0 4px;letter-spacing:-.01em}
.drawer-subtitle{font-size:var(--fs-sm);color:var(--text-muted);margin:0;font-family:var(--font-mono);word-break:break-all}
.drawer-close{
    width:28px;height:28px;border:0;background:transparent;border-radius:var(--r-sm);
    color:var(--text-faint);display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.drawer-close:hover{background:var(--bg-hover);color:var(--text)}
.drawer-close svg{width:16px;height:16px}
.drawer-body{flex:1;overflow-y:auto;padding:var(--sp-5);display:flex;flex-direction:column;gap:var(--sp-5)}
.drawer-section{display:flex;flex-direction:column;gap:var(--sp-2)}
.drawer-section-label{font-size:var(--fs-xs);font-weight:600;color:var(--text-faint);text-transform:uppercase;letter-spacing:.06em}

/* URL row inside drawer */
.url-row{display:flex;gap:var(--sp-2)}
.url-input{
    flex:1;height:32px;
    border:1px solid var(--border);border-radius:var(--r-sm);
    padding:0 var(--sp-3);
    background:var(--bg-sunken);color:var(--text);
    font-family:var(--font-mono);font-size:var(--fs-sm);
}
.url-input:focus{outline:none;border-color:var(--brand-500);box-shadow:var(--shadow-focus)}
body.drawer-open{overflow:hidden}

@media (max-width:900px){
    .drawer{
        top:auto;left:0;right:0;bottom:0;
        width:100%;max-height:90vh;
        border-left:0;border-top:1px solid var(--border-soft);
        border-radius:var(--r-xl) var(--r-xl) 0 0;
        transform:translateY(100%);
    }
    .drawer.open{transform:translateY(0)}
}

/* ============================================================
   ROW FOLDER / ROW SELECTED
   ============================================================ */
.row-folder{background:var(--bg-row-folder)}
.row-folder:hover{background:var(--bg-row-folder-hover) !important}
.row-folder td{border-bottom-color:#f1ecd9}
.row-selected{background:var(--brand-50) !important}
.row-selected td{border-bottom-color:var(--brand-100)}

/* ============================================================
   LABEL ADD button (+) for inline label editing
   ============================================================ */
.label-add{
    display:inline-flex;align-items:center;justify-content:center;
    width:22px;height:22px;border-radius:50%;
    border:1px dashed var(--border-strong);background:transparent;
    color:var(--text-faint);cursor:pointer;
    transition:all var(--dur-fast) var(--ease);padding:0;
}
.label-add:hover{border-color:var(--brand-500);color:var(--brand-600);background:var(--brand-50);border-style:solid}
.label-add svg{width:12px;height:12px}
