:root {
  --bg: #f1ece3;
  --surface: #fbf8f3;
  --border: #e1d9cc;
  --text: #33302b;
  --muted: #8c8475;
  --primary: #3f3b35;
  --primary-dark: #2a2722;
  --accent-soft: #efe9df;
  --positive: #5c6b4f;
  --positive-bg: #e7ebe0;
  --negative: #a0564e;
  --negative-bg: #f1e2df;
  --info: #9a7b44;
  --info-bg: #f3ebda;
  --radius: 10px;
  --shadow: 0 1px 3px rgba(60,50,35,.06), 0 1px 2px rgba(60,50,35,.04);
}

* { box-sizing: border-box; }

body {
  margin: 0;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Hiragino Sans", "Noto Sans JP", Meiryo, sans-serif;
  background: var(--bg);
  color: var(--text);
  line-height: 1.6;
}

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

/* ---------- Topbar ---------- */
.topbar {
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  box-shadow: var(--shadow);
  position: sticky;
  top: 0;
  z-index: 50;
}
.topbar-inner {
  max-width: 1100px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 18px;
  padding: 10px 16px;
}
.brand { font-weight: 700; font-size: 1.15rem; color: var(--text); }
.brand:hover { text-decoration: none; }
.nav-toggle {
  display: none;
  margin-left: auto;
  font-size: 1.4rem;
  background: none;
  border: none;
  cursor: pointer;
}
.mainnav { display: flex; gap: 4px; align-items: center; }
.mainnav a {
  padding: 8px 12px;
  border-radius: 8px;
  color: var(--text);
  position: relative;
}
.mainnav a:hover { background: var(--bg); text-decoration: none; }
.mainnav a.is-active { background: var(--primary); color: #fff; }
.bell .badge {
  position: absolute;
  top: -2px; right: -2px;
  background: var(--negative);
  color: #fff;
  font-size: .7rem;
  min-width: 18px;
  height: 18px;
  line-height: 18px;
  text-align: center;
  border-radius: 9px;
  padding: 0 4px;
}
.user-menu {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: .9rem;
}
.user-name { color: var(--muted); }

/* ---------- Layout ---------- */
.container {
  max-width: 1100px;
  margin: 24px auto;
  padding: 0 16px;
}
/* カレンダーページは横幅を広げて大きく表示 */
.page-calendar .container { max-width: 1400px; }
.site-footer {
  text-align: center;
  color: var(--muted);
  padding: 30px 16px;
}

.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 20px;
  margin-bottom: 20px;
}

.page-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}
.page-head h1 { font-size: 1.4rem; margin: 0; }

/* ---------- Admin tabs ---------- */
.admin-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 20px;
}
.admin-tabs a {
  padding: 9px 16px;
  border: 1px solid transparent;
  border-bottom: none;
  border-radius: 8px 8px 0 0;
  color: var(--muted);
  font-weight: 600;
  font-size: .95rem;
  margin-bottom: -1px;
}
.admin-tabs a:hover {
  color: var(--text);
  text-decoration: none;
  background: var(--accent-soft);
}
.admin-tabs a.is-active {
  color: var(--text);
  background: var(--surface);
  border-color: var(--border);
  border-bottom-color: var(--surface);
}

/* ---------- Buttons / forms ---------- */
.btn {
  display: inline-block;
  background: var(--primary);
  color: #fff;
  border: none;
  padding: 9px 16px;
  border-radius: 8px;
  font-size: .95rem;
  cursor: pointer;
  text-align: center;
}
.btn:hover { background: var(--primary-dark); text-decoration: none; }
.btn-secondary { background: var(--accent-soft); color: var(--text); border: 1px solid var(--border); }
.btn-secondary:hover { background: #e3dccf; }
.btn-danger { background: var(--negative); }
.btn-danger:hover { background: #991b1b; }
.btn-sm { padding: 5px 10px; font-size: .85rem; }

label { font-weight: 600; font-size: .9rem; display: block; margin-bottom: 4px; }
input[type=text], input[type=password], input[type=date], input[type=search],
select, textarea {
  width: 100%;
  padding: 9px 11px;
  border: 1px solid var(--border);
  border-radius: 8px;
  font-size: .95rem;
  font-family: inherit;
  background: #fffdfa;
  color: var(--text);
}
input[type=text]:focus, input[type=password]:focus, input[type=date]:focus,
input[type=search]:focus, select:focus, textarea:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(63,59,53,.08);
}
textarea { resize: vertical; min-height: 60px; }
.field { margin-bottom: 14px; }
.form-row { display: flex; gap: 12px; flex-wrap: wrap; }
.form-row > * { flex: 1; min-width: 140px; }
.form-actions {
  display: flex;
  gap: 10px;
  justify-content: flex-end;
  flex-wrap: wrap;
  margin-top: 16px;
  padding-top: 4px;
  border-top: 1px solid var(--border);
}

.alert {
  padding: 12px 16px;
  border-radius: 8px;
  margin-bottom: 16px;
}
.alert-success { background: var(--positive-bg); color: var(--positive); }
.alert-error { background: var(--negative-bg); color: var(--negative); }

/* ---------- Calendar ---------- */
.cal-nav { display: flex; align-items: center; gap: 14px; }
.cal-nav h2 { margin: 0; font-size: 1.25rem; }
.calendar { width: 100%; border-collapse: collapse; table-layout: fixed; }
.calendar th {
  padding: 8px;
  font-size: .85rem;
  color: var(--muted);
  border-bottom: 1px solid var(--border);
}
.calendar td {
  border: 1px solid var(--border);
  vertical-align: top;
  height: 132px;
  padding: 6px;
}
.calendar td.other-month { background: #f4f0e8; }
.cell-day {
  font-size: .95rem;
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 4px;
  color: var(--text);
  padding: 3px 6px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--surface);
  cursor: pointer;
  transition: background .15s, border-color .15s, box-shadow .15s, color .15s;
}
.cell-day:hover {
  background: var(--accent-soft);
  border-color: var(--primary);
  text-decoration: none;
}
.cell-day:active { background: var(--accent-soft); }
.cell-day:focus-visible {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 2px var(--accent-soft);
}
.cell-day-num { line-height: 1.2; }
/* 日付の横のアイコンスペース */
.cell-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  flex: 0 0 18px;
}
.cell-icon svg { display: block; }
.cell-icon.is-written { color: var(--positive); }
.cell-icon.is-draft { color: var(--info); }
.cell-icon.is-unwritten { color: var(--muted); opacity: .55; }
.cell-icon.is-empty { visibility: hidden; }
.calendar td.today { background: var(--accent-soft); }
.calendar .sun .cell-day { color: var(--negative); }
.calendar .sat .cell-day { color: #6b7c8a; }
.cell-event {
  font-size: .72rem;
  background: var(--bg);
  border-radius: 4px;
  padding: 1px 4px;
  margin-top: 2px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
/* 余白に直接書き込む予定メモ */
.cell-note {
  display: block;
  width: 100%;
  margin-top: 2px;
  padding: 2px 3px;
  border: 1px solid transparent;
  border-radius: 4px;
  background: transparent;
  font-family: inherit;
  font-size: .82rem;
  line-height: 1.4;
  color: var(--text);
  resize: none;
  overflow: hidden;
  min-height: 88px;
  box-sizing: border-box;
  transition: background .15s, border-color .15s, box-shadow .15s;
}
.cell-note::placeholder { color: var(--muted); opacity: .55; }
.cell-note:hover { border-color: var(--border); }
.cell-note:focus {
  outline: none;
  background: var(--surface);
  border-color: var(--primary);
  box-shadow: 0 0 0 2px var(--accent-soft);
}
.cell-note.is-saving { background: var(--accent-soft); }
.cell-note.is-saved { background: var(--positive-bg); }
.cell-note-view {
  margin-top: 2px;
  font-size: .82rem;
  line-height: 1.4;
  white-space: pre-wrap;
  word-break: break-word;
}
/* カレンダー下の凡例 */
.cal-legend { display: flex; flex-wrap: wrap; align-items: center; gap: 4px 14px; }
.cal-legend-item { display: inline-flex; align-items: center; gap: 4px; }
.cal-legend-item .cell-icon { width: 16px; height: 16px; flex: 0 0 16px; }
/* 選択中の日付セル */
.calendar td.is-selected {
  outline: 2px solid var(--primary);
  outline-offset: -2px;
}
.calendar td.is-selected .cell-day { border-color: var(--primary); }

/* ---------- 日報パネル（カレンダー直下にスライド表示・折りたたみ式） ---------- */
.report-panel { scroll-margin-top: 70px; }
.report-panel.is-loading { opacity: .5; pointer-events: none; }

/* 折りたたみの見出しボタン */
.panel-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  background: none;
  border: none;
  padding: 0;
  margin: 0;
  cursor: pointer;
  font: inherit;
  color: var(--text);
  text-align: left;
}
.panel-toggle-title { font-size: 1.2rem; font-weight: 700; }
.panel-toggle-icon {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: .9rem;
  font-weight: 600;
  color: var(--primary);
  background: var(--accent-soft);
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 5px 12px;
  white-space: nowrap;
}
.panel-toggle:hover .panel-toggle-icon { background: var(--border); }
.panel-toggle-chev { font-size: .85rem; transition: transform .2s; }
.report-panel:not(.is-collapsed) .panel-toggle-chev { transform: rotate(180deg); }
/* テキストは開閉状態で切り替え */
.report-panel.is-collapsed .panel-toggle-label::after { content: '開く'; }
.report-panel:not(.is-collapsed) .panel-toggle-label::after { content: '閉じる'; }

/* 折りたたみ時は本体を隠し、見出しだけ表示 */
.report-panel.is-collapsed .report-panel-body { display: none; }
.report-panel:not(.is-collapsed) .panel-toggle { margin-bottom: 16px; }
.report-panel .panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 14px;
}
.report-panel .panel-head h2 { margin: 0; font-size: 1.2rem; }
.report-panel .panel-date { font-size: .95rem; font-weight: 400; margin-left: 6px; }
.report-panel .panel-section {
  margin-top: 18px;
  padding-top: 16px;
  border-top: 1px solid var(--border);
}
.report-panel .panel-section h3 { margin: 0 0 10px; font-size: 1.05rem; }

/* スライドイン */
@keyframes panel-slide-in {
  from { opacity: 0; transform: translateY(-10px); }
  to   { opacity: 1; transform: translateY(0); }
}
.report-panel.slide-in .report-panel-body {
  animation: panel-slide-in .22s ease-out;
}

/* ---------- Report（作成画面はカード型フォーム） ---------- */
.report-row {
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 14px;
  margin-bottom: 14px;
  background: #f7f3ec;
}
.report-row .row-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 8px;
}

/* ---------- Report（閲覧は帳票風テーブル） ---------- */
.report-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin-bottom: 14px;
  border: 1px solid var(--border);
  border-radius: 8px;
}
.report-table {
  width: 100%;
  min-width: 720px;
  border-collapse: collapse;
  background: var(--surface);
  font-size: .9rem;
}
.report-table th,
.report-table td {
  border: 1px solid var(--border);
  padding: 7px 8px;
  vertical-align: top;
  text-align: left;
}
.report-table thead th {
  background: var(--accent-soft);
  text-align: center;
  font-weight: 700;
  color: var(--text);
  white-space: nowrap;
}
.report-table .rt-sub {
  display: block;
  font-size: .72rem;
  font-weight: 600;
  color: var(--muted);
}
.report-table .rt-no {
  width: 40px;
  text-align: center;
  color: var(--muted);
  white-space: nowrap;
}
.report-table .rt-company { width: 17%; }
.report-table .rt-place   { width: 15%; }
.report-table .rt-customer{ width: 13%; }
.report-table .rt-content { width: auto; }

/* 閲覧テーブル */
.report-table.report-view td { background: #fffdfa; }
/* No. は上下・左右とも中央 */
.report-table.report-view .rt-no { text-align: center; vertical-align: middle; }
/* 得意先名・現場名・担当者名は上下だけ中央（左右は左揃えのまま） */
.report-table.report-view .rt-company,
.report-table.report-view .rt-place,
.report-table.report-view .rt-customer { text-align: left; vertical-align: middle; }
/* 商談内容は左揃え（上下は上寄せ） */
.report-table.report-view .rt-content { text-align: left; vertical-align: top; }
/* 高さを抑えるため、読みやすさを保ちつつ上下を詰める */
.report-table.report-view th,
.report-table.report-view td { padding-top: 3px; padding-bottom: 3px; }
.report-table.report-view .content-view { line-height: 1.4; }
.report-table .rt-cat-tag {
  display: inline-block;
  margin-left: 4px;
  font-size: .72rem;
  color: var(--muted);
  white-space: nowrap;
}
/* 帳票フッターの会社名 */
.report-company-foot {
  text-align: right;
  color: var(--muted);
  font-size: .85rem;
  margin: -6px 0 4px;
}
.marker-positive { background: var(--positive-bg); border-left: 4px solid var(--positive); }
.marker-negative { background: var(--negative-bg); border-left: 4px solid var(--negative); }
.marker-info     { background: var(--info-bg);     border-left: 4px solid var(--info); }

/* お知らせ一覧の各カード */
.announce-item {
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 14px;
  margin-bottom: 14px;
  background: #f7f3ec;
}
.announce-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 8px;
}

/* ---------- 内容のインラインマーカー（エクセル風ハイライト） ---------- */
/* ツールバー */
.mk-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  margin-bottom: 6px;
}
.mk-toolbar-label { font-size: .8rem; color: var(--muted); margin-right: 2px; }
.mk-btn {
  font-size: .8rem;
  padding: 3px 11px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text);
  cursor: pointer;
  line-height: 1.5;
}
.mk-btn:hover { background: var(--accent-soft); }
.mk-btn.is-active {
  box-shadow: 0 0 0 2px var(--primary);
  font-weight: 700;
}
.mk-btn-positive { background: var(--positive-bg); color: var(--positive); border-color: transparent; }
.mk-btn-negative { background: var(--negative-bg); color: var(--negative); border-color: transparent; }
.mk-btn-info     { background: var(--info-bg);     color: var(--info);     border-color: transparent; }
.mk-btn-clear    { color: var(--muted); }

/* contenteditable エディタ（textareaと同じ見た目） */
.mk-editor {
  width: 100%;
  min-height: 60px;
  padding: 9px 11px;
  border: 1px solid var(--border);
  border-radius: 8px;
  font-size: .95rem;
  font-family: inherit;
  background: #fffdfa;
  color: var(--text);
  line-height: 1.6;
  white-space: pre-wrap;
  word-break: break-word;
  overflow-wrap: anywhere;
}
.mk-editor:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(63,59,53,.08);
}
.mk-editor:empty::before {
  content: attr(data-placeholder);
  color: var(--muted);
  opacity: .7;
}

/* インラインのハイライト（編集・閲覧・お知らせ共通） */
.mk-positive, .mk-negative, .mk-info {
  border-radius: 3px;
  padding: 0 .12em;
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
}
/* ハイライトは見やすいよう、UIの淡色より一段濃いめの色にする */
.mk-positive { background: #bcd49a; }
.mk-negative { background: #f0b0a4; }
.mk-info     { background: #f1d57e; }

/* 閲覧時の内容セル（改行・マーカーを保持） */
.content-view {
  white-space: pre-wrap;
  word-break: break-word;
  overflow-wrap: anywhere;
}

.tag {
  display: inline-block;
  font-size: .75rem;
  padding: 2px 8px;
  border-radius: 999px;
  background: var(--accent-soft);
  color: var(--text);
}
.tag.positive { background: var(--positive-bg); color: var(--positive); }
.tag.negative { background: var(--negative-bg); color: var(--negative); }
.tag.info     { background: var(--info-bg); color: var(--info); }

table.list { width: 100%; border-collapse: collapse; }
table.list th, table.list td {
  padding: 9px 10px;
  border-bottom: 1px solid var(--border);
  text-align: left;
  font-size: .9rem;
}
table.list th { color: var(--muted); font-weight: 600; }
.muted { color: var(--muted); }
.text-right { text-align: right; }

/* ---------- Comments ---------- */
.comment { border-top: 1px solid var(--border); padding: 12px 0; }
.comment .meta { font-size: .82rem; color: var(--muted); margin-bottom: 4px; }
.comment.reply { margin-left: 28px; border-top: 1px dashed var(--border); }
.comment-body { white-space: pre-wrap; }

/* ---------- Read status chips ---------- */
.read-toggle {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 12px;
}
.read-toggle-state { font-size: .85rem; }
.read-chips { display: flex; flex-wrap: wrap; gap: 6px; }
.chip {
  font-size: .78rem;
  padding: 2px 9px;
  border-radius: 999px;
  border: 1px solid var(--border);
}
.chip.read { background: var(--positive-bg); color: var(--positive); border-color: transparent; }
.chip.unread { background: var(--surface); color: var(--muted); }
.chip.retired { background: #ececec; color: #888; border-color: transparent; }

/* ---------- 退職者の表示（灰色で辞めたことが分かるように） ---------- */
.row-retired td { color: #999; background: #fafafa; }
.row-retired .chip.retired { color: #777; }
option.opt-retired { color: #999; }

/* ---------- Search results（内容をその場で展開表示） ---------- */
.search-report {
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 14px 16px;
  margin-top: 16px;
  background: var(--surface);
}
.search-report:first-of-type { margin-top: 8px; }
.search-report[data-read="0"] { border-left: 4px solid var(--info); }
.search-report-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 12px;
}
.search-report-title { margin: 0; font-size: 1.05rem; }
.search-report-date { font-size: .9rem; font-weight: 400; margin-left: 8px; }
.search-report-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.btn-comment-toggle {
  background: #fff;
  color: var(--text);
  border: 1px solid var(--border);
}
.btn-comment-toggle:hover,
.btn-comment-toggle:focus-visible {
  background: var(--accent-soft);
  color: var(--text);
  border-color: #d4cbb8;
}
.btn-comment-toggle[aria-expanded="true"] {
  background: var(--accent-soft);
  color: var(--text);
  border-color: var(--border);
}
.btn-comment-toggle[aria-expanded="true"]:hover,
.btn-comment-toggle[aria-expanded="true"]:focus-visible {
  background: #e3dccf;
  color: var(--text);
  border-color: #d4cbb8;
}
.btn-comment-toggle .comment-chev {
  display: inline-block;
  margin-left: 2px;
  font-size: .72em;
  line-height: 1;
  transition: transform 0.25s ease;
  transform: rotate(180deg); /* ▲を下向きに＝下に伸びる */
}
.btn-comment-toggle[aria-expanded="true"] .comment-chev {
  transform: rotate(0deg); /* 開いているときは▲＝閉じる */
}
.btn-comment-toggle.has-unread {
  background: var(--negative);
  color: #fff;
  border-color: var(--negative);
}
.btn-comment-toggle.has-unread:hover,
.btn-comment-toggle.has-unread:focus-visible {
  background: #8f4a44;
  border-color: #8f4a44;
  color: #fff;
}
.search-report-comments {
  overflow: hidden;
  max-height: 0;
  opacity: 0;
  transition: max-height 0.35s ease, opacity 0.25s ease, margin 0.25s ease, padding 0.25s ease;
}
.search-report-comments.is-open {
  max-height: 4000px;
  opacity: 1;
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--border);
}
.search-comments-inner .comment:first-child { border-top: none; padding-top: 0; }

/* ---------- Login ---------- */
.auth-wrap {
  max-width: 380px;
  margin: 8vh auto;
  padding: 0 16px;
}
.auth-wrap h1 { text-align: center; }

/* ---------- Responsive ---------- */
@media (max-width: 720px) {
  .nav-toggle { display: block; }
  .mainnav, .user-menu {
    display: none;
    width: 100%;
    flex-direction: column;
    align-items: stretch;
    margin-left: 0;
  }
  body.nav-open .mainnav,
  body.nav-open .user-menu {
    display: flex;
  }
  .topbar-inner { flex-wrap: wrap; }
  .calendar td { height: auto; min-height: 64px; padding: 3px; }
  .calendar .cell-event { display: none; }
  .calendar td.has-event:not(:focus-within) .cell-day::after {
    content: "•";
    color: var(--primary);
    margin-left: 3px;
  }
  .cell-note { min-height: 40px; font-size: .78rem; }
  .cell-note-view { font-size: .78rem; }
}

/* 編集画面の公開状態バナー（新規／下書き／公開中） */
.report-status {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  margin: 0 0 14px;
  padding: 10px 12px;
  border: 1px solid var(--border);
  border-left-width: 4px;
  border-radius: var(--radius);
  font-size: .85rem;
}
.report-status-icon { font-size: 1.05rem; line-height: 1.3; }
.report-status-text { display: flex; flex-direction: column; gap: 2px; }
.report-status-desc { color: var(--muted); font-size: .8rem; }
.report-status.is-new { background: var(--accent-soft); border-left-color: var(--muted); }
.report-status.is-new strong { color: var(--text); }
.report-status.is-draft { background: var(--info-bg); border-left-color: var(--info); }
.report-status.is-draft strong { color: var(--info); }
.report-status.is-published { background: var(--positive-bg); border-left-color: var(--positive); }
.report-status.is-published strong { color: var(--positive); }

/* ---------- 得意先分析 ---------- */
.ca-picker { position: relative; }
.ca-search { position: relative; max-width: 520px; }

/* 候補ドロップダウン */
.ca-suggest {
  position: absolute;
  z-index: 30;
  left: 0;
  right: 0;
  margin-top: 4px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: var(--shadow);
  max-height: 320px;
  overflow-y: auto;
}
.ca-suggest-item {
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
  padding: 9px 12px;
  background: none;
  border: none;
  border-bottom: 1px solid var(--border);
  font: inherit;
  color: var(--text);
  text-align: left;
  cursor: pointer;
}
.ca-suggest-item:last-child { border-bottom: none; }
.ca-suggest-item:hover { background: var(--accent-soft); }
.ca-suggest-name { flex: 1; word-break: break-all; }
.ca-suggest-count { color: var(--muted); font-size: .82rem; white-space: nowrap; }
.ca-tag-group {
  font-size: .7rem;
  padding: 1px 7px;
  border-radius: 999px;
  background: var(--info-bg);
  color: var(--info);
  white-space: nowrap;
}
/* チェックマーク */
.ca-check {
  flex: 0 0 18px;
  width: 18px;
  height: 18px;
  border: 1px solid var(--border);
  border-radius: 5px;
  background: #fffdfa;
  position: relative;
}
.ca-suggest-item.is-checked .ca-check {
  background: var(--primary);
  border-color: var(--primary);
}
.ca-suggest-item.is-checked .ca-check::after {
  content: "";
  position: absolute;
  left: 5px; top: 1px;
  width: 5px; height: 10px;
  border: solid #fff;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}
.ca-suggest-empty { padding: 10px 12px; color: var(--muted); font-size: .85rem; }

/* 選択中のチップ */
.ca-selected {
  margin-top: 14px;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #f7f3ec;
}
.ca-selected-label { font-size: .85rem; font-weight: 600; margin-bottom: 8px; }
.ca-chips { display: flex; flex-wrap: wrap; gap: 6px; }
.ca-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 4px 4px 12px;
  border-radius: 999px;
  background: var(--primary);
  color: #fff;
  font-size: .85rem;
}
.ca-chip-name { word-break: break-all; }
.ca-chip-x {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px; height: 20px;
  border: none;
  border-radius: 999px;
  background: rgba(255,255,255,.18);
  color: #fff;
  font-size: 1rem;
  line-height: 1;
  cursor: pointer;
}
.ca-chip-x:hover { background: rgba(255,255,255,.34); }
.ca-save-state { margin-top: 8px; font-size: .8rem; color: var(--muted); min-height: 1.2em; }

/* 結果ブロック */
.ca-result-block { margin-bottom: 22px; }
.ca-result-block:last-child { margin-bottom: 0; }
.ca-result-title {
  margin: 0 0 6px;
  font-size: 1.1rem;
  display: flex;
  align-items: baseline;
  gap: 10px;
  flex-wrap: wrap;
  border-bottom: 1px solid var(--border);
  padding-bottom: 6px;
}
.ca-result-sub { font-size: .85rem; font-weight: 400; color: var(--muted); }
.ca-note { margin: 0 0 10px; font-size: .82rem; }

.ca-user { margin-bottom: 14px; }
.ca-user-head {
  margin: 0 0 6px;
  font-size: 1rem;
  display: flex;
  align-items: center;
  gap: 8px;
}
.ca-count {
  font-size: .8rem;
  font-weight: 700;
  color: var(--primary);
  background: var(--accent-soft);
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 1px 10px;
}

/* 日付（クリックで明細を展開） */
.ca-date {
  border: 1px solid var(--border);
  border-radius: 8px;
  margin-bottom: 6px;
  background: #fffdfa;
}
.ca-date > summary {
  cursor: pointer;
  padding: 8px 12px;
  font-weight: 600;
  font-size: .92rem;
  list-style: none;
}
.ca-date > summary::-webkit-details-marker { display: none; }
.ca-date > summary::before {
  content: "▸";
  display: inline-block;
  margin-right: 8px;
  color: var(--muted);
  transition: transform .15s;
}
.ca-date[open] > summary::before { transform: rotate(90deg); }
.ca-date > summary:hover { background: var(--accent-soft); border-radius: 8px; }
/* 開いている間は見出しを濃いまま強調（どこで閉じるか分かるように） */
.ca-date[open] > summary {
  background: #e3dccf;
  border-bottom: 1px solid var(--border);
  border-radius: 8px 8px 0 0;
}
.ca-date[open] > summary:hover { background: #dcd3c2; }
.ca-date-body { padding: 4px 12px 12px; }

.ca-detail {
  border-top: 1px dashed var(--border);
  padding: 10px 0;
}
.ca-detail:first-child { border-top: none; }
.ca-detail-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 4px 16px;
  font-size: .88rem;
  margin-bottom: 4px;
}
.ca-kv { display: inline-flex; align-items: baseline; gap: 4px; }
.ca-k {
  font-size: .72rem;
  font-weight: 700;
  color: var(--muted);
  background: var(--accent-soft);
  border-radius: 4px;
  padding: 0 5px;
}
.ca-detail-content { font-size: .9rem; margin: 2px 0 4px; }
.ca-detail-link { font-size: .8rem; }

/* 商談の傾向（ポジ／ネガ） */
.ca-senti-bar {
  display: flex;
  height: 14px;
  border-radius: 999px;
  overflow: hidden;
  background: var(--accent-soft);
  margin: 4px 0 6px;
}
.ca-senti-fill { display: block; height: 100%; }
.ca-senti-fill.is-positive { background: #bcd49a; }
.ca-senti-fill.is-negative { background: #f0b0a4; }
.ca-senti-summary { margin: 0 0 10px; font-size: .9rem; }
.ca-senti-summary .muted { font-size: .82rem; margin-left: 6px; }
.ca-senti-group {
  border: 1px solid var(--border);
  border-radius: 8px;
  margin-bottom: 6px;
  background: #fffdfa;
}
.ca-senti-group > summary {
  cursor: pointer;
  padding: 8px 12px;
  font-size: .92rem;
  list-style: none;
  display: flex;
  align-items: center;
  gap: 8px;
}
.ca-senti-group > summary::-webkit-details-marker { display: none; }
.ca-senti-group > summary::before {
  content: "▸";
  color: var(--muted);
  transition: transform .15s;
}
.ca-senti-group[open] > summary::before { transform: rotate(90deg); }
.ca-senti-group > summary:hover { background: var(--accent-soft); border-radius: 8px; }
/* 開いている間は見出しを濃いまま強調（どこで閉じるか分かるように） */
.ca-senti-group[open] > summary {
  background: #e3dccf;
  border-bottom: 1px solid var(--border);
  border-radius: 8px 8px 0 0;
}
.ca-senti-group[open] > summary:hover { background: #dcd3c2; }
