﻿/* components.css — asobito UIコンポーネント定義（Layer 3）
   読み込み順: main.css → tokens.css → components.css → layout.css
   main.css より後に読み込まれるため、同一セレクタは components.css が優先される。
   変数定義（:root）は tokens.css の責務。このファイルはセレクタルールのみ。 */

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   Button
   定義原則: 1画面に btn-primary は最大1つ。空状態のCTAは必ず btn-primary。
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

.btn-primary,
.btn-secondary,
.btn-destructive,
.btn-ghost {
  display: inline-flex;
  align-items: center;
  gap: var(--_sp-4);
  border-radius: var(--rs);
  font-size: var(--_fs-13);
  font-weight: var(--_fw-500);
  font-family: inherit;
  cursor: pointer;
  transition: background 120ms ease;
  border: none;
  white-space: nowrap;
  text-decoration: none;
  box-shadow: none;
}

.btn-primary:disabled,
.btn-secondary:disabled,
.btn-destructive:disabled {
  opacity: .5;
  cursor: not-allowed;
}

/* ── btn-primary（オレンジ / 行動軸） */
.btn-primary {
  height: 32px;
  padding: 0 var(--_sp-16);
  background: var(--cta);
  color: #fff;
  border: none;
}
.btn-primary:hover { background: var(--cta-hover); }
.btn-primary:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px #fff, 0 0 0 4px var(--cta);
}

/* ── btn-secondary */
.btn-secondary {
  height: 32px;
  padding: 0 var(--_sp-12);
  background: var(--card-bg);
  color: var(--t2);
  border: 1px solid var(--bdr);
}
.btn-secondary:hover { background: var(--surf); color: var(--t1); }
.btn-secondary:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px #fff, 0 0 0 4px var(--blue);
}

/* ── acct-src-active（会計連携: 出所選択ボタンのアクティブ状態） */
.acct-src-active {
  border-color: var(--accent) !important;
  color: var(--accent) !important;
}

/* ── btn-destructive（削除・取消・無効化） */
.btn-destructive {
  height: 32px;
  padding: 0 var(--_sp-12);
  background: var(--card-bg);
  color: var(--danger);
  border: 1px solid rgba(220, 38, 38, 0.35);
}
.btn-destructive:hover { background: var(--danger-soft); }
.btn-destructive:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px #fff, 0 0 0 4px var(--danger);
}

/* ── btn-ghost */
.btn-ghost {
  height: 32px;
  padding: 0 var(--_sp-12);
  background: transparent;
  color: var(--t3);
  border: none;
}
.btn-ghost:hover { color: var(--t2); }

/* ── btn-xs（行アクション用極小ボタン） */
.btn-primary.btn-xs,
.btn-secondary.btn-xs,
.btn-destructive.btn-xs,
.btn-ghost.btn-xs,
.btn-danger.btn-xs {
  height: auto !important; padding: 4px 10px; font-size: 11px !important; border-radius: 4px; line-height: 1.4;
}

/* ── svc-customer-table 列幅定義 */
.svc-customer-table .col-next-action { min-width: 180px; }
.svc-customer-table .col-actions { width: 136px; min-width: 136px; }

/* ── svc-row-actions（顧客管理タブ アイコンアクション列） */
.svc-row-actions {
  display: grid;
  grid-template-columns: repeat(4, 28px);
  gap: 6px;
  justify-content: end;
  align-items: center;
  width: 136px;
}
.svc-icon-action {
  width: 28px;
  height: 28px;
  border-radius: 6px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--bdr);
  background: var(--card-bg);
  color: var(--t2);
  cursor: pointer;
  transition: background 120ms ease, color 120ms ease;
  padding: 0;
}
.svc-icon-action:hover:not(.is-disabled) { background: var(--surf); color: var(--t1); }
.svc-icon-action.is-primary { background: var(--cta); border-color: var(--cta); color: #fff; }
.svc-icon-action.is-primary:hover:not(.is-disabled) { background: var(--cta-hover); border-color: var(--cta-hover); }
.svc-icon-action.is-disabled { opacity: 0.35; cursor: not-allowed; pointer-events: none; }

/* ── btn-danger（btn-destructive 後方互換エイリアス） */
.btn-danger {
  height: 32px;
  padding: 0 var(--_sp-12);
  background: var(--card-bg);
  color: var(--danger);
  border: 1px solid rgba(220, 38, 38, 0.35);
  display: inline-flex;
  align-items: center;
  gap: var(--_sp-4);
  border-radius: var(--rs);
  font-size: var(--_fs-13);
  font-weight: var(--_fw-500);
  font-family: inherit;
  cursor: pointer;
  transition: background 120ms ease;
  white-space: nowrap;
  box-shadow: none;
}
.btn-danger:hover { background: var(--danger-soft); }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   KPI Card
   定義原則: ヒーロー値は22px/600。BIツール寄りの28px+は禁止。
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

.kpi-card {
  background: var(--card-bg);
  border: 1px solid var(--bdr);
  border-radius: var(--_r-6);
  padding: var(--_sp-16) 20px var(--_sp-12);
  position: relative;
  box-shadow: none;
  min-width: 0;
}

/* ── 指標ラベル（要素①） */
.kpi-label {
  font-size: var(--_fs-13);
  font-weight: var(--_fw-500);
  color: var(--t2);
  margin-bottom: var(--_sp-8);
  letter-spacing: .01em;
  text-transform: none;
}

/* ── ヒーロー値（要素②）— 22px 自然認知サイズ */
.kpi-value {
  font-size: var(--_fs-22);
  font-weight: var(--_fw-600);
  color: var(--t1);
  line-height: 1.2;
  letter-spacing: -.02em;
  font-variant-numeric: tabular-nums;
}

/* ── 単位（要素③） */
.kpi-unit {
  font-size: var(--_fs-13);
  font-weight: var(--_fw-400);
  color: var(--t3);
  margin-left: 2px;
}

/* ── 差分（要素④） */
.kpi-delta {
  display: inline-flex;
  align-items: center;
  gap: var(--_sp-4);
  margin-top: var(--_sp-8);
  font-size: var(--_fs-13);
  font-weight: var(--_fw-500);
  padding: 2px var(--_sp-8);
  border-radius: var(--_r-4);
}
.kpi-delta.pos { color: var(--success); background: var(--success-soft); }
.kpi-delta.neg { color: var(--danger);  background: var(--danger-soft); }
.kpi-delta.neu { color: var(--t2);      background: var(--surf); }

/* ── 空状態 */
.kpi-value:empty::before,
.kpi-value[data-empty]::before { content: "—"; color: var(--t4); }
.kpi-value[data-loading]::before {
  content: "—（読込中）";
  color: var(--t4);
  font-size: var(--_fs-14);
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   Table Row
   定義原則: ホバー・選択は青軸で統一。緑使用禁止。
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

.tbl {
  width: 100%;
  border-collapse: collapse;
  font-variant-numeric: tabular-nums;
}

.tbl th {
  background: var(--surf);        /* #F8FAFC */
  color: var(--sb-txt);           /* #94A3B8 */
  font-size: 10.5px;
  font-weight: 500;
  padding: 8px 16px;
  border-bottom: 0.5px solid #E2E8F0;
  white-space: nowrap;
  text-align: left;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.tbl td {
  background: var(--card-bg);
  color: var(--t1);
  font-size: 13px;
  font-weight: 400;
  padding: 11px 16px;
  min-height: 44px;
  border-bottom: 0.5px solid #F1F5F9;
  border-right: none;
  transition: background .08s;
  font-variant-numeric: tabular-nums;
  line-height: 1.5;
}

/* ── 先頭列: 強調 */
.tbl td:first-child { font-weight: 500; color: var(--ink, #0E1117); }

/* ── 状態: ホバー */
.tbl tbody tr:hover td,
.tbl tr:hover td { background: var(--surf) !important; }

/* ── 状態: 選択（青ボーダー） */
.tbl tbody tr.selected td { background: var(--blue-soft); }
.tbl tbody tr.selected td:first-child {
  border-left: 2px solid var(--blue);
  padding-left: calc(var(--_sp-16) - 2px);
}

/* ── 状態: 警告 */
.tbl tbody tr.row-warning td { background: #FEF9C3; }
.tbl tbody tr.row-warning .tbl-trigger { color: var(--danger); }

/* ── 状態: エラー */
.tbl tbody tr.row-error td { background: var(--danger-soft); }

/* ── 状態: 無効 */
.tbl tbody tr.row-disabled td { color: var(--t4); }
.tbl tbody tr.row-disabled:hover td { background: var(--card-bg); }

/* ── 数値列 */
.tbl .num,
.tbl td.num { text-align: right; font-variant-numeric: tabular-nums; }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   Page Header
   定義原則: タイトル（左）+ アクション（右）。btn-primary は最大1つ。
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

.page-hd {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--_sp-12);
  padding-bottom: 20px;
  margin-bottom: 28px;
  border-bottom: 1px solid var(--bdr);
}

.page-hd-left { flex: 1; min-width: 0; }

.page-hd-title {
  font-size: var(--fs-title);       /* 20px（tokens Layer 2） */
  font-weight: var(--fw-semibold);  /* 600 */
  color: var(--t-title) !important;
  letter-spacing: -.02em;
  line-height: 1.3;
  text-transform: none;
}

.page-hd-sub {
  font-size: var(--_fs-12);
  color: var(--t3);
  margin-top: 3px;
  font-weight: var(--_fw-400);
  line-height: 1.5;
}

.page-hd-actions,
.page-hd-right {
  display: flex;
  align-items: center;
  gap: var(--_sp-8);
  flex-shrink: 0;
  padding-top: 3px;
  position: relative;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   Scope Selector（経営視座セレクタ）
   M5-2 設計準拠。box-shadow禁止・btn-primary禁止。
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

.scope-context {
  font-size: 12px;
  color: var(--t3);
  margin-top: 2px;
}

.scope-selector-btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 6px 10px;
  font-size: 12px;
  background: var(--card-bg);
  border: 1px solid var(--bdr);
  border-radius: 4px;
  cursor: pointer;
  max-width: 240px;
  white-space: nowrap;
  overflow: hidden;
}
.scope-selector-btn:hover,
.scope-selector-btn[aria-expanded="true"] {
  background: var(--blue-soft);
  border-color: var(--blue);
}
.scope-selector-prefix { color: var(--t3); flex-shrink: 0; }
.scope-selector-name   { color: var(--t1); font-weight: 500; overflow: hidden; text-overflow: ellipsis; }
.scope-selector-caret  { color: var(--t3); font-size: 10px; flex-shrink: 0; }

.scope-dropdown {
  position: absolute;
  top: calc(100% + 4px);
  right: 0;
  width: 280px;
  max-height: 360px;
  overflow-y: auto;
  overflow-x: hidden;
  background: var(--card-bg);
  border: 1px solid var(--bdr);
  border-radius: 6px;
  z-index: 200;
  padding: 8px 0;
}
.scope-dropdown[hidden] { display: none; }
.scope-dropdown-header  { font-size: 11px; color: var(--t3); padding: 4px 12px 8px; }
.scope-biz-group-hd     { font-size: 11px; color: var(--t3); padding: 8px 12px 4px; }

.scope-option {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  font-size: 13px;
  color: var(--t1);
  cursor: pointer;
  outline: none;
}
.scope-option:hover,
.scope-option:focus           { background: var(--blue-soft); }
.scope-option[aria-selected="true"] {
  background: var(--blue-soft);
  font-weight: 500;
}
.scope-option--company        { font-size: 14px; }
.scope-option--biz            { padding-left: 16px; }
.scope-option--svc            { padding-left: 32px; }
.scope-option--empty {
  padding-left: 32px;
  font-size: 12px;
  color: var(--t4);
  cursor: default;
}
.scope-option--empty:hover    { background: none; }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   Tabs
   定義原則: アクティブは青軸（下線）。緑使用禁止。
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

.tabs {
  display: flex;
  border-bottom: 1px solid var(--bdr);
  gap: 0;
}

.tab-item {
  display: inline-flex;
  align-items: center;
  gap: var(--_sp-4);
  padding: var(--_sp-8) var(--_sp-16);
  font-size: var(--_fs-13);
  font-weight: var(--_fw-400);
  color: var(--t3);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  transition: color .12s;
  text-transform: none;
  user-select: none;
}

.tab-item:hover { color: var(--t2); }

.tab-item.active {
  color: var(--t1);
  font-weight: var(--_fw-600);
  border-bottom-color: var(--blue);
}

.tab-item .tab-count {
  font-size: var(--_fs-11);
  font-weight: var(--_fw-500);
  padding: 1px 5px;
  border-radius: var(--_r-pill);
  background: var(--surf);
  color: var(--t3);
}
.tab-item.active .tab-count {
  background: var(--blue-soft);
  color: var(--blue);
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   Badge / Status Chip
   定義原則: 緑=booked のみ。青=committed のみ。オレンジ禁止。
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

.badge {
  display: inline-flex;
  align-items: center;
  height: 20px;
  padding: 0 var(--_sp-8);
  border-radius: var(--_r-pill);
  font-size: var(--_fs-11);
  font-weight: var(--_fw-500);
  line-height: 1;
  white-space: nowrap;
  border: 1px solid transparent;
}

/* booked（緑）: 外部照合済み */
.badge-booked {
  background: var(--success-soft);
  color: var(--success);
  border-color: var(--success-border);
}

/* committed（青）: 意思決定済み */
.badge-committed {
  background: var(--blue-soft);
  color: var(--blue);
  border-color: var(--blue-border);
}

/* pending（中立） */
.badge-pending {
  background: var(--surf);
  color: var(--t3);
  border-color: var(--bdr);
}

/* forecast（警告） */
.badge-forecast {
  background: var(--warning-soft);
  color: var(--warning);
  border-color: var(--warning-border);
}

/* actual（青ライト） */
.badge-actual {
  background: var(--blue-soft);
  color: var(--blue);
  border-color: var(--blue-border);
}

/* danger（赤） */
.badge-danger {
  background: var(--danger-soft);
  color: var(--danger);
  border-color: var(--danger-border);
}

/* cancelled（打消線） */
.badge-cancelled {
  background: var(--surf);
  color: var(--t4);
  border-color: var(--bdr);
  text-decoration: line-through;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   Focus Ring（共通）
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: none;
  border-color: var(--blue);
  box-shadow: 0 0 0 2px var(--blue-soft);
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   崩壊防止ルール
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

/* shadow 禁止 */
.card, .kpi-card, .modal, .mbox { box-shadow: none !important; }

/* ── fiscal period selector ─────────────────────── */
.fiscal-period-row { display:flex; justify-content:flex-end; align-items:center; margin:8px 0 10px; }
.fps-wrap   { position:relative; display:inline-flex; align-items:center; gap:2px; }
.fps-arrow  {
  width:22px; height:22px; border-radius:50%;
  border:1px solid var(--bdr); background:rgba(255,255,255,0.65);
  color:var(--t3); display:inline-flex; align-items:center; justify-content:center;
  padding:0; font-size:10px; line-height:1; cursor:pointer;
}
.fps-arrow:hover:not(:disabled) { background:var(--surf); color:var(--t1); }
.fps-arrow:disabled { opacity:.3; cursor:not-allowed; }
.fps-label  {
  border:none; background:transparent;
  color:var(--t1); cursor:pointer; padding:2px 8px; font-size:12px; font-weight:500; white-space:nowrap;
}
.fps-label:hover { color:var(--accent); }
.fps-dropdown {
  position:absolute; top:calc(100% + 4px); right:0; z-index:200;
  background:var(--card-bg); border:1px solid var(--bdr); border-radius:4px;
  min-width:240px;
}
.fps-option {
  display:block; width:100%; text-align:left; background:none; border:none;
  padding:7px 12px; font-size:12px; color:var(--t2); cursor:pointer; white-space:nowrap;
}
.fps-option:hover     { background:var(--surf); }
.fps-option.is-active { color:var(--accent); font-weight:500; }

/* ── world-map period selector ──────────────────── */
.wm-period-sel {
  display: flex;
  align-items: center;
  gap: 8px;
}
.wm-period-sep {
  color: var(--t3);
  font-size: 12px;
}
.wm-period-base-lbl {
  color: var(--t3);
  font-size: 12px;
  white-space: nowrap;
}
.fps-select {
  font-size: 12px;
  color: var(--t1);
  background: var(--card-bg);
  border: 1px solid var(--bdr);
  border-radius: 4px;
  padding: 3px 6px;
  cursor: pointer;
}
.fps-select:focus { outline: none; border-color: var(--accent); }

/* 事業ナビ 区切り線・追加アクション */
.nav-biz-add-sep {
  height: 1px;
  background: var(--bdr);
  margin: 4px 8px;
}
.nav-biz-add-item {
  display: flex;
  align-items: center;
  height: 28px;
  padding: 4px 10px 4px 6px;
  font-size: 11px;
  color: var(--t4);
  cursor: pointer;
  border-radius: 4px;
  background: transparent;
  transition: background 0.1s;
  margin-top: 2px;
}
.nav-biz-add-item:hover {
  background: rgba(37, 99, 235, 0.06);
  color: var(--accent);
}

/* ── 事業追加ボタン専用: padding-left: 14px で .nav-biz-row text と完全一致 ── */
/* 14px = nav-biz-row の margin-left(4) + padding-left(10) */
.nav-biz-add-business {
  display: flex;
  align-items: center;
  height: 28px;
  padding: 4px 10px 4px 14px;
  margin: 2px 0 0;
  font-size: 11px;
  color: var(--t4);
  cursor: pointer;
  border-radius: 4px;
  background: transparent;
  transition: background 0.1s;
}
.nav-biz-add-business:hover {
  background: rgba(37, 99, 235, 0.06);
  color: var(--accent);
}

/* ── サービス追加ボタン専用: padding-left: 28px で .nav-biz-svc-item text と完全一致 ── */
/* 28px = svc-item padding-left(16) + ::before width(6) + ::before margin-right(6) */
/* nav-biz-children content(18px) + 28px = 46px from flyout = svc-item text position */
.nav-biz-add-service {
  display: flex;
  align-items: center;
  height: 28px;
  padding: 4px 10px 4px 28px;
  margin: 2px 0 0;
  font-size: 11px;
  color: var(--t4);
  cursor: pointer;
  border-radius: 4px;
  background: transparent;
  transition: background 0.1s;
}
.nav-biz-add-service:hover {
  background: rgba(37, 99, 235, 0.06);
  color: var(--accent);
}

/* ── 事業ナビ アコーディオン ── */
.nav-biz-accordion { }
.nav-biz-accordion + .nav-biz-accordion { margin-top: 2px; }

.nav-biz-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 6px 10px;
  margin: 0 4px;
  border-radius: 4px;
  cursor: pointer;
  font-size: 12px;
  color: var(--t2);
  transition: background 0.1s;
}
.nav-biz-row:hover { background: var(--accent-d); color: var(--accent); }
.nav-biz-row.active { background: var(--accent-d); color: var(--accent); }
.nav-biz-row.is-expanded-active { background: var(--accent-d); color: var(--accent); }
.nav-biz-label { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.nav-biz-children {
  overflow: hidden;
  border-left: 1px solid var(--bdr);
  margin-left: 12px;
  padding-left: 6px;
}
.nav-biz-row + .nav-biz-children { margin-top: 2px; }
.nav-biz-row.active + .nav-biz-children {
  border-left: 2px solid var(--accent);
}

.nav-biz-svc-item {
  display: flex;
  align-items: center;
  padding: 4px 10px 4px 16px;
  height: 28px;
  line-height: 20px;
  font-size: 11px;
  color: var(--t2);
  cursor: pointer;
  border-radius: 4px;
  transition: background 0.1s;
  background: transparent;
  box-sizing: border-box;
}
.nav-biz-svc-item::before {
  content: '';
  width: 6px;
  height: 6px;
  background: transparent;
  border-radius: 50%;
  display: inline-block;
  margin-right: 6px;
  flex-shrink: 0;
}
.nav-biz-svc-item:hover { background: rgba(37, 99, 235, 0.06); color: var(--accent); }
.nav-biz-row:hover ~ .nav-biz-children .nav-biz-svc-item:hover { background: rgba(37, 99, 235, 0.04); }
.nav-biz-svc-item.active { background: rgba(37, 99, 235, 0.10); color: var(--accent); }
.nav-biz-svc-item.active::before { background: var(--accent); }
.nav-biz-svc-item + .nav-biz-svc-item { margin-top: 2px; }

/* ── 予算編成 nav: 年度グループ（年度 → 版 階層） ── */
.nav-budget-year-group + .nav-budget-year-group { margin-top: 2px; }

.nav-budget-year-row {
  display: flex;
  align-items: center;
  cursor: pointer;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 500;
  padding: 4px 6px;
  color: var(--t3);
  transition: background 0.1s;
  user-select: none;
}
.nav-budget-year-row:hover { background: rgba(37,99,235,0.04); color: var(--accent); }
.nav-budget-year-row.active { color: var(--accent); }
.nav-budget-year-row.is-expanded-active { background: var(--accent-d); color: var(--accent); }

.nav-budget-year-children {
  overflow: hidden;
  border-left: 1px solid var(--bdr);
  margin-left: 8px;
  padding-left: 4px;
}
.nav-budget-year-children.is-collapsed {
  display: none;
}
.nav-budget-year-row.active + .nav-budget-year-children {
  border-left: 2px solid var(--accent);
}

/* ── 予算計画 nav 項目（状態バッジ付き） ── */
.nav-budget-plan-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.nav-biz-plan-label {
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.nav-budget-plan-status {
  font-size: 9px;
  padding: 1px 4px;
  border-radius: 3px;
  margin-left: 4px;
  flex-shrink: 0;
  color: var(--t3);
  background: var(--surf);
  border: 1px solid var(--bdr);
}
.nav-budget-plan-status.badge-status-active { color: var(--accent); border-color: rgba(37,99,235,0.3); background: rgba(37,99,235,0.06); }
.nav-budget-plan-status.badge-status-done   { color: #16a34a; border-color: rgba(22,163,74,0.3); background: rgba(22,163,74,0.06); }
.nav-budget-plan-status.badge-status-warn   { color: #d97706; border-color: rgba(217,119,6,0.3); background: rgba(217,119,6,0.06); }
.nav-budget-plan-status.badge-status-idle   { color: var(--t4); }

/* ── 経営メニュー 予算編成 accordion（.nav-biz-children と同一仕様・独立スコープ） ── */
.nav-mgmt-children {
  overflow: hidden;
  border-left: 1px solid var(--bdr);
  margin-left: 12px;
  padding-left: 6px;
}
.nav-biz-row + .nav-mgmt-children { margin-top: 2px; }
.nav-biz-row.active + .nav-mgmt-children {
  border-left: 2px solid var(--accent);
}

/* ── nav-chevron: 階層表現システム（唯一の正） ── */
.nav-chevron {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 14px;
  height: 14px;
  color: var(--t4);
  font-size: 14px;
  line-height: 1;
  transform-origin: 50% 50%;
  transition: transform 120ms ease, color 120ms ease, opacity 150ms ease;
  pointer-events: none;
  flex-shrink: 0;
  margin-left: auto;
}
/* flyout: 右方向 — 色変化のみ・回転しない */
.nav-chevron.is-flyout { /* no rotation */ }
/* inline: 下方向展開 — is-open 時に 90deg 回転 */
.nav-chevron.is-inline.is-open {
  transform: rotate(90deg) translateY(0.5px);
}

/* 親状態との色同期: nav-biz-row 系（経営accordion / 事業accordion） */
.nav-biz-row:hover    .nav-chevron { color: var(--accent); }
.nav-biz-row.active   .nav-chevron { color: var(--accent); }
.nav-biz-row.expanded .nav-chevron { color: var(--accent); }

/* 親状態との色同期: nav-budget-year-row 系（予算編成年度） */
.nav-budget-year-row:hover    .nav-chevron { color: var(--accent); }
.nav-budget-year-row.active   .nav-chevron { color: var(--accent); }
.nav-budget-year-row.expanded .nav-chevron { color: var(--accent); }

/* ── biz-svc ページ内タブバー ── */
.svc-tab-bar {
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--bdr);
  margin-bottom: 16px;
  overflow-x: auto;
  scrollbar-width: none;
}
.svc-tab-bar::-webkit-scrollbar { display: none; }

.svc-tab {
  padding: 8px 14px;
  font-size: 12px;
  color: var(--t2);
  border-bottom: 2px solid transparent;
  cursor: pointer;
  white-space: nowrap;
  transition: color 0.1s;
  flex-shrink: 0;
}
.svc-tab:hover { color: var(--t1); }
.svc-tab.active { color: var(--accent); border-bottom-color: var(--accent); font-weight: 500; }

/* ── biz-svc KPIカード ── */
.svc-kpi-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 16px;
}
.svc-kpi-card {
  background: var(--card-bg);
  border: 1px solid var(--bdr);
  border-radius: 6px;
  padding: 12px 16px;
  min-width: 120px;
}
.svc-kpi-label {
  font-size: 11px;
  color: var(--t3);
  margin-bottom: 4px;
}
.svc-kpi-value {
  font-size: 20px;
  font-weight: 600;
  color: var(--t1);
  font-variant-numeric: tabular-nums;
}
.svc-kpi-unit {
  font-size: 11px;
  color: var(--t3);
  margin-top: 2px;
}

/* biz-summary サービスカード */
.biz-svc-cards { display: flex; flex-direction: column; gap: 8px; }
.biz-svc-card {
  padding: 12px 16px;
  border: 1px solid var(--bdr);
  border-radius: 6px;
  cursor: pointer;
  background: var(--card-bg);
  transition: border-color 0.15s;
}
.biz-svc-card:hover { border-color: var(--accent); }
.biz-svc-card-hd {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 6px;
}
.biz-svc-card-name { font-size: 13px; font-weight: 500; color: var(--t1); }
.biz-svc-card-model { font-size: 11px; color: var(--t3); }
.biz-svc-card-kpi { font-size: 11px; color: var(--t2); margin-bottom: 8px; }
.biz-svc-card-cta { font-size: 11px; color: var(--accent); }

.name-edit-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  margin-left: 6px;
  border: none;
  background: transparent;
  color: var(--t4);
  cursor: pointer;
  border-radius: 4px;
  font-size: 11px;
  vertical-align: middle;
}
.name-edit-btn:hover {
  background: rgba(37, 99, 235, 0.06);
  color: var(--accent);
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   subscription サービス詳細ページ
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

/* ── MRR変化分解 ── */
.svc-mrr-breakdown {
  margin-top: 6px;
  font-size: 11px;
  color: var(--t2);
}
.svc-mrr-change {
  font-size: 12px;
  font-weight: 500;
  margin-bottom: 4px;
}
.svc-mrr-items {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 12px;
}
.svc-mrr-item { color: var(--t3); }
.svc-mrr-item strong { color: var(--t1); font-weight: 500; }

/* ── クイックアクション ── */
.svc-quick-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 12px;
}

/* ── ステータス / ジャーニー / ファネル バッジ ── */
.svc-badge {
  display: inline-block;
  font-size: 10px;
  padding: 1px 7px;
  border-radius: 3px;
  white-space: nowrap;
}

/* 顧客ステータス */
.svc-badge-active   { background: rgba(22,163,74,.12);  color: #15803D; }
.svc-badge-prospect { background: var(--blue-soft);     color: var(--blue); }
.svc-badge-churned  { background: var(--surf);          color: var(--t3); }

/* ジャーニーステージ */
.svc-badge-journey-onboarding        { background: var(--blue-soft);      color: var(--blue); }
.svc-badge-journey-active            { background: rgba(22,163,74,.12);   color: #15803D; }
.svc-badge-journey-adoption_risk     { background: rgba(217,119,6,.12);   color: #B45309; }
.svc-badge-journey-expansion_signal  { background: rgba(13,148,136,.12);  color: #0F766E; }
.svc-badge-journey-renewal_pending   { background: rgba(234,88,12,.12);   color: #C2410C; }
.svc-badge-journey-churn_risk        { background: var(--red-d);          color: var(--red); }
.svc-badge-journey-churned           { background: var(--surf);           color: var(--t3); }

/* ファネルステージ */
.svc-badge-funnel-contacted   { background: var(--surf);        color: var(--t2); }
.svc-badge-funnel-meeting     { background: var(--surf);        color: var(--t2); }
.svc-badge-funnel-interested  { background: var(--blue-soft);   color: var(--blue); }
.svc-badge-funnel-considering { background: var(--blue-soft);   color: var(--blue); }
.svc-badge-funnel-decision    { background: rgba(37,99,235,.18); color: #1D4ED8; }
.svc-badge-funnel-won         { background: rgba(22,163,74,.12); color: #15803D; }
.svc-badge-funnel-lost        { background: var(--red-d);        color: var(--red); }

/* ── reason_type ランキングバー ── */
.svc-reason-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
  font-size: 11px;
}
.svc-reason-label {
  width: 72px;
  flex-shrink: 0;
  color: var(--t2);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.svc-reason-bar {
  flex: 1;
  height: 6px;
  border-radius: 3px;
  background: var(--surf);
  overflow: hidden;
}
.svc-reason-bar > span {
  display: block;
  height: 100%;
  background: var(--accent);
  border-radius: 3px;
}
.svc-reason-bar-loss > span { background: var(--red); }
.svc-reason-count {
  width: 32px;
  flex-shrink: 0;
  text-align: right;
  color: var(--t3);
}

/* ── ファネルバーチャート ── */
.svc-funnel-chart {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.svc-funnel-row {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 11px;
}
.svc-funnel-label {
  width: 72px;
  flex-shrink: 0;
  color: var(--t2);
}
.svc-funnel-bar-wrap {
  flex: 1;
  height: 14px;
  border-radius: 3px;
  background: var(--surf);
  overflow: hidden;
}
.svc-funnel-bar {
  height: 100%;
  background: var(--accent);
  border-radius: 3px;
  min-width: 2px;
}
.svc-funnel-meta {
  display: flex;
  gap: 6px;
  align-items: center;
  min-width: 120px;
}
.svc-funnel-count { color: var(--t1); font-weight: 500; }
.svc-funnel-amount { color: var(--t3); }
.svc-funnel-conv {
  font-size: 10px;
  padding: 0 4px;
  border-radius: 3px;
  background: var(--blue-soft);
  color: var(--blue);
}
.svc-funnel-alert {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 12px;
  border-radius: var(--r);
  background: rgba(220,38,38,0.07);
  border: 1px solid rgba(220,38,38,0.2);
  color: var(--red);
  font-size: 11px;
  margin-bottom: 12px;
}
.svc-funnel-details {
  padding: 6px 8px 8px 80px;
  background: var(--surf);
  border-radius: 0 0 4px 4px;
  margin-top: -4px;
  margin-bottom: 4px;
}
.svc-funnel-priority-label {
  font-size: 10px;
  color: var(--t3);
  margin-bottom: 4px;
}
.svc-funnel-priority-item {
  font-size: 11px;
  color: var(--t2);
  padding: 2px 0;
  display: flex;
  gap: 8px;
}
.svc-funnel-rate {
  font-size: 10px;
  color: var(--t3);
  padding: 2px 8px;
  text-align: left;
}

/* ── ジャーニー スイムレーン ── */
.svc-swimlane {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding-bottom: 4px;
  scrollbar-width: thin;
}
.svc-swimlane-col {
  flex: 0 0 160px;
  min-width: 0;
  border: 1px solid var(--bdr);
  border-radius: 6px;
  background: var(--card-bg);
  overflow: hidden;
}
.svc-swimlane-hd {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 6px 10px;
  border-top: 3px solid var(--bdr);
  background: var(--surf);
  border-bottom: 1px solid var(--bdr);
}
.svc-swimlane-label { font-size: 11px; font-weight: 500; color: var(--t2); }
.svc-swimlane-count { font-size: 11px; font-weight: 600; }
.svc-swimlane-body { padding: 6px; display: flex; flex-direction: column; gap: 4px; min-height: 48px; }
.svc-swimlane-empty { font-size: 11px; color: var(--t4); padding: 4px 4px; }

/* ── ジャーニー顧客カード（スイムレーン内） ── */
.svc-journey-customer {
  padding: 6px 8px;
  border: 1px solid var(--bdr);
  border-radius: 4px;
  background: #fff;
  font-size: 11px;
}
.svc-journey-cname  { color: var(--t1); font-weight: 500; margin-bottom: 2px; }
.svc-journey-mrr    { color: var(--t2); }
.svc-journey-days   { color: var(--t3); font-size: 10px; }
.svc-journey-reason { color: var(--t3); font-size: 10px; }
.svc-journey-actions {
  display: flex;
  gap: 4px;
  margin-top: 4px;
}

/* ── pre-churnシグナルパネル ── */
.svc-signal-panel {
  margin-top: 16px;
  padding: 12px 14px;
  border: 1px solid rgba(220,38,38,.25);
  border-radius: 6px;
  background: rgba(220,38,38,.03);
}
.svc-signal-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 4px 0;
  font-size: 11px;
  border-bottom: 1px solid var(--bdr);
}
.svc-signal-row:last-child { border-bottom: none; }
.svc-signal-cname { flex: 1; color: var(--t1); font-weight: 500; }
.svc-signal-type  { color: var(--red); }
.svc-signal-days  { color: var(--t3); white-space: nowrap; }

/* ── 売上見込みサマリ ── */
.svc-forecast-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 16px;
}
.svc-forecast-band {
  flex: 1;
  min-width: 120px;
  padding: 10px 14px;
  border: 1px solid var(--bdr);
  border-radius: 6px;
  background: var(--card-bg);
}
.svc-forecast-band-total {
  border-color: var(--accent);
  background: var(--blue-soft);
}
.svc-forecast-band-label { font-size: 11px; color: var(--t3); margin-bottom: 4px; }
.svc-forecast-band-value { font-size: 16px; font-weight: 600; color: var(--t1); font-variant-numeric: tabular-nums; }
.svc-forecast-band-total .svc-forecast-band-value { color: var(--accent); }

/* ── プランカードグリッド ── */
.svc-plan-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 12px;
}
.svc-plan-card {
  padding: 14px 16px;
  border: 1px solid var(--bdr);
  border-radius: 6px;
  background: var(--card-bg);
}
.svc-plan-card-hd {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 6px;
  gap: 8px;
}
.svc-plan-name   { font-size: 13px; font-weight: 500; color: var(--t1); }
.svc-plan-amount { font-size: 15px; font-weight: 600; color: var(--t1); font-variant-numeric: tabular-nums; }
.svc-plan-cycle  { font-size: 11px; font-weight: 400; color: var(--t3); }
.svc-plan-meta   { font-size: 11px; color: var(--t3); margin-bottom: 6px; }
.svc-plan-features {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-bottom: 10px;
}
.svc-plan-tag {
  font-size: 10px;
  padding: 1px 6px;
  border-radius: 3px;
  background: var(--surf);
  color: var(--t2);
  border: 1px solid var(--bdr);
}
.svc-plan-actions {
  display: flex;
  gap: 6px;
  margin-top: 8px;
}

/* ── 意思決定パネル（サマリ・注目点） ── */
.svc-decision-panel {
  background: var(--surf);
  border: 1px solid var(--bdr);
  border-radius: 6px;
  padding: 12px 16px;
  margin-top: 16px;
}
.svc-decision-panel-title {
  font-size: 11px;
  font-weight: 500;
  color: var(--t2);
  margin-bottom: 8px;
}
.svc-decision-panel-item {
  font-size: 11px;
  color: var(--t3);
  line-height: 1.8;
}
.svc-decision-panel-item strong {
  color: var(--t1);
  font-weight: 500;
}


/* ─ ファネル 最優先アクションパネル ─ */
.svc-priority-action {
  border: 1px solid var(--bdr);
  border-left: 3px solid var(--accent);
  background: var(--card-bg);
  border-radius: var(--r);
  padding: 10px 14px;
  margin-bottom: 12px;
}
.svc-priority-action--funnel { border-left-color: #D97706; }
.svc-priority-action--deal   { border-left-color: var(--red); }
.svc-priority-action-title {
  font-size: 10px; font-weight: 500; color: var(--t3); margin-bottom: 4px;
}
.svc-priority-action-main { font-size: 12px; color: var(--t1); line-height: 1.5; }
.svc-priority-action-sub  { font-size: 11px; color: var(--t2); margin-top: 2px; }
.svc-priority-action-meta { font-size: 10px; color: var(--t3); margin-top: 4px; }

/* ─ ファネル 優先対応ランク ─ */
.svc-priority-rank        { font-size: 10px; font-weight: 600; min-width: 18px; color: var(--t3); }
.svc-priority-rank.rank-1 { color: var(--t2); }

/* ─ ファネル アクションラベル ─ */
.svc-action-label {
  font-size: 10px; color: var(--t2);
  background: rgba(220,38,38,0.07); border: 1px solid rgba(220,38,38,0.2);
  border-radius: 3px; padding: 1px 5px; white-space: nowrap;
}

/* ─ チャネル改善施策 ─ */
.svc-channel-action {
  font-size: 11px; color: var(--t2); padding: 5px 0 2px;
  border-top: 1px solid var(--bdr); margin-top: 6px;
  display: flex; gap: 6px; flex-wrap: wrap; align-items: center;
}
.svc-channel-action-label      { color: var(--t3); }
.svc-channel-action-problem    { color: var(--t2); }
.svc-channel-action-suggestion { color: var(--accent); }

/* ─ ファネル改善アクション（商談なし時） ─ */
.svc-funnel-improvements     { margin-top: 12px; text-align: left; display: inline-block; }
.svc-funnel-improvement-item { font-size: 11px; color: var(--t2); padding: 3px 0; display: flex; gap: 6px; }
.svc-improvement-issue       { color: var(--t2); }
.svc-improvement-action      { color: var(--accent); }

/* ─ ファネルバー meta 2行化 ─ */
.svc-funnel-meta-row1 { display: flex; gap: 8px; align-items: center; }
.svc-funnel-meta-row2 { display: flex; gap: 8px; align-items: center; margin-top: 2px; font-size: 10px; color: var(--t3); }

/* ══════════════════════════════════════
   コホートタブ（subscription型専用）
══════════════════════════════════════ */
.svc-cohort-wrap { display: flex; flex-direction: column; gap: 16px; padding: 12px 0; }

/* アクションカード */
.svc-cohort-action-card {
  border: 1px solid var(--bdr);
  border-left: 3px solid var(--red);
  background: var(--card-bg);
  padding: 12px 16px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.cohort-signal-label   { font-size: 11px; color: var(--t3); }
.cohort-signal-problem { font-size: 12px; color: var(--t1); margin: 0; }
.cohort-signal-cause   { font-size: 11px; color: var(--t2); margin: 0; }
.cohort-signal-next    { font-size: 11px; color: var(--accent); margin: 0; }

/* マトリクスブロック */
.svc-cohort-matrix-block { display: flex; flex-direction: column; gap: 8px; }

/* モード切替（2ボタン）*/
.svc-cohort-mode-toggle { display: flex; gap: 6px; }
.svc-cohort-mode-toggle button {
  font-size: 11px;
  padding: 3px 10px;
  border: 1px solid var(--bdr);
  background: var(--card-bg);
  color: var(--t2);
  cursor: pointer;
}
.svc-cohort-mode-toggle button.active { border-color: var(--accent); color: var(--accent); }

/* マトリクスセル */
.cohort-cell          { cursor: pointer; text-align: right; }
.cohort-cell:hover    { background: #EFF6FF !important; }
.cohort-cell.active   { border-left: 2px solid var(--accent); }
.cohort-cell-warn     { background: rgba(234,179,8,0.12); }
.cohort-cell-alert    { background: rgba(220,38,38,0.12); }
.cohort-cell-future   { background: var(--surf); color: var(--t4); cursor: default; }

/* リスクパネル（確定チャーンと物理分離）*/
.svc-cohort-risk-panel {
  background: var(--surf);
  border: 1px solid var(--bdr);
  padding: 10px 14px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.cohort-risk-header { font-size: 11px; color: var(--t2); display: flex; align-items: center; gap: 8px; }
.cohort-risk-note   { font-size: 10px; color: var(--t4); }

/* ドリル顧客一覧 */
.svc-cohort-detail        { border: 1px solid var(--bdr); background: var(--card-bg); padding: 12px 16px; }
.svc-cohort-detail.hidden { display: none; }


/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   購買申請カード（申請カード構造 v2）
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

/* モーダル幅: responsive */
#wf-form-box { max-width: min(1100px, calc(100vw - 48px)) !important; }

/* 予算バナー */
.pf-banner          { display:flex; justify-content:space-between; align-items:flex-start;
                      padding:12px 16px; background:var(--surf); border-bottom:1px solid var(--bdr); }
.pf-banner-left     { flex:1; min-width:0; }
.pf-hierarchy       { display:flex; align-items:center; gap:6px; flex-wrap:wrap; margin-bottom:4px; }
.pf-h-event         { font-size:13px; font-weight:600; color:var(--t1); }
.pf-h-line          { font-size:12px; color:var(--t2); }
.pf-h-request       { font-size:12px; color:var(--accent); font-weight:500; }
.pf-h-sep           { color:var(--t4); font-size:12px; }
.pf-banner-meta     { font-size:12px; color:var(--t3); }
.pf-banner-right    { display:flex; gap:16px; margin-left:16px; flex-shrink:0; }
.pf-kpi             { text-align:right; }
.pf-kpi-lbl         { font-size:11px; color:var(--t3); }
.pf-kpi-val         { font-size:15px; font-weight:600; color:var(--t1); }
.pf-budget-bar      { height:3px; background:var(--bdr); }
.pf-budget-fill     { height:100%; background:var(--accent); transition:width .3s; }
.pf-fill-warn       { background:#F59E0B; }
.pf-fill-over       { background:var(--red); }

/* cost_control_mode ボタン */
.pf-mode-btns       { display:flex; gap:8px; flex-wrap:wrap; margin-top:8px; }
.pf-mode-btn        { display:flex; flex-direction:column; align-items:flex-start;
                      padding:8px 14px; border:1px solid var(--bdr); border-radius:8px;
                      background:var(--card-bg); cursor:pointer; text-align:left; min-width:140px;
                      font-family:inherit; }
.pf-mode-icon       { font-size:16px; margin-bottom:2px; }
.pf-mode-title      { font-size:13px; font-weight:500; color:var(--t1); }
.pf-mode-hint       { font-size:11px; color:var(--t3); margin-top:2px; }
.pf-mode-btn.active { border-color:var(--accent); background:rgba(22,163,74,.06); }
.pf-mode-btn.active .pf-mode-title { color:var(--accent); }
.pf-mode-btn:hover:not(.active) { border-color:var(--t3); }

/* セクション共通 */
.pf-section         { padding:14px 20px; border-bottom:1px solid var(--bdr); }
.pf-section:last-child { border-bottom:none; }
.pf-sec-label       { font-size:11px; font-weight:600; color:var(--t3); text-transform:uppercase;
                      letter-spacing:.05em; margin-bottom:8px; }
.pf-req             { color:var(--red); font-size:10px; margin-left:4px; }
.pf-hint            { font-size:11px; color:var(--t3); margin-top:3px; }
.pf-field           { margin-bottom:10px; }
.pf-field:last-child { margin-bottom:0; }
.pf-field label     { font-size:13px; color:var(--t2); display:block; margin-bottom:4px; }

/* purpose チップ */
.pf-chips           { display:flex; gap:6px; flex-wrap:wrap; margin-top:4px; }
.pf-chip            { padding:4px 10px; border:1px solid var(--bdr); border-radius:14px;
                      background:var(--card-bg); font-size:12px; color:var(--t2); cursor:pointer;
                      font-family:inherit; transition:border-color 100ms; }
.pf-chip:hover      { border-color:var(--t3); }
.pf-chip.active     { border-color:var(--accent); background:rgba(22,163,74,.08); color:var(--accent); }
.pf-chips-primary .pf-chip.active { font-weight:600; }

/* 折りたたみ */
.pf-collapsible-hd  { background:none; border:none; padding:0; font-size:13px; color:var(--t2);
                      cursor:pointer; text-align:left; width:100%; font-family:inherit; }
.pf-collapsible-hd:hover { color:var(--t1); }

/* 摘要プレビュー */
.pf-desc-preview    { font-size:12px; color:var(--t3); margin-top:4px; font-style:italic; }

/* IDバッジ（補助情報） */
.pf-id-badge        { font-size:11px; color:var(--t4); margin-top:4px; }
.pf-id-badge code   { font-family:monospace; font-size:10px; background:var(--surf);
                      padding:1px 4px; border-radius:3px; color:var(--t3); }

/* ═══════════════════════════════════════════════════════════════
   購買申請カード v3 — 4カラム経営イベント入力カード
   1366x768 で縦スクロールなし・即入力UI
   ═══════════════════════════════════════════════════════════════ */

/* モーダル大判化（1366px環境でも横スクロールなし）
   #wf-form-box.pf-v2-modal を使うことで line 1159 の #wf-form-box ID ルールに勝つ */
#wf-form-box.pf-v2-modal,
.mbox.pf-v2-modal {
  width: calc(100vw - 48px) !important;
  max-width: 1680px !important;
  min-width: auto !important;
  height: min(88vh, 820px) !important;
  max-height: min(88vh, 820px) !important;
}

/* purchase時: wf-stepper-wrap に pf-meta-band + pf-stepper-area を描画するため表示維持 */
.pf-v2-modal #wf-stepper-wrap {
  display: block;
}

/* 丸ステッパー */
.pf-v3-stepper {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: 0 64px;
}
.pf-v3-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  min-width: 88px;
}
.pf-v3-step-dot {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 700;
}
.pf-v3-step.active .pf-v3-step-dot {
  background: #2563EB;
  color: #fff;
}
.pf-v3-step:not(.active) .pf-v3-step-dot {
  border: 2px solid #E5E7EB;
  color: #CBD5E1;
  background: #fff;
}
.pf-v3-step-label {
  font-size: 11px;
  color: var(--t3);
}
.pf-v3-step.active .pf-v3-step-label {
  color: #2563EB;
  font-weight: 600;
}
.pf-v3-step-line {
  flex: 1;
  height: 2px;
  background: #E5E7EB;
  max-width: 360px;
  margin: 0 16px;
  align-self: flex-start;
  margin-top: 14px;
}

/* ── ステッパー in グレー帯（mbox-hd）purchase モーダル用 ── */
.pf-hd-stepper {
  display: flex;
  align-items: center;
  gap: 0;
}
.pf-hd-step {
  display: flex;
  align-items: center;
  gap: 5px;
}
.pf-hd-dot {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: transparent;
  border: 2px solid #D1D5DB;
  color: #9CA3AF;
  font-size: 10px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  box-sizing: border-box;
}
.pf-hd-step.pf-hd-step-active .pf-hd-dot {
  background: #2563EB;
  border-color: #2563EB;
  color: #fff;
}
.pf-hd-lbl {
  font-size: 11px;
  color: var(--t3);
  font-weight: 400;
}
.pf-hd-step.pf-hd-step-active .pf-hd-lbl {
  color: #2563EB;
  font-weight: 500;
}
.pf-hd-line {
  width: 20px;
  height: 1px;
  background: #E5E7EB;
  margin: 0 4px;
}

/* 申請メタ情報帯（mbox-hd 直下・ステッパー上） */
.pf-meta-band {
  display: flex;
  align-items: center;
  gap: 28px;
  padding: 7px 24px;
  background: #fff;
  border-bottom: 1px solid var(--bdr);
  flex-shrink: 0;
}
.pf-meta-item { display: flex; align-items: center; gap: 5px; }
.pf-meta-lbl  { font-size: 11px; color: var(--t3); font-weight: 500; }
.pf-meta-val  { font-size: 12px; color: var(--t1); font-weight: 500; }

/* ステッパーエリア（meta-band 直下・pf-stepper-area） */
.pf-stepper-area {
  display: flex;
  align-items: center;
  gap: 0;
  padding: 8px 24px;
  background: var(--surf);
  border-bottom: 1px solid var(--bdr);
  flex-shrink: 0;
}
.pf-stepper-area .pf-hd-step { display: flex; align-items: center; gap: 5px; }
.pf-stepper-area .pf-hd-line { width: 20px; height: 1px; background: #E5E7EB; margin: 0 4px; }

/* 支払予定スケジュール — 3モードセレクター */
.pf-v3-pay-mode-row {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 8px;
}
.pf-v3-pay-mode-row select {
  flex: 1;
  font-size: 12px;
  padding: 5px 8px;
  border: 1px solid var(--bdr);
  border-radius: 6px;
  background: #fff;
  color: var(--t1);
}
.pf-v3-pay-header-fields {
  display: flex;
  gap: 8px;
  margin-top: 6px;
}
.pf-v3-pay-header-fields > div {
  flex: 1;
  min-width: 0;
}
.pf-v2-modal #wf-form-body {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  overflow-anchor: none;
}
.pf-v2-modal .pf-v3-grid   { flex-shrink: 0; }
.pf-v2-modal .pf-v3-lines  { position: relative; height: auto; }
.pf-v2-modal .pf-v3-bottom { position: relative; height: auto; }

/* イベント詳細コンテンツ未選択時の非表示 */
#pf-event-col-content:empty { display: none; }

/* 4カラムグリッド */
.pf-v3-grid {
  display: grid;
  grid-template-columns:
    minmax(240px, 1fr)
    minmax(240px, 1fr)
    minmax(280px, 1.1fr)
    minmax(380px, 1.3fr);
  gap: 0;
  border-bottom: 1px solid #EEF2F7;
}

/* カラム — padding圧縮で1366x768収束 */
.pf-v3-col {
  padding: 12px 16px;
  border-right: 1px solid #EEF2F7;
}
.pf-v3-col:last-child { border-right: none; }

/* カラムタイトル */
.pf-v3-col-hd  { display:flex; align-items:center; gap:6px; margin-bottom:10px; }
.pf-v3-col-num {
  width:20px; height:20px; border-radius:4px; background:#2563EB;
  color:#fff; font-size:11px; font-weight:700;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.pf-v3-col-title { font-size:15px; font-weight:700; color:var(--t1); line-height:1.2; }

/* フィールド共通 */
.pf-v3-field { margin-bottom:8px; }
.pf-v3-field:last-child { margin-bottom:0; }
.pf-v3-label { font-size:11px; font-weight:500; color:var(--t3); margin-bottom:3px; display:block; }
.pf-v3-req   { color:var(--red); margin-left:2px; }


/* ① 申請者 readonly 表示 */
.pf-v3-applicant {
  font-size:12px; color:var(--t2); padding:4px 0;
  display:flex; align-items:center; gap:4px;
}
.pf-v3-applicant-lbl { color:var(--t3); }

/* ② cost_control_mode カード */
.pf-v3-mode-cards    { display:flex; flex-direction:column; gap:6px; }
.pf-v3-mode-card {
  padding:8px 10px; border:1px solid var(--bdr); border-radius:6px;
  background:#fff; cursor:pointer; text-align:left; width:100%; font-family:inherit;
}
.pf-v3-mode-card-title { font-size:12px; font-weight:500; color:var(--t1); display:block; }
.pf-v3-mode-card-sub   { font-size:11px; color:var(--t3); display:block; margin-top:1px; line-height:1.35; }
.pf-v3-mode-card.active              { border:2px solid #2563EB; background:#F8FBFF; }
.pf-v3-mode-card.active .pf-v3-mode-card-title { color:#2563EB; }

/* ③ 主目的ドロップダウン */
.pf-v3-purpose-primary {
  width:100%; font-size:13px; padding:6px 8px;
  border:1px solid var(--bdr); border-radius:6px;
  background:#fff; color:var(--t1);
}

/* ③ 副目的タグ — 最大2行 */
.pf-v3-tags { display:flex; flex-wrap:wrap; gap:4px; margin-top:4px; max-height:48px; overflow:hidden; }
.pf-v3-tag {
  padding:2px 8px; border:1px solid var(--bdr); border-radius:10px;
  background:#fff; font-size:11px; color:var(--t2); cursor:pointer; font-family:inherit;
}
.pf-v3-tag.active { border-color:#2563EB; background:#EFF6FF; color:#2563EB; }

/* ③ 詳細理由 */
#wff_purpose_notes { min-height:96px !important; }

/* ④ 経営イベント列 — 白背景（入力不可に見えない） */
.pf-v3-event-col { background:#fff; }

/* 5KPI横一列 */
.pf-v3-kpi-row {
  display:grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap:5px; margin-top:8px;
}
.pf-v3-kpi-card {
  background:#F8FAFC; border:1px solid #EEF2F7; border-radius:6px;
  padding:5px 6px; text-align:center;
}
.pf-v3-kpi-card.kpi-clickable { cursor:pointer; }
.pf-v3-kpi-card.kpi-clickable:hover { border-color:#2563EB; background:#F0F7FF; }
.pf-v3-kpi-lbl {
  font-size:10px; color:var(--t3); margin-bottom:2px; display:block;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.pf-v3-kpi-val {
  font-size:12px; font-weight:600; color:var(--t1);
  font-variant-numeric:tabular-nums; white-space:nowrap;
  overflow:hidden; text-overflow:ellipsis;
}
.pf-v3-kpi-val.kv-this { color:#2563EB; }
.pf-v3-kpi-val.kv-over { color:var(--red); }

/* 採用済フライアウト */
.pf-committed-flyout {
  position:absolute; top:0; right:0;
  width:320px; background:#fff;
  border:1px solid var(--bdr); border-radius:8px;
  box-shadow:0 4px 16px rgba(0,0,0,0.12); z-index:100;
}
.pf-committed-flyout-hd {
  padding:10px 14px; border-bottom:1px solid var(--bdr);
  display:flex; align-items:center; justify-content:space-between;
  font-size:12px; font-weight:600; color:var(--t2);
}
.pf-committed-flyout-body { max-height:240px; overflow-y:auto; padding:8px 0; }
.pf-committed-row {
  padding:6px 14px; display:flex; align-items:center; gap:8px;
  font-size:12px; border-bottom:1px solid #F5F5F5;
}
.pf-committed-row:last-child { border-bottom:none; }
.pf-committed-no { color:var(--t3); white-space:nowrap; }
.pf-committed-title { flex:1; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.pf-committed-amt { color:#2563EB; font-weight:500; white-space:nowrap; font-variant-numeric:tabular-nums; }

/* イベント名・期間 */
.pf-v3-event-name { font-size:12px; font-weight:600; color:var(--t1); margin-bottom:2px; }
.pf-v3-event-meta { font-size:11px; color:var(--t3); font-variant-numeric:tabular-nums; }

/* 全editable input/select/textarea は白背景 */
.pf-v3-col input,
.pf-v3-col select,
.pf-v3-col textarea,
.pf-v3-items-table input,
.pf-v3-items-table select { background:#fff !important; }

/* readonly のみ薄グレー */
.pf-v3-items-table input[readonly] {
  background:#F7F9FC !important; color:var(--t3) !important; border:1px solid transparent;
}

/* 明細テーブルセクション — flex:1 で充填（pf-v2-modal内） */
.pf-v3-lines    { padding:8px 16px; border-bottom:1px solid #EEF2F7; }
.pf-v3-lines-hd { font-size:12px; font-weight:600; color:var(--t2); margin-bottom:6px;
                  display:flex; align-items:center; gap:6px; }

/* 明細テーブル — auto layout で支払列の追加/削除に対応 */
.pf-v3-items-table { width:100%; border-collapse:collapse; table-layout:auto; font-size:13px; }
/* 支払予定列: デフォルト非表示 / pf-show-pay クラスで表示 */
.pf-v3-items-table .pf-pay-col { display:none; }
.pf-v3-items-table.pf-show-pay .pf-pay-col { display:table-cell; }
.pf-v3-items-table th {
  background:var(--surf); font-size:11px; font-weight:500; color:var(--t3);
  padding:4px 5px; border-bottom:1px solid var(--bdr);
  text-align:left; white-space:nowrap; overflow:hidden;
}
.pf-v3-items-table td      { padding:3px 4px; border-bottom:1px solid var(--bdr); vertical-align:middle; }
.pf-v3-items-table tfoot td { padding:4px 5px; font-size:12px; font-weight:500; color:var(--t2); background:var(--surf); }

/* 明細テーブル列幅 — 情報価値ベース可変幅（内容・金額を強調、補助列を圧縮） */
.pf-v3-items-table .col-month   { width: 64px; }                    /* 固定縮小: 経営影響月 */
.pf-v3-items-table .col-desc    { width: 17%;  min-width: 100px; }  /* 拡大: 内容（主要列） */
.pf-v3-items-table .col-qty     { width: 44px; }
.pf-v3-items-table .col-unit    { width: 32px; }                    /* 縮小: 単位（補助） */
.pf-v3-items-table .col-price   { width: 6%;   min-width: 52px; }   /* 縮小: 単価 */
.pf-v3-items-table .col-amount  { width: 10%;  min-width: 72px; }   /* 拡大: 金額（主要列） */
.pf-v3-items-table .col-tax     { width: 6%;   min-width: 52px; }   /* 縮小: 税区分（補助） */
.pf-v3-items-table .col-acct    { width: 8%;   min-width: 64px; }   /* 縮小: 科目（補助） */
.pf-v3-items-table .col-gendesc { width: 21%;  min-width: 160px; }  /* 維持: 会計摘要 */
.pf-v3-items-table .col-del     { width: 28px; }

/* 会計摘要自動生成フィールド — システム生成を視覚的に区別
   .pf-v3-items-table input[readonly] の !important を詳細度で上書き */
.pf-v3-items-table input.pf-gen-desc-input[readonly] {
  background: #EFF6FF !important;
  color: var(--t2) !important;
  border: 1px solid transparent !important;
  border-left: 2px solid #BFDBFE !important;
  cursor: default;
}
.pf-v3-items-table input.pf-gen-desc-input[readonly]::placeholder { color: var(--t4); }

/* 行追加ボタン ○+ */
.pf-v3-add-row-btn {
  background:none; border:1px solid var(--bdr); border-radius:50%;
  width:22px; height:22px; font-size:13px; color:var(--t3); cursor:pointer;
  display:inline-flex; align-items:center; justify-content:center; line-height:1;
  font-family:inherit;
}
.pf-v3-add-row-btn:hover { border-color:var(--accent); color:var(--accent); }

/* 添付・備考 50:50 — 高さ圧縮 */
.pf-v3-bottom { display:grid; grid-template-columns:1fr 1fr; gap:0; border-bottom:1px solid #EEF2F7; }
.pf-v3-bottom-col              { padding:8px 16px; }
.pf-v3-bottom-col:first-child  { border-right:1px solid #EEF2F7; }
.pf-v3-drop-area {
  height:60px; border:1.5px dashed var(--bdr); border-radius:6px;
  display:flex; align-items:center; justify-content:center;
  font-size:12px; color:var(--t4); background:#FAFAFA;
}
.pf-v3-bottom-col textarea {
  height:60px; width:100%; font-size:13px; padding:5px 8px;
  border:1px solid var(--bdr); border-radius:6px;
  resize:none; color:var(--t1); background:#fff; font-family:inherit;
}

/* 非eventモード: opacity禁止 — layout維持+KPI非表示+select disabled */
.pf-v3-event-col.pf-mode-nonevent #pf-event-col-content { display:none; }
.pf-v3-event-col.pf-mode-nonevent #pf-v3-budget-row     { display:none; }
.pf-v3-event-col.pf-mode-nonevent select,
.pf-v3-event-col.pf-mode-nonevent #pf-v3-event-search-input { opacity:0.45; pointer-events:none; }

/* 施策・案件 検索型セレクター */
.pf-v3-event-search-wrap { position:relative; }
.pf-v3-event-search-dd {
  position:absolute; top:calc(100% + 2px); left:0; right:0; z-index:300;
  background:#fff; border:1px solid var(--bdr); border-radius:6px;
  box-shadow:0 4px 16px rgba(0,0,0,.1); max-height:260px; overflow-y:auto;
}
.pf-v3-event-dd-item {
  padding:7px 10px; cursor:pointer; border-bottom:1px solid #F3F4F6;
}
.pf-v3-event-dd-item:last-child { border-bottom:none; }
.pf-v3-event-dd-item:hover,.pf-v3-event-dd-item.selected { background:#EFF6FF; }
.pf-v3-event-dd-name { font-size:13px; font-weight:500; color:var(--t1); }
.pf-v3-event-dd-meta { font-size:11px; color:var(--t3); margin-top:2px; }
.pf-v3-event-dd-empty { padding:12px; font-size:13px; color:var(--t3); text-align:center; }

/* 単位 select + カスタム入力 */
.pf-v3-unit-wrap { display:flex; gap:3px; }
.pf-v3-unit-wrap select { min-width:0; font-size:11px; }
.pf-v3-unit-custom { width:48px; font-size:11px; }

/* unknown 理由テキストエリア */
.pf-v3-unknown-reason { margin-top:6px; }
.pf-v3-unknown-reason textarea {
  width:100%; font-size:12px; padding:5px 8px;
  border:1px solid var(--red); border-radius:6px; resize:none; height:52px;
}

/* ── 支払申請 (payment) 専用クラス ────────────────────────────── */

/* 口座情報エリア */
.py-bank-info { display:none; }
.py-bank-info.visible { display:block; }

/* 支払確認カード（Col4） */
.py-confirm-card {
  border:1px solid var(--bdr);
  border-radius:4px;
  padding:8px 12px;
  background:var(--card-bg);
  margin-top:8px;
}
.py-confirm-row {
  display:flex;
  justify-content:space-between;
  padding:3px 0;
  font-size:13px;
}
.py-confirm-val { font-variant-numeric:tabular-nums; }
.py-confirm-danger { color:var(--danger); }
.py-confirm-ok { color:var(--success); }

/* 差額ハイライト（明細行） */
.py-diff-warn td { background:#FFF7F7; }
.py-diff-warn-row td { background:#FFF7F7; }

/* 税抜金額表示列（支払明細） */
.py-col-excl-tax { width:80px; text-align:right; }
.py-excl-tax-disp { font-size:12px; color:var(--t3); font-variant-numeric:tabular-nums; }

/* 確認カードセクション区切り */
.py-confirm-section-hd {
  font-size:10px; font-weight:600; color:var(--t3);
  text-transform:uppercase; letter-spacing:.05em;
  padding:6px 0 2px; border-top:1px solid var(--bdr); margin-top:4px;
}
.py-confirm-section-hd:first-child { border-top:none; margin-top:0; }

/* 確認カード端数・許容差異 */
.py-confirm-warn { color:var(--cta); }

/* 請求書照合エラー */
.py-invoice-mismatch { border:1px solid var(--danger) !important; }
.py-invoice-mismatch-msg { color:var(--danger); font-size:12px; margin-top:4px; }

/* 支払情報セクション */
.py-payment-info-section {
  padding:12px 16px;
  border-top:1px solid var(--bdr);
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:12px 16px;
}

/* M2: PR候補検索ドロップダウン行 */
.pf-v3-search-item {
  display:flex; align-items:center; gap:8px; padding:6px 10px;
  cursor:pointer; border-bottom:1px solid var(--bdr); font-size:12px;
}
.pf-v3-search-item:last-child { border-bottom:none; }
.pf-v3-search-item:hover { background:var(--blue-soft); }
.py-pr-no    { font-size:12px; font-weight:600; color:var(--blue); min-width:80px; }
.py-pr-title { font-size:12px; color:var(--t1); flex:1; }
.py-pr-vendor{ font-size:11px; color:var(--t3); min-width:80px; }
.py-pr-amt   { font-size:11px; color:var(--t2); min-width:90px; text-align:right; }
.py-pr-status{ font-size:11px; color:var(--t3); min-width:60px; }
.py-pr-date  { font-size:11px; color:var(--t4); min-width:80px; text-align:right; }

/* M2: 差額列（明細テーブル）*/
.py-col-diff { width:90px; text-align:right; }
.py-diff-disp { font-size:12px; color:var(--t3); font-variant-numeric:tabular-nums; }
.py-diff-disp-warn { color:var(--cta); font-weight:600; }

/* M2: 証憑情報ステータスチップ */
.py-chip-row { display:flex; flex-wrap:wrap; gap:4px; margin-bottom:8px; }
.py-chip { font-size:11px; padding:2px 8px; border-radius:10px; font-weight:500; }
.py-chip-ok   { background:#DCFCE7; color:#166534; }
.py-chip-ng   { background:#FEE2E2; color:#991B1B; }
.py-chip-warn { background:#FEF3C7; color:#92400E; }
.py-chip-info { background:#EFF6FF; color:#1E40AF; }

/* M2: 承認状態カード */
.py-aprv-card { display:flex; flex-direction:column; gap:8px; }
.py-aprv-section { border:1px solid var(--bdr); border-radius:6px; padding:8px 12px; }
.py-aprv-section-hd {
  font-size:10px; font-weight:600; color:var(--t3);
  text-transform:uppercase; letter-spacing:.05em;
  padding-bottom:4px; border-bottom:1px solid var(--bdr); margin-bottom:6px;
}
.py-aprv-judge-row { display:flex; justify-content:space-between; align-items:center; padding:3px 0; }
.py-aprv-row { display:flex; justify-content:space-between; gap:8px; padding:2px 0; font-size:13px; }
.py-aprv-row-warn .py-aprv-val { color:var(--cta); }
.py-aprv-lbl { color:var(--t3); font-size:13px; }
.py-aprv-val { color:var(--t1); font-variant-numeric:tabular-nums; font-size:13px; }
.py-aprv-badge { font-size:11px; padding:2px 10px; border-radius:10px; font-weight:600; }
.py-aprv-badge-ok { background:#DCFCE7; color:#166534; }
.py-aprv-badge-ng { background:#FEE2E2; color:#991B1B; }

/* M2: 確認カード補助ラベル */
.py-confirm-lbl { color:var(--t3); font-size:13px; }
.py-confirm-val-text { color:var(--t1); font-variant-numeric:tabular-nums; font-size:13px; }

/* Final-1/2: accounting snapshot card ─────────────────────────── */
.pjf-snapshot-card {
  margin:12px 0;
  border:1px solid var(--bdr);
  border-radius:6px;
  background:var(--card-bg);
  overflow:hidden;
}
.pjf-snapshot-card.pjf-snapshot-ok   { border-left:3px solid var(--success); }
.pjf-snapshot-card.pjf-snapshot-warn { border-left:3px solid var(--cta); }
.pjf-snapshot-title {
  display:flex;align-items:center;gap:8px;
  padding:8px 12px;
  font-size:12px;font-weight:600;color:var(--t2);
  border-bottom:1px solid var(--bdr);
  background:var(--surf);
}
.pjf-snapshot-badge {
  font-size:11px;padding:2px 8px;border-radius:10px;font-weight:600;
}
.pjf-snapshot-ok   .pjf-snapshot-badge { background:#DCFCE7;color:#166534; }
.pjf-snapshot-warn .pjf-snapshot-badge { background:#FEF3C7;color:#92400E; }
.pjf-snapshot-meta {
  display:grid;grid-template-columns:auto 1fr;gap:2px 10px;
  padding:8px 12px;font-size:12px;
}
.pjf-snapshot-lbl { color:var(--t3);white-space:nowrap; }
.pjf-snapshot-footer {
  display:flex;align-items:center;justify-content:space-between;
  padding:6px 12px;border-top:1px solid var(--bdr);
  background:var(--surf);
}
.pjf-snapshot-hist       { font-size:11px;color:var(--t3); }
.pjf-snapshot-hist-none  { font-style:italic; }
.pjf-snapshot-hist-error { font-size:11px;color:var(--danger); }
/* ═══════════════════════════════════════════════════
   左メニュー改修 — Sidebar flex priority / Shortcut / Sidebar User
   2026-05-13 追加
   ═══════════════════════════════════════════════════ */

/* Sidebar flex: .sidebar-nav は flex:1 を持つため min-height:0 で圧縮可能にする */
.sidebar-nav { min-height: 0 !important; }

/* ─── Shortcut Section（.sidebar 直下 flex child）─── */
.nav-shortcut-section {
  flex-shrink: 0;
  max-height: min(30vh, 200px);
  overflow-y: auto;
  overflow-x: hidden;
}
.nav-shortcut-divider {
  height: 1px; background: var(--bdr); margin: 8px 12px 4px;
  opacity: 0; transition: opacity .15s;
}
.sidebar:hover:not(.desktop-collapsed) .nav-shortcut-divider { opacity: 1; }

.nav-shortcut-heading {
  max-width: 0; opacity: 0; overflow: hidden; white-space: nowrap;
  padding: 8px 12px 4px;
  font-size: 11px; font-weight: 500; color: var(--t3); letter-spacing: .04em;
  transition: max-width .18s ease, opacity .15s ease;
}
.sidebar:hover:not(.desktop-collapsed) .nav-shortcut-heading { max-width: 140px; opacity: 1; }

.nav-shortcut-icon { color: var(--t3); }
.nav-shortcut-label {
  max-width: 0; opacity: 0; overflow: hidden; white-space: nowrap;
  transition: max-width .18s ease, opacity .15s ease;
}
.sidebar:hover:not(.desktop-collapsed) .nav-shortcut-label { max-width: 120px; opacity: 1; }

.nav-shortcut-add { color: var(--t4); }
.nav-shortcut-add-label {
  max-width: 0; opacity: 0; overflow: hidden; white-space: nowrap;
  transition: max-width .18s ease, opacity .15s ease;
}
.sidebar:hover:not(.desktop-collapsed) .nav-shortcut-add-label { max-width: 140px; opacity: 1; }
.nav-shortcut-add:hover { color: var(--t3); background: var(--menu-hover-bg); }

/* ─── Shortcut Picker Popover ─── */
.shortcut-picker {
  position: fixed;
  background: var(--card-bg); border: 1px solid var(--bdr);
  border-radius: 6px; box-shadow: 4px 4px 16px rgba(0,0,0,.08);
  z-index: 310; padding: 4px;
  min-width: 200px; max-width: 280px; max-height: 320px; overflow-y: auto;
}
.shortcut-picker-hd {
  padding: 8px 12px 4px;
  font-size: 11px; font-weight: 500; color: var(--t3); letter-spacing: .04em;
}
.shortcut-picker-item {
  padding: 8px 12px; font-size: 13px; color: var(--t2);
  cursor: pointer; border-radius: 4px; transition: background .1s;
}
.shortcut-picker-item:hover { background: var(--menu-hover-bg); color: var(--menu-hover-text); }
.shortcut-picker-empty { padding: 12px; font-size: 12px; color: var(--t4); text-align: center; }

/* ─── Sidebar User Area（.sidebar 直下 flex child）─── */
.sidebar-user {
  flex-shrink: 0; border-top: 1px solid var(--bdr);
  padding: 6px 0; position: relative;
}
.sidebar-user-trigger {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 8px; margin: 0;
  cursor: pointer; border-radius: 6px; overflow: hidden;
  white-space: nowrap; transition: background .12s;
}
.sidebar-user-trigger:hover { background: var(--menu-hover-bg); }

.sidebar-user-avatar {
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--blue-soft); color: var(--blue);
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 600; flex-shrink: 0; user-select: none;
}
.sidebar-user-text {
  max-width: 0; opacity: 0; overflow: hidden; flex: 1; min-width: 0;
  display: flex; flex-direction: column; gap: 2px;
  transition: max-width .18s ease, opacity .15s ease;
}
.sidebar:hover:not(.desktop-collapsed) .sidebar-user-text { max-width: 120px; opacity: 1; }
.sidebar-user-company {
  font-size: 11px; font-weight: 500; color: var(--t2);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.sidebar-user-name {
  font-size: 11px; color: var(--t3);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.sidebar-user-chevron {
  max-width: 0; opacity: 0; overflow: hidden; flex-shrink: 0; color: var(--t3);
  transition: max-width .18s ease, opacity .15s ease;
}
.sidebar:hover:not(.desktop-collapsed) .sidebar-user-chevron { max-width: 16px; opacity: 1; }

.sidebar-user-menu {
  position: absolute; bottom: calc(100% + 4px); left: 6px; right: 6px;
  background: var(--card-bg); border: 1px solid var(--bdr); border-radius: 6px;
  box-shadow: 0 4px 12px rgba(0,0,0,.08); z-index: 310; padding: 4px; min-width: 160px;
}
.sidebar-user-menu-item {
  padding: 8px 12px; font-size: 13px; color: var(--t2);
  cursor: pointer; border-radius: 4px; transition: background .1s;
}
.sidebar-user-menu-item:hover { background: var(--menu-hover-bg); color: var(--menu-hover-text); }
.sidebar-user-menu-logout { color: var(--danger); }
.sidebar-user-menu-logout:hover { background: rgba(220,38,38,.06); color: var(--danger); }
.sidebar-user-menu-divider { height: 1px; background: var(--bdr); margin: 4px 8px; }

/* Final-2: CSV export button */
.btn-csv-export {
  font-size:12px;padding:4px 12px;
  background:var(--blue);color:#fff;
  border:none;border-radius:4px;cursor:pointer;
  font-weight:600;
}
.btn-csv-export:hover              { background:var(--blue-h); }
.btn-csv-export.btn-csv-warn       { background:var(--cta); }
.btn-csv-export.btn-csv-warn:hover { background:var(--cta-h); }
/* ── 選択カード（Org / WS 選択フロー） ─────────────────── */
.sel-card-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  max-width: 480px;
}
.sel-card {
  border: 1px solid var(--bdr);
  border-radius: var(--rs);
  background: var(--card-bg);
  padding: 14px 16px;
  cursor: pointer;
  transition: border-color .12s;
}
.sel-card:hover {
  border-color: var(--blue);
  background: var(--blue-soft);
}
.sel-card-name {
  font-size: 14px;
  font-weight: 500;
  color: var(--t1);
}
.sel-card-meta {
  font-size: 12px;
  color: var(--t3);
  margin-top: 2px;
}
