/* v16 UI 확장 — places-master / milestones / rewards / contacts / context-drawer */

/* ───── aliases for chips (code uses hyphen form) ───── */
.chip-primary { background: var(--c-primary-soft); color: var(--c-primary); border-color: transparent; }
.chip-good    { background: rgba(22,163,74,.10);  color: var(--c-good); border-color: transparent; }
.chip-warn    { background: rgba(217,119,6,.10);  color: var(--c-warn); border-color: transparent; }
.chip-muted   { background: rgba(0,0,0,.04);      color: var(--muted, #6b7280); border-color: transparent; }

/* btn-primary alias so markup .btn.btn-primary also works */
.btn-primary { background: var(--c-primary); color: var(--c-on-primary); border-color: var(--c-primary); }
.btn-primary:hover { background: var(--c-primary-hover, #2bb77a); }

/* ───── pill row (tabs/filter chips) ───── */
.pm-tabs { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }
.pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 12px; border: 1px solid var(--c-line);
  border-radius: 999px; background: transparent; color: inherit;
  font-size: 13px; line-height: 1; cursor: pointer;
  transition: background .12s, border-color .12s;
}
.pill:hover { background: rgba(0,0,0,.04); }
.pill.on { background: var(--c-primary-soft); border-color: var(--c-primary); color: var(--c-primary); font-weight: 600; }
.pill b { font-weight: 600; margin-left: 2px; color: inherit; opacity: .75; }
.pill [data-lucide] { width: 14px; height: 14px; }

/* ───── places-master list ───── */
.pm-list { display: flex; flex-direction: column; }
.pm-row {
  display: grid; grid-template-columns: 36px 1fr auto auto;
  gap: 12px; align-items: center;
  padding: 10px 8px; border-bottom: 1px solid var(--c-line);
  cursor: pointer; transition: background .1s;
}
.pm-row:hover { background: var(--c-primary-soft); }
.pm-icon {
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(0,0,0,.04); display: grid; place-items: center;
}
.pm-icon [data-lucide] { width: 18px; height: 18px; color: var(--c-primary); }
.pm-name { font-weight: 600; }
.pm-last { font-size: 12px; color: var(--muted, #6b7280); white-space: nowrap; }
.pm-meta { display: flex; gap: 4px; flex-wrap: wrap; justify-content: flex-end; }

/* ───── milestones ───── */
.badge-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 10px;
}
.badge-card {
  border: 1px solid var(--c-line); border-radius: 12px;
  padding: 12px 10px; text-align: center;
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  background: var(--c-surface, #fff);
  transition: transform .1s, box-shadow .1s;
}
.badge-card.earned { box-shadow: 0 1px 0 rgba(0,0,0,.04); }
.badge-card.earned:hover { transform: translateY(-2px); box-shadow: 0 6px 16px rgba(0,0,0,.08); }
.badge-card.locked { opacity: .55; filter: saturate(.4); }
.badge-ico {
  width: 48px; height: 48px; border-radius: 12px; border: 2px solid;
  display: grid; place-items: center;
}
.badge-ico [data-lucide] { width: 24px; height: 24px; }
.badge-name { font-weight: 600; font-size: 13px; }

.tl-wrap { padding: 4px 0; }
.tl-month { margin-bottom: 20px; }
.tl-month-head {
  font-weight: 700; padding: 6px 10px; margin-bottom: 6px;
  background: var(--c-primary-soft); color: var(--c-primary);
  border-radius: 8px; display: inline-block; font-size: 13px;
}
.tl-item {
  display: flex; gap: 10px; align-items: flex-start;
  padding: 8px 10px; border-left: 3px solid #999;
  background: var(--c-surface, #fff);
  border-radius: 0 8px 8px 0;
  margin-bottom: 6px; cursor: pointer;
  transition: background .1s;
}
.tl-item:hover { background: rgba(0,0,0,.03); }
.tl-dot {
  width: 28px; height: 28px; border-radius: 50%;
  display: grid; place-items: center; flex-shrink: 0; color: #fff;
}
.tl-dot [data-lucide] { width: 14px; height: 14px; }
.tl-body { flex: 1; min-width: 0; }
.tl-title { font-weight: 600; margin-bottom: 2px; }
.tl-meta { display: flex; gap: 6px; align-items: center; flex-wrap: wrap; margin-bottom: 2px; }
.tl-desc { margin-top: 2px; }

/* ───── rewards ───── */
.person-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 10px; }
.person-card {
  border: 2px solid var(--c-line); border-radius: 14px;
  padding: 14px 10px; text-align: center;
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  background: var(--c-surface, #fff); cursor: pointer;
  transition: border-color .12s, transform .1s;
}
.person-card:hover { transform: translateY(-2px); }
.person-card.on { border-color: var(--c-primary); background: var(--c-primary-soft); }
.person-emoji { font-size: 32px; line-height: 1; }
.person-name { font-weight: 600; }

.wbar-wrap {
  display: flex; align-items: flex-end; gap: 4px;
  padding: 16px 6px 6px; min-height: 80px;
}
.wbar-col {
  flex: 1; display: flex; flex-direction: column; align-items: center;
  gap: 4px; min-width: 20px;
}
.wbar { width: 80%; min-height: 2px; border-radius: 3px; }
.wbar.pos { background: var(--c-good); }
.wbar.neg { background: var(--c-bad); }
.wbar-lbl { font-size: 10px; color: var(--muted, #6b7280); white-space: nowrap; }

.rw-list { display: flex; flex-direction: column; }
.rw-row {
  display: grid; grid-template-columns: 80px 32px 1fr auto;
  gap: 10px; align-items: center;
  padding: 8px 4px; border-bottom: 1px solid var(--c-line);
}
.rw-date { font-size: 12px; color: var(--muted, #6b7280); }
.rw-emoji { font-size: 22px; text-align: center; }
.rw-reason { font-weight: 500; }

/* ───── contacts ───── */
.ct-list { display: flex; flex-direction: column; }
.ct-row {
  display: grid; grid-template-columns: 40px 1fr auto;
  gap: 10px; align-items: center;
  padding: 8px 4px; border-bottom: 1px solid var(--c-line);
}
.ct-ico {
  width: 40px; height: 40px; border-radius: 50%;
  display: grid; place-items: center;
}
.ct-ico [data-lucide] { width: 18px; height: 18px; }
.ct-name { font-weight: 600; }
.ct-meta { display: flex; gap: 4px; flex-wrap: wrap; justify-content: flex-end; align-items: center; }

/* ───── Context Drawer ───── */
.ctx-drawer-host {
  position: fixed; inset: 0; pointer-events: none; z-index: 1000;
}
.ctx-drawer-host.open { pointer-events: auto; }
.ctx-drawer-scrim {
  position: absolute; inset: 0; background: rgba(0,0,0,.35);
  opacity: 0; transition: opacity .2s;
}
.ctx-drawer-host.open .ctx-drawer-scrim { opacity: 1; }
.ctx-drawer {
  position: absolute; top: 0; right: 0; bottom: 0;
  width: min(480px, 100%);
  background: var(--c-surface, #fff);
  box-shadow: -8px 0 32px rgba(0,0,0,.12);
  display: flex; flex-direction: column;
  transform: translateX(100%); transition: transform .25s ease-out;
}
.ctx-drawer-host.open .ctx-drawer { transform: translateX(0); }
.ctx-drawer-head {
  padding: 14px 16px; border-bottom: 1px solid var(--c-line);
  display: flex; align-items: flex-start; gap: 8px;
}
.ctx-drawer-title { margin: 0; font-size: 16px; font-weight: 700; flex: 1; }
.ctx-drawer-close {
  background: transparent; border: none; cursor: pointer;
  color: var(--muted, #6b7280); padding: 4px;
}
.ctx-drawer-close:hover { color: var(--c-primary); }
.ctx-drawer-body {
  padding: 14px 16px; overflow-y: auto; flex: 1;
  display: flex; flex-direction: column; gap: 14px;
}
.ctx-chips { display: flex; gap: 4px; flex-wrap: wrap; }
.ctx-section {
  background: rgba(0,0,0,.02); border-radius: 10px;
  padding: 10px 12px;
}
.ctx-section-head {
  margin: 0 0 8px; font-size: 13px; font-weight: 700;
  display: flex; align-items: center; gap: 6px;
  color: var(--c-primary);
}
.ctx-section-head [data-lucide] { width: 14px; height: 14px; }
.ctx-section-count {
  margin-left: auto; font-size: 11px; font-weight: 500;
  background: var(--c-primary); color: #fff;
  padding: 1px 8px; border-radius: 10px;
}
.ctx-section-body { display: flex; flex-direction: column; gap: 2px; }
.ctx-item {
  display: flex; gap: 8px; align-items: flex-start;
  padding: 6px 8px; border-radius: 6px;
  transition: background .1s;
}
.ctx-item-click { cursor: pointer; }
.ctx-item-click:hover { background: rgba(0,0,0,.05); }
.ctx-item-main { flex: 1; min-width: 0; }
.ctx-item-title { font-weight: 500; font-size: 13px; }
.ctx-item-sub { font-size: 12px; color: var(--muted, #6b7280); margin-top: 2px; }
.ctx-item-meta {
  font-size: 12px; color: var(--c-primary); font-weight: 600;
  white-space: nowrap; margin-left: auto; align-self: center;
}
.ctx-empty {
  padding: 12px; text-align: center; color: var(--muted, #6b7280);
  font-size: 12px;
}
body.ctx-drawer-locked { overflow: hidden; }

/* ───── calendar/money context trigger ───── */
.cal-day-ctx, .tx-ctx {
  background: transparent; border: 1px solid var(--c-line);
  border-radius: 8px; width: 28px; height: 28px;
  display: grid; place-items: center; cursor: pointer;
  color: var(--muted, #6b7280);
  transition: background .1s, color .1s, border-color .1s;
  flex-shrink: 0;
}
.cal-day-ctx:hover, .tx-ctx:hover {
  background: var(--c-primary-soft); color: var(--c-primary); border-color: var(--c-primary);
}
.cal-day-ctx [data-lucide], .tx-ctx [data-lucide] { width: 14px; height: 14px; }
.cal-day-item { position: relative; }
.cal-day-item .cal-day-ctx {
  position: absolute; right: 8px; top: 8px;
}

/* ───── Mobile responsive ───── */
@media (max-width: 720px) {
  .pm-row { grid-template-columns: 32px 1fr auto; }
  .pm-last { display: none; }
  .ctx-drawer { width: 100%; }
  .rw-row { grid-template-columns: 64px 28px 1fr auto; font-size: 13px; }
}

/* ───── Weekly Report ───── */
.wr-wrap { max-width: 1080px; margin: 0 auto; padding: 12px; }
.wr-toolbar { display: flex; justify-content: space-between; margin-bottom: 12px; }
.wr-title { padding: 8px 4px 16px; border-bottom: 1px solid var(--c-line); margin-bottom: 16px; }
.wr-title .h2 { display: flex; align-items: center; gap: 8px; margin: 0 0 4px; }

.wr-summary {
  display: grid; grid-template-columns: repeat(6, 1fr); gap: 12px;
  margin-bottom: 16px;
}
.wr-stat {
  background: var(--c-surface); border: 1px solid var(--c-line); border-radius: 10px;
  padding: 12px; text-align: center;
}
.wr-stat-v { font-size: 18px; font-weight: 700; }
.wr-stat-l { font-size: 12px; color: var(--c-muted); margin-top: 2px; }

.wr-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.wr-grid > .card { margin: 0; }

.wr-list { list-style: none; padding: 0; margin: 0; }
.wr-row {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 4px; border-bottom: 1px dashed var(--c-line);
  font-size: 14px;
}
.wr-row:last-child { border-bottom: none; }
.wr-row:hover { background: var(--c-primary-soft); }

.wr-spend-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.wr-cat { margin-bottom: 10px; }
.wr-cat-label { display: flex; justify-content: space-between; margin-bottom: 4px; }
.wr-cat-bar { height: 10px; background: var(--c-line); border-radius: 5px; overflow: hidden; }
.wr-cat-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--c-primary), var(--c-primary-deep, var(--c-primary)));
}

@media (max-width: 900px) {
  .wr-summary { grid-template-columns: repeat(3, 1fr); }
  .wr-grid, .wr-spend-grid { grid-template-columns: 1fr; }
}
@media print {
  .wr-toolbar, .mobile-nav, .sidenav, .topbar { display: none !important; }
  .wr-wrap { padding: 0; }
  .card { break-inside: avoid; }
}

/* ───── Context drawer actions ───── */
.ctx-actions {
  display: flex; gap: 6px; flex-wrap: wrap;
  padding: 10px 16px 4px; border-bottom: 1px solid var(--c-line);
  background: var(--c-surface-alt, var(--c-surface));
}
.ctx-action { display: inline-flex; align-items: center; gap: 4px; }
.ctx-action [data-lucide] { width: 14px; height: 14px; }

/* ───── Link picker modal ───── */
.lnk-picker-host {
  position: fixed; inset: 0; z-index: 1200;
  display: none; align-items: center; justify-content: center;
}
.lnk-picker-host.open { display: flex; }
.lnk-picker-scrim {
  position: absolute; inset: 0; background: rgba(0,0,0,.3);
}
.lnk-picker {
  position: relative;
  width: 480px; max-width: 92vw;
  max-height: 80vh; display: flex; flex-direction: column;
  background: var(--c-surface); border: 1px solid var(--c-line); border-radius: 12px;
  box-shadow: 0 24px 60px rgba(0,0,0,.2); overflow: hidden;
}
.lnk-picker-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 14px; border-bottom: 1px solid var(--c-line);
}
.lnk-picker-title { margin: 0; font-size: 15px; font-weight: 600; }
.lnk-picker-close {
  border: none; background: transparent; cursor: pointer;
  color: var(--c-muted, #6b7280); padding: 4px;
}
.lnk-picker-search { padding: 10px 14px; border-bottom: 1px dashed var(--c-line); }
.lnk-picker-input {
  width: 100%; padding: 8px 10px; font-size: 14px;
  border: 1px solid var(--c-line); border-radius: 8px; background: var(--c-bg);
}
.lnk-picker-body { flex: 1; overflow-y: auto; }
.lnk-picker-list { list-style: none; padding: 4px; margin: 0; }
.lnk-picker-row {
  padding: 8px 10px; border-radius: 8px; cursor: pointer;
  font-size: 13px;
}
.lnk-picker-row:hover { background: var(--c-primary-soft, #eef); }
