/* ===========================================================
   벨라 구직 커맨드센터 — 디자인 시스템 (아트 재설계 v2)
   editorial · warm · 라이트/다크 · MVP 확장형
   =========================================================== */

/* ---- 디자인 토큰 ---- */
:root {
  --font-display: "Fraunces", "Pretendard", serif;
  --font-body: "Pretendard", system-ui, sans-serif;
  --r-lg: 18px; --r-md: 13px; --r-sm: 9px;
  --pad: clamp(16px, 4vw, 28px);
  --maxw: 1240px;
  --ease: cubic-bezier(.22,.61,.36,1);
}
/* 라이트 (기본) — 따뜻한 종이 */
:root, [data-theme="light"] {
  --bg: #f6f2e9;
  --bg-grad: radial-gradient(1100px 520px at 88% -8%, #efe7d3 0%, #f6f2e9 60%);
  --elev: #fffdf8;
  --card: #fffefb;
  --card-2: #fbf7ee;
  --ink: #221c14;
  --ink-2: #5b5246;
  --ink-3: #847a66;
  --line: #e6ddcc;
  --line-2: #d8cdb6;
  --gold: #8a5e1c;
  --gold-2: #c89a4c;
  --gold-ink: #fffaf0;
  --mint: #1a6f5b; --mint-bg:#e3f1ec;
  --rose: #a83a4e; --rose-bg:#f6e6e9;
  --blue: #2c569c; --blue-bg:#e6ecf6;
  --violet:#5d44a4; --violet-bg:#ece7f6;
  --shadow: 0 1px 2px rgba(60,45,20,.06), 0 14px 34px rgba(80,60,25,.10);
  --shadow-sm: 0 1px 2px rgba(60,45,20,.05), 0 4px 12px rgba(80,60,25,.06);
}
/* 다크 — 따뜻한 무광 */
[data-theme="dark"] {
  --bg: #141009;
  --bg-grad: radial-gradient(1100px 520px at 88% -8%, #221a10 0%, #141009 60%);
  --elev: #2a2216;
  --card: #241d13;
  --card-2: #1b160e;
  --ink: #f3ecdd;
  --ink-2: #b9ad97;
  --ink-3: #8a8069;
  --line: #322a1d;
  --line-2: #443a28;
  --gold: #e6ba6c;
  --gold-2: #d2a652;
  --gold-ink: #1c1305;
  --mint: #6fd2b6; --mint-bg:#152620;
  --rose: #f0a0ad; --rose-bg:#2b1519;
  --blue: #9cbcf0; --blue-bg:#141d2c;
  --violet:#bca8f0; --violet-bg:#1c1730;
  --shadow: 0 1px 2px rgba(0,0,0,.4), 0 16px 38px rgba(0,0,0,.42);
  --shadow-sm: 0 1px 2px rgba(0,0,0,.35), 0 6px 16px rgba(0,0,0,.30);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  background: var(--bg-grad) fixed, var(--bg);
  color: var(--ink);
  font-family: var(--font-body);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  transition: background .4s var(--ease), color .25s var(--ease);
  padding-bottom: 90px;
}
.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 var(--pad); }
a { color: inherit; }

/* ---- 헤더 ---- */
.topbar { display: flex; align-items: center; gap: 14px; padding: 22px 0 0; }
.brand { display: flex; flex-direction: column; }
.brand .kick { font-size: 11px; letter-spacing: .26em; text-transform: uppercase; color: var(--gold); font-weight: 700; }
.brand h1 { font-family: var(--font-display); font-weight: 600; font-size: clamp(26px, 4.6vw, 40px); letter-spacing: -.015em; line-height: 1.05; margin-top: 2px; }
.brand h1 em { font-style: italic; color: var(--gold); }
.topbar .spacer { flex: 1; }
.theme-btn { width: 44px; height: 44px; border-radius: 50%; border: 1px solid var(--line-2); background: var(--elev); color: var(--ink); font-size: 18px; cursor: pointer; display: grid; place-items: center; transition: .2s var(--ease); box-shadow: var(--shadow-sm); }
.theme-btn:hover { transform: rotate(-12deg) scale(1.06); border-color: var(--gold); }

.lede { color: var(--ink-2); font-size: 15px; max-width: 720px; margin: 16px 0 0; }

/* ---- 링크 추가 (자동수집) ---- */
.ingest { margin: 22px 0 6px; background: linear-gradient(180deg, var(--elev), var(--card)); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 16px 18px; box-shadow: var(--shadow-sm); }
.ingest .lab { font-size: 12.5px; font-weight: 700; color: var(--ink); display: flex; align-items: center; gap: 7px; }
.ingest .hint { font-size: 11.5px; color: var(--ink-3); margin: 2px 0 11px; }
.ingest form { display: flex; gap: 9px; }
.ingest input { flex: 1; background: var(--bg); border: 1px solid var(--line-2); border-radius: var(--r-md); color: var(--ink); padding: 12px 14px; font-size: 13.5px; font-family: inherit; outline: none; transition: .18s; }
.ingest input:focus { border-color: var(--gold); box-shadow: 0 0 0 3px color-mix(in srgb, var(--gold) 18%, transparent); }
.ingest button { white-space: nowrap; }

/* ---- 통계 ---- */
.stats { display: grid; grid-template-columns: repeat(5, 1fr); gap: 11px; margin: 20px 0 4px; }
.stat { background: var(--card); border: 1px solid var(--line); border-radius: var(--r-md); padding: 14px 15px; box-shadow: var(--shadow-sm); }
.stat .n { font-family: var(--font-display); font-size: 27px; font-weight: 600; line-height: 1; }
.stat .l { font-size: 11.5px; color: var(--ink-3); margin-top: 5px; font-weight: 500; }
.stat.g .n { color: var(--gold); } .stat.r .n { color: var(--rose); } .stat.m .n { color: var(--mint); } .stat.b .n { color: var(--blue); }

/* ---- 툴바 ---- */
.toolbar { position: sticky; top: 0; z-index: 30; display: flex; flex-wrap: wrap; gap: 10px; align-items: center; margin: 24px 0 18px; padding: 13px 0; background: linear-gradient(var(--bg) 72%, transparent); }
.chips { display: flex; flex-wrap: wrap; gap: 7px; }
.chip { cursor: pointer; user-select: none; font-size: 12.5px; padding: 8px 14px; border-radius: 999px; border: 1px solid var(--line-2); background: var(--elev); color: var(--ink-2); transition: .16s var(--ease); font-weight: 500; }
.chip:hover { border-color: var(--gold); color: var(--ink); }
.chip.on { background: var(--gold); color: var(--gold-ink); border-color: var(--gold); font-weight: 700; }
.toolbar .right { margin-left: auto; display: flex; gap: 9px; align-items: center; }
.sel, .search input { background: var(--elev); border: 1px solid var(--line-2); border-radius: var(--r-md); color: var(--ink); padding: 9px 12px; font-size: 12.5px; font-family: inherit; outline: none; }
.search input { width: 200px; }
.search input:focus, .sel:focus { border-color: var(--gold); }

/* ---- 뷰 탭 (공고 / 작업실) ---- */
.viewtabs { display: flex; gap: 8px; margin: 22px 0 2px; }
.vtab { font-family: inherit; font-size: 13.5px; font-weight: 600; padding: 10px 18px; border-radius: 999px; border: 1px solid var(--line-2); background: var(--elev); color: var(--ink-2); cursor: pointer; transition: .16s var(--ease); }
.vtab:hover { border-color: var(--gold); color: var(--ink); }
.vtab.on { background: var(--ink); color: var(--bg); border-color: var(--ink); }

/* ---- 작업실 카드 ---- */
.wcard { background: linear-gradient(180deg, var(--card), var(--card-2)); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 19px; box-shadow: var(--shadow-sm); display: flex; flex-direction: column; }
.wcard .c-co { font-size: 12px; font-weight: 700; color: var(--gold); }
.wcard .c-title { font-family: var(--font-display); font-weight: 600; font-size: 18px; margin-top: 3px; }
.steps { display: flex; gap: 6px; margin: 14px 0; }
.step { flex: 1; text-align: center; font-size: 10.5px; font-weight: 600; padding: 7px 4px; border-radius: var(--r-sm); background: var(--bg); border: 1px solid var(--line); color: var(--ink-3); }
.step.done { background: color-mix(in srgb, var(--mint) 16%, transparent); border-color: var(--mint); color: var(--mint); }
.step.cur { background: var(--gold); border-color: var(--gold); color: var(--gold-ink); }
.docs { display: flex; flex-wrap: wrap; gap: 7px; margin-bottom: 6px; }
.doc { font-size: 12px; font-weight: 600; padding: 8px 12px; border-radius: var(--r-md); border: 1px solid var(--line-2); background: var(--elev); color: var(--ink); text-decoration: none; transition: .15s; }
.doc:hover { border-color: var(--gold); transform: translateY(-1px); }
.doc.empty-doc { color: var(--ink-3); opacity: .55; pointer-events: none; }

/* 미니 액션 (캘린더·보관·삭제) */
.c-mini { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 9px; padding-top: 9px; border-top: 1px dashed var(--line); }
.mini { font-family: inherit; font-size: 11.5px; font-weight: 600; padding: 6px 11px; border-radius: 999px; border: 1px solid var(--line-2); background: var(--bg); color: var(--ink-2); cursor: pointer; text-decoration: none; transition: .15s var(--ease); }
.mini:hover { border-color: var(--gold); color: var(--ink); transform: translateY(-1px); }
.mini.danger:hover { border-color: var(--rose); color: var(--rose); }
.statussel { font-family: inherit; font-size: 11.5px; font-weight: 600; padding: 6px 10px; border-radius: 999px; border: 1px solid var(--line-2); background: var(--bg); color: var(--ink-3); cursor: pointer; outline: none; }
.statussel:hover { border-color: var(--gold); }
.statussel.st-관심 { color: var(--blue); border-color: color-mix(in srgb, var(--blue) 45%, transparent); background: var(--blue-bg); }
.statussel.st-작업중 { color: var(--gold); border-color: var(--gold); background: color-mix(in srgb, var(--gold) 12%, transparent); }
.statussel.st-지원완료 { color: var(--mint); border-color: color-mix(in srgb, var(--mint) 45%, transparent); background: var(--mint-bg); }
.statussel.st-보류 { color: var(--ink-3); border-style: dashed; }
.archive-toggle { margin-left: auto; }
.vtab.archive-toggle.on { background: var(--gold); color: var(--gold-ink); border-color: var(--gold); }

/* ---- 카드 그리드 ---- */
.grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(360px, 1fr)); gap: 16px; }
.card { background: linear-gradient(180deg, var(--card), var(--card-2)); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 19px 19px 16px; box-shadow: var(--shadow-sm); position: relative; overflow: hidden; transition: transform .2s var(--ease), box-shadow .2s var(--ease), border-color .2s var(--ease); display: flex; flex-direction: column; opacity: 0; transform: translateY(10px); animation: rise .5s var(--ease) forwards; }
@keyframes rise { to { opacity: 1; transform: none; } }
.card::before { content: ""; position: absolute; inset: 0 auto 0 0; width: 4px; background: var(--line-2); }
.card.f5::before { background: linear-gradient(var(--gold), var(--rose)); }
.card.f4::before { background: var(--mint); }
.card.f3::before { background: var(--blue); }
.card:hover { transform: translateY(-3px); box-shadow: var(--shadow); border-color: var(--gold); }

.c-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; }
.c-co { font-size: 12px; font-weight: 700; color: var(--gold); letter-spacing: .02em; }
.c-title { font-family: var(--font-display); font-weight: 600; font-size: 18.5px; line-height: 1.25; margin-top: 4px; letter-spacing: -.01em; }
.fit { flex-shrink: 0; font-size: 12px; font-weight: 700; padding: 5px 10px; border-radius: 999px; white-space: nowrap; letter-spacing: .04em; }
.f5 .fit { color: var(--gold); background: color-mix(in srgb, var(--gold) 14%, transparent); border: 1px solid var(--gold); }
.f4 .fit { color: var(--mint); background: var(--mint-bg); border: 1px solid color-mix(in srgb, var(--mint) 40%, transparent); }
.f3 .fit { color: var(--blue); background: var(--blue-bg); border: 1px solid color-mix(in srgb, var(--blue) 40%, transparent); }

.c-meta { display: flex; flex-wrap: wrap; gap: 6px; margin: 13px 0 12px; }
.pill { font-size: 11px; padding: 5px 9px; border-radius: var(--r-sm); background: var(--bg); border: 1px solid var(--line); color: var(--ink-2); display: inline-flex; gap: 5px; align-items: center; font-weight: 500; }
.pill.cat { color: var(--violet); background: var(--violet-bg); border-color: color-mix(in srgb, var(--violet) 30%, transparent); }
.pill.remote { color: var(--mint); background: var(--mint-bg); border-color: color-mix(in srgb, var(--mint) 30%, transparent); }
.pill.due { color: var(--rose); background: var(--rose-bg); border-color: color-mix(in srgb, var(--rose) 30%, transparent); }
.pill.status { color: var(--ink-2); }

.c-reason { font-size: 13px; color: var(--ink-2); line-height: 1.5; padding: 11px 0 0; border-top: 1px dashed var(--line-2); }
.c-reason b { color: var(--gold); }
.c-detail { font-size: 12px; color: var(--ink-3); margin-top: 9px; line-height: 1.55; display: none; }
.c-detail.open { display: block; }
.c-detail .row { margin-top: 5px; }
.c-detail .k { color: var(--ink-2); font-weight: 600; }
.more { font-size: 11.5px; color: var(--gold); cursor: pointer; margin-top: 8px; user-select: none; font-weight: 600; display: inline-flex; gap: 4px; }

.c-actions { display: flex; gap: 8px; margin-top: auto; padding-top: 14px; }
.btn { border: 1px solid var(--line-2); background: var(--elev); color: var(--ink); font-family: inherit; font-size: 12.5px; font-weight: 600; padding: 10px 13px; border-radius: var(--r-md); cursor: pointer; transition: .16s var(--ease); text-decoration: none; display: inline-flex; align-items: center; justify-content: center; gap: 6px; }
.btn:hover { border-color: var(--gold); transform: translateY(-1px); }
.btn.primary { background: var(--gold); color: var(--gold-ink); border-color: var(--gold); flex: 1; }
.btn.primary:hover { filter: brightness(1.07); }
.btn.ghost { color: var(--ink-2); }

/* ---- 토스트 ---- */
.toast { position: fixed; left: 50%; bottom: 30px; transform: translate(-50%, 30px); background: var(--ink); color: var(--bg); padding: 13px 20px; border-radius: 999px; font-size: 13px; font-weight: 600; box-shadow: var(--shadow); opacity: 0; pointer-events: none; transition: .3s var(--ease); z-index: 100; max-width: 88vw; }
.toast.show { opacity: 1; transform: translate(-50%, 0); }

/* ---- 내 조건 (멀티유저 프로필) ---- */
.profile-btn { height: 44px; padding: 0 16px; border-radius: 999px; border: 1px solid var(--line-2); background: var(--elev); color: var(--ink); font-family: inherit; font-size: 13px; font-weight: 600; cursor: pointer; display: inline-flex; align-items: center; gap: 7px; transition: .2s var(--ease); box-shadow: var(--shadow-sm); }
.profile-btn:hover { border-color: var(--gold); }
.greet { margin: 14px 0 0; font-size: 14px; color: var(--ink-2); }
.greet b { color: var(--gold); }

.pill.match { color: var(--gold); background: color-mix(in srgb, var(--gold) 14%, transparent); border-color: var(--gold); font-weight: 700; }

.modal-bg { position: fixed; inset: 0; background: color-mix(in srgb, #000 55%, transparent); backdrop-filter: blur(4px); display: none; place-items: center; z-index: 200; padding: 18px; }
.modal-bg.show { display: grid; animation: fade .2s var(--ease); }
@keyframes fade { from { opacity: 0; } }
.modal { background: var(--elev); border: 1px solid var(--line-2); border-radius: var(--r-lg); max-width: 480px; width: 100%; padding: 26px; box-shadow: var(--shadow); max-height: 90vh; overflow: auto; }
.modal h2 { font-family: var(--font-display); font-size: 23px; font-weight: 600; }
.modal .sub { color: var(--ink-3); font-size: 13px; margin: 4px 0 18px; }
.field { margin-bottom: 16px; }
.field > label { font-size: 12.5px; font-weight: 700; color: var(--ink); display: block; margin-bottom: 8px; }
.field input { width: 100%; background: var(--bg); border: 1px solid var(--line-2); border-radius: var(--r-md); color: var(--ink); padding: 11px 13px; font-size: 13.5px; font-family: inherit; outline: none; }
.field input:focus { border-color: var(--gold); }
.opts { display: flex; flex-wrap: wrap; gap: 7px; }
.opt { cursor: pointer; user-select: none; font-size: 12.5px; padding: 8px 13px; border-radius: 999px; border: 1px solid var(--line-2); background: var(--bg); color: var(--ink-2); transition: .15s; }
.opt:hover { border-color: var(--gold); }
.opt.on { background: var(--gold); color: var(--gold-ink); border-color: var(--gold); font-weight: 700; }
.modal-actions { display: flex; gap: 9px; margin-top: 22px; }
.modal-actions .btn { flex: 1; padding: 12px; }

.empty { text-align: center; color: var(--ink-3); padding: 70px 0; font-size: 14px; }
footer { margin-top: 44px; padding-top: 22px; border-top: 1px solid var(--line); color: var(--ink-3); font-size: 12px; text-align: center; line-height: 1.9; }
footer b { color: var(--ink-2); }

@media (max-width: 720px) {
  .stats { grid-template-columns: repeat(2, 1fr); }
  .grid { grid-template-columns: 1fr; }
  .search input { width: 130px; }
  .ingest form { flex-direction: column; }
}
