/* =============================================================================
 * notion.css — 経営管理アプリを Notion と「見た目・操作とも同一」にするための主スタイル
 *
 * 方針: Notion (light mode) の配色・余白・タイポ・サイドバーツリー・データベース
 *       ビュー（テーブル/ボード/ギャラリー/リスト）・ビュータブ・ツールバー（Filter/
 *       Sort/Search/New）・ページ（プロパティ＋本文＋インラインDB）・カラータグを忠実再現。
 * 絵文字は使わない。アイコンはモノクロの線画SVG（Notion既定のDBアイコン相当）。
 * 本ファイルは notion-theme.css の後に読み込み、シェルとDB系コンポーネントを上書き／追加する。
 * analytics（.card/.kpi/.chartbox 等）は notion-theme.css 側を継続利用。
 * ========================================================================== */

:root {
  /* Notion テキスト階調 */
  --nt-text:#37352f;
  --nt-text-2:#787774;     /* セカンダリ */
  --nt-text-3:#9b9a97;     /* プレースホルダ/説明 */
  --nt-line:#ecebea;       /* 罫線（薄） */
  --nt-line-2:#e3e2e0;     /* 罫線（やや濃） */
  --nt-bg:#ffffff;
  --nt-sidebar:#f7f7f5;
  --nt-hover:#f1f1ef;      /* 行/項目ホバー */
  --nt-hover-2:#e8e7e4;    /* 選択 */
  --nt-blue:#2383e2;
  --nt-radius:3px;
  /* Notion タグ配色（light mode 実測値）: bg / text */
  --tg-default-bg:#e3e2e0; --tg-default-fg:#37352f;
  --tg-gray-bg:#e3e2e0;    --tg-gray-fg:#787774;
  --tg-brown-bg:#eee0da;   --tg-brown-fg:#64473a;
  --tg-orange-bg:#fadec9;  --tg-orange-fg:#854c1d;
  --tg-yellow-bg:#fdecc8;  --tg-yellow-fg:#89632a;
  --tg-green-bg:#dbeddb;   --tg-green-fg:#2b593f;
  --tg-blue-bg:#d3e5ef;    --tg-blue-fg:#28456c;
  --tg-purple-bg:#e8deee;  --tg-purple-fg:#492f64;
  --tg-pink-bg:#f5e0e9;    --tg-pink-fg:#943d73;
  --tg-red-bg:#ffe2dd;     --tg-red-fg:#6e3630;
}

body {
  font-family:ui-sans-serif,-apple-system,BlinkMacSystemFont,"Segoe UI",Helvetica,"Hiragino Kaku Gothic ProN","Noto Sans JP",Arial,sans-serif;
  color:var(--nt-text);
  font-size:14px;
}

/* =============================================================================
 * アプリシェル: サイドバー + メイン
 * ========================================================================== */
#app.shown { display:flex; min-height:100vh; align-items:stretch; }

/* ---- 左サイドバー（Notionツリー） ---- */
.n-sidebar {
  width:248px; flex-shrink:0; background:var(--nt-sidebar);
  border-right:1px solid var(--nt-line-2);
  height:100vh; position:sticky; top:0; overflow-y:auto;
  padding:0; display:flex; flex-direction:column; gap:0;
  font-size:14px; color:var(--nt-text-2);
}
.n-sidebar::-webkit-scrollbar { width:8px; }
.n-sidebar::-webkit-scrollbar-thumb { background:#d3d1cb; border-radius:4px; }

/* ---- サイドバー 折りたたみ / 幅ドラッグ ---- */
.n-side-collapse { margin-left:auto; border:0; background:none; cursor:pointer; color:var(--nt-text-3); padding:3px; border-radius:5px; display:inline-flex; align-items:center; flex-shrink:0; }
.n-side-collapse:hover { background:var(--nt-line); color:var(--nt-text); }
.n-side-resizer { flex:0 0 5px; align-self:stretch; cursor:col-resize; position:relative; z-index:5; }
.n-side-resizer::after { content:''; position:absolute; left:1px; top:0; bottom:0; width:2px; background:transparent; transition:background .1s; }
.n-side-resizer:hover::after, .n-side-resizer.dragging::after { background:var(--nt-blue); }
.n-side-expand { position:fixed; left:8px; top:12px; z-index:60; width:30px; height:38px; border:1px solid var(--nt-line-2); background:#fff; border-radius:8px; display:none; align-items:center; justify-content:center; cursor:pointer; color:var(--nt-text-2); box-shadow:0 2px 8px rgba(0,0,0,.12); }
.n-side-expand:hover { color:var(--nt-text); border-color:var(--nt-text-3); }
#app.side-collapsed .n-sidebar { width:0 !important; min-width:0; border:0; overflow:hidden; }
#app.side-collapsed .n-side-resizer { display:none; }
#app.side-collapsed .n-side-expand { display:flex; }

/* ワークスペースヘッダ */
.n-ws {
  display:flex; align-items:center; gap:8px; padding:10px 12px 8px;
  font-weight:600; color:var(--nt-text); font-size:14px; cursor:default;
}
.n-ws .n-ws-logo {
  width:20px; height:20px; border-radius:4px; background:var(--nt-text); color:#fff;
  display:flex; align-items:center; justify-content:center; font-size:12px; font-weight:700; flex-shrink:0;
}
.n-ws .n-ws-name { flex:1; min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.n-ws .n-ws-cv { color:var(--nt-text-3); font-size:11px; }
/* arksdelta. ブランド（株式会社プラスワイズ版に準拠: weight800・tight・ドット#E87722） */
.brandmark { font-weight:800; letter-spacing:-.4px; }
.brand-dot { color:#E87722; font-weight:800; }
.n-ws .brandmark { font-size:16px; letter-spacing:-.4px; }
#gate h1.brandmark { font-size:26px; letter-spacing:-.5px; }
/* ダッシュボードのクイック起動カード（スライド作成） */
.ck-quicklaunch { margin:0 0 16px; }
.ck-launch-card { width:100%; display:flex; align-items:center; gap:14px; text-align:left;
  background:#fff; border:1px solid var(--n-line, #e6e9ee); border-radius:12px;
  padding:14px 18px; color:#1f1f1d; cursor:pointer; transition:.15s; font-family:inherit;
  box-shadow:0 1px 3px rgba(16,24,40,.06); }
.ck-launch-card:hover { background:#fff8f2; border-color:#E87722; box-shadow:0 4px 14px rgba(232,119,34,.14); }
.ck-launch-ic { width:40px; height:40px; flex-shrink:0; border-radius:10px; background:#E87722;
  display:flex; align-items:center; justify-content:center; }
.ck-launch-ic svg { width:22px; height:22px; color:#fff; }
.ck-launch-tx { flex:1; min-width:0; display:flex; flex-direction:column; gap:2px; }
.ck-launch-tx b { font-size:15px; font-weight:700; letter-spacing:-.2px; color:#1f1f1d; }
.ck-launch-tx span { font-size:12px; color:#6b7280; }
.ck-launch-go { font-size:13px; font-weight:700; color:#E87722; white-space:nowrap; }

/* サイドバー共通アクション（Search 等） */
.n-side-actions { padding:0 8px 6px; }
.n-side-item {
  display:flex; align-items:center; gap:8px; width:100%; text-align:left;
  border:0; background:none; cursor:pointer; color:var(--nt-text-2);
  padding:4px 8px; border-radius:var(--nt-radius); line-height:1.3; font-size:14px;
}
.n-side-item:hover { background:var(--nt-hover); }
.n-side-item .ic { width:18px; height:18px; flex-shrink:0; display:flex; align-items:center; justify-content:center; color:var(--nt-text-2); }
.n-side-item .ic svg { width:16px; height:16px; display:block; }

/* セクション見出し（PRIVATE / TEAMSPACES 風） */
.n-side-section {
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 14px 4px; font-size:11px; font-weight:600; letter-spacing:.03em;
  color:var(--nt-text-3); text-transform:none;
}
.n-tree { padding:0 8px; display:flex; flex-direction:column; gap:1px; }
.n-tree-item {
  display:flex; align-items:center; gap:7px; width:100%; text-align:left;
  border:0; background:none; cursor:pointer; color:var(--nt-text-2);
  padding:5px 8px; border-radius:var(--nt-radius); line-height:1.3; font-size:14px;
}
.n-tree-item:hover { background:var(--nt-hover); }
.n-tree-item.active { background:var(--nt-hover-2); color:var(--nt-text); font-weight:500; }
.n-tree-item .ic { width:18px; height:18px; flex-shrink:0; display:flex; align-items:center; justify-content:center; color:#91918e; }
.n-tree-item .ic svg { width:17px; height:17px; display:block; }
.n-tree-item.active .ic { color:var(--nt-text-2); }
.n-tree-item .lbl { flex:1; min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.n-tree-item .cnt { color:var(--nt-text-3); font-size:12px; font-variant-numeric:tabular-nums; }

.n-sidebar .n-spacer { flex:1 1 auto; }
.n-sidebar .n-foot {
  border-top:1px solid var(--nt-line-2); padding:8px 14px; font-size:12px; color:var(--nt-text-3);
}
.n-sidebar .n-foot .who { display:block; color:var(--nt-text-2); margin-bottom:2px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.n-sidebar .n-foot button { background:none; border:0; color:var(--nt-blue); cursor:pointer; font-size:12px; padding:0; }

/* ---- メイン ---- */
.n-main { flex:1; min-width:0; background:var(--nt-bg); display:flex; flex-direction:column; height:100vh; overflow:hidden; }

/* トップバー（パンくず） */
.n-topbar {
  height:45px; flex-shrink:0; display:flex; align-items:center; gap:4px;
  padding:0 16px; border-bottom:1px solid transparent; font-size:14px; color:var(--nt-text-2);
}
.n-crumb { display:flex; align-items:center; gap:6px; background:none; border:0; cursor:pointer; color:var(--nt-text-2); padding:3px 6px; border-radius:var(--nt-radius); font-size:14px; max-width:280px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.n-crumb:hover { background:var(--nt-hover); }
.n-crumb .ic { width:16px; height:16px; color:#91918e; display:inline-flex; }
.n-crumb .ic svg { width:15px; height:15px; }
.n-crumb-sep { color:var(--nt-text-3); padding:0 1px; }

/* スクロール領域 */
.n-scroll { flex:1; overflow-y:auto; }
/* スライド作成は全面表示（左右60px・下余白を除去してエディタを最大化） */
#analytics-wrap.slides-full { padding:0; }
#analytics-wrap.slides-full #panel-slides { margin:0; }
#analytics-wrap.slides-full #slides-mount { width:100%; height:calc(100vh - 45px); border-radius:0; }

/* DBページ/分析ページ共通の本文幅。Notion既定は最大 ~900px・上左右パディング。 */
.n-page-wrap { max-width:976px; margin:0 auto; padding:0 96px; }
.n-page-wrap.full { max-width:none; padding:0 60px; }

/* =============================================================================
 * データベースページ ヘッダ
 * ========================================================================== */
.n-db-head { padding:48px 0 2px; }
.n-db-title { display:flex; align-items:center; gap:10px; font-size:30px; font-weight:700; letter-spacing:-.4px; color:var(--nt-text); margin:0; }
.n-db-title .ic { width:34px; height:34px; display:flex; align-items:center; justify-content:center; color:#91918e; }
.n-db-title .ic svg { width:30px; height:30px; }
.n-db-desc { color:var(--nt-text-3); font-size:14px; margin:8px 0 0; line-height:1.5; }

/* ビュータブ */
.n-viewbar { display:flex; align-items:center; gap:2px; border-bottom:1px solid var(--nt-line-2); margin-top:10px; }
.n-viewtab {
  display:flex; align-items:center; gap:6px; background:none; border:0; cursor:pointer;
  color:var(--nt-text-2); font-size:14px; padding:8px 8px; margin-bottom:-1px;
  border-bottom:2px solid transparent; line-height:1.2;
}
.n-viewtab .ic { width:16px; height:16px; color:#91918e; display:inline-flex; }
.n-viewtab .ic svg { width:15px; height:15px; }
.n-viewtab:hover { color:var(--nt-text); }
.n-viewtab.active { color:var(--nt-text); border-bottom-color:var(--nt-text); font-weight:500; }
.n-viewtab.add { color:var(--nt-text-3); }

/* ツールバー（検索/フィルタ/ソート/New） */
.n-toolbar { display:flex; align-items:center; gap:2px; padding:8px 0 6px; min-height:42px; }
.n-toolbar .sp { flex:1; }
.n-tb-btn {
  display:flex; align-items:center; gap:5px; background:none; border:0; cursor:pointer;
  color:var(--nt-text-2); font-size:13px; padding:5px 8px; border-radius:var(--nt-radius); line-height:1.2;
}
.n-tb-btn:hover { background:var(--nt-hover); }
.n-tb-btn.on { color:var(--nt-blue); }
/* リスト/ボード レイアウト切替（セグメント） */
.n-lt-group { display:inline-flex; border:1px solid var(--nt-line); border-radius:7px; overflow:hidden; }
.n-lt { display:inline-flex; align-items:center; justify-content:center; border:0; background:#fff; color:var(--nt-text-3); cursor:pointer; padding:5px 9px; }
.n-lt + .n-lt { border-left:1px solid var(--nt-line); }
.n-lt svg { width:15px; height:15px; }
.n-lt:hover { background:#f7f7f5; color:var(--nt-text-2); }
.n-lt.on { background:#f0f0ee; color:var(--nt-text); }
.n-tb-btn .ic { width:15px; height:15px; display:inline-flex; }
.n-tb-btn .ic svg { width:14px; height:14px; }
.n-tb-search { display:flex; align-items:center; gap:6px; }
.n-tb-search input {
  border:0; background:none; outline:none; font-size:13px; color:var(--nt-text);
  width:0; opacity:0; transition:width .15s, opacity .15s; padding:0;
}
.n-tb-search.open input { width:180px; opacity:1; border-bottom:1px solid var(--nt-line-2); padding:2px 0; }
.n-new-btn {
  display:flex; align-items:center; gap:5px; background:var(--nt-blue); color:#fff; border:0; cursor:pointer;
  font-size:13px; padding:5px 10px; border-radius:var(--nt-radius); font-weight:500; line-height:1.4;
}
.n-new-btn:hover { background:#1a6fc0; }
.n-new-btn .ic svg { width:14px; height:14px; }
/* New 分割ボタンの右キャレット */
.n-new-caret { background:var(--nt-blue); color:#fff; border:0; border-left:1px solid rgba(255,255,255,.25); cursor:pointer; padding:5px 6px; border-radius:0 var(--nt-radius) var(--nt-radius) 0; }
.n-new-btn.split { border-radius:var(--nt-radius) 0 0 var(--nt-radius); }

/* フィルタ/ソートのチップ行 */
.n-chips { display:flex; flex-wrap:wrap; gap:6px; padding:0 0 8px; }
.n-chip {
  display:inline-flex; align-items:center; gap:6px; background:#f1f0ee; border:1px solid var(--nt-line-2);
  border-radius:var(--nt-radius); font-size:12px; color:var(--nt-text-2); padding:3px 6px 3px 9px;
}
.n-chip select, .n-chip input { border:0; background:none; font-size:12px; color:var(--nt-text); outline:none; }
.n-chip .x { cursor:pointer; color:var(--nt-text-3); border:0; background:none; padding:0 2px; font-size:13px; }
.n-chip .x:hover { color:var(--nt-text); }

/* =============================================================================
 * テーブルビュー（Notion table）
 * ========================================================================== */
.n-tablewrap { overflow-x:auto; border-top:1px solid var(--nt-line-2); }
table.n-table { width:100%; border-collapse:collapse; font-size:14px; }
table.n-table th, table.n-table td {
  text-align:left; padding:0; border-bottom:1px solid var(--nt-line); border-right:1px solid var(--nt-line);
  vertical-align:top;
}
table.n-table th:first-child, table.n-table td:first-child { border-left:1px solid var(--nt-line); }
table.n-table thead th {
  font-size:13px; color:var(--nt-text-2); font-weight:400; background:#fff;
  padding:7px 8px; white-space:nowrap; cursor:pointer; user-select:none; position:sticky; top:0; z-index:2;
}
table.n-table thead th .th-in { display:flex; align-items:center; gap:6px; }
table.n-table thead th .ic { width:15px; height:15px; color:#9b9a97; display:inline-flex; flex-shrink:0; }
table.n-table thead th .ic svg { width:14px; height:14px; }
table.n-table thead th.num .th-in { justify-content:flex-end; }
table.n-table tbody td { padding:6px 8px; color:var(--nt-text); height:34px; }
table.n-table tbody td.num { text-align:right; font-variant-numeric:tabular-nums; }
table.n-table tbody tr:hover { background:#f8f8f7; }
table.n-table tbody tr.n-grouphdr { background:#f7f7f5; }
table.n-table tbody tr.n-grouphdr:hover { background:#f7f7f5; }
table.n-table tbody tr.n-grouphdr td { padding:8px; height:auto; border-left:1px solid var(--nt-line); }
table.n-table tbody tr.n-grouphdr td .n-grouphdr-cnt { margin-left:8px; color:var(--nt-text-3); font-size:12px; font-variant-numeric:tabular-nums; }
table.n-table tbody tr:hover .n-open-btn { opacity:1; }
table.n-table td.cell-title { font-weight:400; }
.n-titlecell { display:flex; align-items:center; gap:6px; min-width:0; }
.n-titlecell .t { overflow:hidden; text-overflow:ellipsis; white-space:nowrap; cursor:pointer; }
.n-titlecell .t:hover { text-decoration:underline; }
.n-open-btn {
  opacity:0; transition:opacity .1s; margin-left:auto; flex-shrink:0;
  display:inline-flex; align-items:center; gap:3px; font-size:11px; color:var(--nt-text-2);
  border:1px solid var(--nt-line-2); border-radius:var(--nt-radius); background:#fff; cursor:pointer; padding:1px 6px;
}
.n-open-btn:hover { background:var(--nt-hover); }
.n-table-foot { display:flex; align-items:center; gap:8px; padding:6px 8px; border-bottom:1px solid var(--nt-line); }
.n-newrow { display:flex; align-items:center; gap:7px; color:var(--nt-text-3); font-size:14px; padding:7px 8px; cursor:pointer; border-bottom:1px solid var(--nt-line); }
.n-newrow:hover { background:#f8f8f7; color:var(--nt-text-2); }
.n-newrow .ic svg { width:15px; height:15px; }
.n-count-foot { color:var(--nt-text-3); font-size:12px; padding:8px 2px; }

/* =============================================================================
 * カラータグ / Status ピル
 * ========================================================================== */
.n-tag {
  display:inline-flex; align-items:center; gap:5px; padding:2px 8px; border-radius:var(--nt-radius);
  font-size:13px; line-height:18px; max-width:100%; white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.n-tag.status::before { content:""; width:7px; height:7px; border-radius:50%; background:currentColor; opacity:.85; flex-shrink:0; }
.n-tag.c-default{ background:var(--tg-default-bg); color:var(--tg-default-fg); }
.n-tag.c-gray   { background:var(--tg-gray-bg);    color:var(--tg-gray-fg); }
.n-tag.c-brown  { background:var(--tg-brown-bg);   color:var(--tg-brown-fg); }
.n-tag.c-orange { background:var(--tg-orange-bg);  color:var(--tg-orange-fg); }
.n-tag.c-yellow { background:var(--tg-yellow-bg);  color:var(--tg-yellow-fg); }
.n-tag.c-green  { background:var(--tg-green-bg);   color:var(--tg-green-fg); }
.n-tag.c-blue   { background:var(--tg-blue-bg);    color:var(--tg-blue-fg); }
.n-tag.c-purple { background:var(--tg-purple-bg);  color:var(--tg-purple-fg); }
.n-tag.c-pink   { background:var(--tg-pink-bg);    color:var(--tg-pink-fg); }
.n-tag.c-red    { background:var(--tg-red-bg);     color:var(--tg-red-fg); }
.n-tags { display:flex; flex-wrap:wrap; gap:4px; }
/* status のドット色はテキスト色に従わせず明示（より正確に） */
.n-tag.status.c-default::before{ background:#9b9a97; }
.n-tag.status.c-gray::before{ background:#9b9a97; }
.n-tag.status.c-brown::before{ background:#a27763; }
.n-tag.status.c-orange::before{ background:#cb7b37; }
.n-tag.status.c-yellow::before{ background:#c29343; }
.n-tag.status.c-green::before{ background:#4f9768; }
.n-tag.status.c-blue::before{ background:#529cca; }
.n-tag.status.c-purple::before{ background:#9a6dd7; }
.n-tag.status.c-pink::before{ background:#e255a1; }
.n-tag.status.c-red::before{ background:#ff7369; }

/* リレーション/ページ参照リンク（Notion下線リンク） */
.n-ref { color:var(--nt-text); text-decoration:none; border-bottom:1px solid rgba(55,53,47,.25); cursor:pointer; }
.n-ref:hover { border-bottom-color:rgba(55,53,47,.55); }
.n-person { display:inline-flex; align-items:center; gap:5px; }
.n-avatar { width:18px; height:18px; border-radius:50%; background:#dfddd9; color:#5a5852; display:inline-flex; align-items:center; justify-content:center; font-size:10px; font-weight:600; }
.n-date { color:var(--nt-text); }
.n-num { font-variant-numeric:tabular-nums; }
.n-empty { color:var(--nt-text-3); }

/* =============================================================================
 * ボードビュー（Notion board）
 * ========================================================================== */
.n-board { display:flex; gap:10px; overflow-x:auto; padding:8px 0 20px; align-items:flex-start; }
.n-bcol { width:260px; flex-shrink:0; }
.n-bcol-head { display:flex; align-items:center; gap:6px; padding:4px 4px 8px; position:sticky; top:0; }
.n-bcol-head .cnt { color:var(--nt-text-3); font-size:13px; }
.n-bcol-head .add { margin-left:auto; color:var(--nt-text-3); cursor:pointer; background:none; border:0; }
.n-bcol-head .add svg { width:15px; height:15px; }
.n-bcards { display:flex; flex-direction:column; gap:8px; min-height:8px; }
.n-bcard {
  background:#fff; border:1px solid var(--nt-line-2); border-radius:5px; padding:8px 10px;
  box-shadow:0 1px 2px rgba(15,15,15,.05); cursor:pointer;
}
.n-bcard:hover { background:#fafafa; }
.n-bcard .t { font-size:14px; color:var(--nt-text); margin-bottom:6px; line-height:1.35; }
.n-bcard .props { display:flex; flex-direction:column; gap:5px; }
.n-bcard .props .row { display:flex; align-items:center; gap:6px; flex-wrap:wrap; }
.n-bcard .props .mini { font-size:12px; color:var(--nt-text-2); }
.n-bcol-newcard { display:flex; align-items:center; gap:6px; color:var(--nt-text-3); font-size:13px; padding:7px 6px; cursor:pointer; border-radius:var(--nt-radius); }
.n-bcol-newcard:hover { background:var(--nt-hover); color:var(--nt-text-2); }
.n-bcol-newcard svg { width:14px; height:14px; }
.n-bcard[draggable="true"] { cursor:grab; }
.n-bcard.dragging { opacity:.45; }
.n-bcol.dragover .n-bcards { outline:2px dashed var(--nt-blue); outline-offset:2px; border-radius:6px; background:rgba(35,131,226,.04); min-height:40px; }

/* =============================================================================
 * ギャラリービュー（Notion gallery）
 * ========================================================================== */
.n-gallery { display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:12px; padding:10px 0 20px; }
.n-gcard { border:1px solid var(--nt-line-2); border-radius:6px; overflow:hidden; cursor:pointer; background:#fff; box-shadow:0 1px 2px rgba(15,15,15,.04); }
.n-gcard:hover { background:#fafafa; }
.n-gcard .cover { height:120px; background:#f1f0ee; display:flex; align-items:center; justify-content:center; }
.n-gcard .cover .avatarbig { width:56px; height:56px; border-radius:12px; background:#e7eef6; color:#2f6db3; display:flex; align-items:center; justify-content:center; font-weight:700; font-size:22px; }
.n-gcard .body { padding:10px 12px; }
.n-gcard .body .t { font-size:14px; font-weight:500; color:var(--nt-text); margin-bottom:8px; line-height:1.3; }
.n-gcard .body .props { display:flex; flex-direction:column; gap:6px; }

/* =============================================================================
 * リストビュー（Notion list）
 * ========================================================================== */
.n-list { padding:6px 0 20px; }
.n-litem { display:flex; align-items:center; gap:10px; padding:7px 6px; border-bottom:1px solid var(--nt-line); cursor:pointer; }
.n-litem:hover { background:#f8f8f7; }
.n-litem .t { flex:1; min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; color:var(--nt-text); }
.n-litem .meta { display:flex; align-items:center; gap:8px; flex-shrink:0; }

/* =============================================================================
 * カレンダービュー
 * ========================================================================== */
.n-cal-bar { display:flex; align-items:center; gap:8px; padding:8px 0 12px; }
.n-cal-nav { background:none; border:1px solid var(--nt-line-2); border-radius:var(--nt-radius); cursor:pointer; color:var(--nt-text-2); width:26px; height:26px; display:inline-flex; align-items:center; justify-content:center; }
.n-cal-nav:hover { background:var(--nt-hover); } .n-cal-nav svg { width:15px; height:15px; }
.n-cal-label { font-size:15px; font-weight:600; color:var(--nt-text); min-width:96px; text-align:center; }
.n-cal-today { background:none; border:1px solid var(--nt-line-2); border-radius:var(--nt-radius); cursor:pointer; color:var(--nt-text-2); font-size:12px; padding:4px 10px; }
.n-cal-today:hover { background:var(--nt-hover); }
.n-cal-grid { display:grid; grid-template-columns:repeat(7,1fr); }
.n-cal-head { border:1px solid var(--nt-line-2); border-bottom:0; border-radius:6px 6px 0 0; overflow:hidden; }
.n-cal-wd { padding:6px 8px; font-size:12px; color:var(--nt-text-2); text-align:right; background:#fafafa; border-right:1px solid var(--nt-line); }
.n-cal-wd:last-child { border-right:0; } .n-cal-wd.sun { color:#c0392b; } .n-cal-wd.sat { color:#2f6db3; }
.n-cal-body { border:1px solid var(--nt-line-2); border-radius:0 0 6px 6px; overflow:hidden; }
.n-cal-cell { min-height:104px; border-right:1px solid var(--nt-line); border-bottom:1px solid var(--nt-line); padding:4px; display:flex; flex-direction:column; gap:3px; }
.n-cal-cell:nth-child(7n) { border-right:0; }
.n-cal-cell.empty { background:#fbfbfa; }
.n-cal-day { font-size:12px; color:var(--nt-text-2); text-align:right; padding:1px 3px; }
.n-cal-cell.today .n-cal-day { background:var(--nt-blue); color:#fff; border-radius:50%; width:20px; height:20px; display:inline-flex; align-items:center; justify-content:center; margin-left:auto; }
.n-cal-ev { font-size:11px; line-height:1.3; padding:2px 6px; border-radius:3px; cursor:pointer; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.n-cal-ev.c-default{background:var(--tg-default-bg);color:var(--tg-default-fg);} .n-cal-ev.c-gray{background:var(--tg-gray-bg);color:var(--tg-gray-fg);}
.n-cal-ev.c-brown{background:var(--tg-brown-bg);color:var(--tg-brown-fg);} .n-cal-ev.c-orange{background:var(--tg-orange-bg);color:var(--tg-orange-fg);}
.n-cal-ev.c-yellow{background:var(--tg-yellow-bg);color:var(--tg-yellow-fg);} .n-cal-ev.c-green{background:var(--tg-green-bg);color:var(--tg-green-fg);}
.n-cal-ev.c-blue{background:var(--tg-blue-bg);color:var(--tg-blue-fg);} .n-cal-ev.c-purple{background:var(--tg-purple-bg);color:var(--tg-purple-fg);}
.n-cal-ev.c-pink{background:var(--tg-pink-bg);color:var(--tg-pink-fg);} .n-cal-ev.c-red{background:var(--tg-red-bg);color:var(--tg-red-fg);}

/* =============================================================================
 * ページピーク（行クリックで開くNotionページ）
 * ========================================================================== */
#n-peek-overlay { position:fixed; inset:0; background:rgba(15,15,15,.35); z-index:300; display:none; }
#n-peek-overlay.open { display:block; }
.n-peek {
  position:fixed; top:0; right:0; height:100vh; width:min(1100px, max(720px, 50vw)); background:#fff;
  box-shadow:-2px 0 24px rgba(0,0,0,.18); z-index:301; overflow-y:auto; transform:translateX(100%);
  transition:transform .18s ease;
}
.n-peek.open { transform:translateX(0); }
.n-peek-bar { position:sticky; top:0; background:#fff; display:flex; align-items:center; gap:6px; padding:8px 14px; border-bottom:1px solid var(--nt-line); z-index:5; }
.n-peek-bar .nav { display:flex; align-items:center; gap:2px; color:var(--nt-text-2); }
.n-peek-bar .ico { background:none; border:0; cursor:pointer; color:var(--nt-text-2); padding:4px; border-radius:var(--nt-radius); display:inline-flex; }
.n-peek-bar .ico:hover { background:var(--nt-hover); }
.n-peek-bar .ico svg { width:18px; height:18px; }
.n-peek-bar .crumb { font-size:13px; color:var(--nt-text-2); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.n-peek-bar .sp { flex:1; }
.n-peek-body { padding:18px 56px 120px; }
.n-peek-body.center { max-width:920px; margin:0 auto; }
.n-rec-title { display:flex; align-items:flex-start; gap:10px; color:var(--nt-text); margin:14px 0 12px; }
.n-rec-h1 { flex:1; min-width:0; margin:0; font-size:30px; font-weight:700; letter-spacing:-.5px; line-height:1.3; color:var(--nt-text); word-break:normal; overflow-wrap:anywhere; line-break:strict; }
.n-rec-h1 .n-editable { display:inline; max-width:none; }
.n-title-ce { outline:none; cursor:text; border-radius:4px; }
.n-title-ce:empty:before { content:"無題"; color:var(--nt-text-3); }
.n-rec-title .icbox { width:30px; height:30px; border-radius:7px; display:flex; align-items:center; justify-content:center; font-size:14px; font-weight:700; flex-shrink:0; margin-top:3px; background:#eef3f8; color:#5a86b8; }
.n-rec-title .icbox.svg { background:#f3f2f0; color:#9b9a97; }
.n-rec-title .icbox.svg svg { width:18px; height:18px; }

/* プロパティ表（key 左 / value 右） */
.n-props { display:flex; flex-direction:column; gap:1px; margin-bottom:10px; }
.n-prop { display:flex; align-items:flex-start; gap:8px; font-size:14px; padding:5px 6px; border-radius:var(--nt-radius); }
.n-prop:hover { background:#f8f8f7; }
.n-prop > .k { color:var(--nt-text-2); min-width:170px; max-width:170px; display:flex; align-items:center; gap:7px; padding-top:1px; flex-shrink:0; }
.n-prop > .k .ic { width:16px; height:16px; color:#9b9a97; display:inline-flex; }
.n-prop > .k .ic svg { width:15px; height:15px; }
.n-prop > .v { flex:1; min-width:0; color:var(--nt-text); padding-top:1px; }

/* 本文セクション */
.n-sec-h { font-size:20px; font-weight:600; color:var(--nt-text); margin:26px 0 2px; }
.n-sec-desc { color:var(--nt-text-3); font-size:14px; margin:0 0 10px; line-height:1.5; }
.n-divider { border:0; border-top:1px solid var(--nt-line-2); margin:18px 0; }
/* Notion風オープンなインラインDB（枠で囲まず、罫線のみ） */
.n-inline-db { border:0; border-top:1px solid var(--nt-line-2); }
.n-inline-db table { width:100%; border-collapse:collapse; font-size:14px; }
.n-inline-db th { text-align:left; color:var(--nt-text-3); font-weight:400; font-size:12px; padding:6px 8px; border-bottom:1px solid var(--nt-line); background:none; white-space:nowrap; }
.n-inline-db td { padding:7px 8px; border-bottom:1px solid var(--nt-line); color:var(--nt-text); vertical-align:top; }
.n-inline-db td.num { text-align:right; font-variant-numeric:tabular-nums; }
.n-inline-db tbody tr:hover { background:#f8f8f7; }
.n-inline-foot { padding:6px 8px; font-size:12px; color:var(--nt-text-3); text-align:left; background:none; }
.n-hasdoc { display:inline-block; margin-left:6px; font-size:10px; line-height:1.4; color:var(--nt-text-3); border:1px solid var(--nt-line-2); border-radius:4px; padding:0 4px; vertical-align:middle; }
table.n-table tbody tr.n-grouphdr td .n-grouphdr-lbl { font-weight:600; font-size:13px; color:var(--nt-text); }

/* ===== タスク管理UI（進捗パネル/カンバン強調/クイック操作/詳細展開） ===== */
/* 進捗パネル: モノトーン。達成リング＋残り件数＋内訳テキスト（色アクセントなし） */
.n-tasksummary { margin:14px 0 4px; }
.n-quest { display:flex; align-items:center; gap:22px; padding:14px 20px; border:1px solid var(--nt-line); border-radius:10px; background:#fff; flex-wrap:wrap; }
.n-quest-ring { cursor:pointer; flex-shrink:0; }
.n-ring-svg .n-ring-track { stroke:#ededeb; }
.n-ring-svg .n-ring-fill { stroke:#37352f; transition:stroke-dasharray .6s cubic-bezier(.4,0,.2,1); }
.n-ring-svg .n-ring-pct { font-size:20px; font-weight:700; fill:var(--nt-text); font-family:inherit; }
.n-ring-svg .n-ring-sub { font-size:10px; fill:var(--nt-text-3); letter-spacing:.04em; }
.n-quest-mid { display:flex; flex-direction:column; gap:4px; min-width:170px; }
.n-quest-remain { display:flex; align-items:baseline; gap:8px; cursor:pointer; }
.n-quest-remain .n-qr-n { font-size:30px; font-weight:700; line-height:1; color:var(--nt-text); font-variant-numeric:tabular-nums; }
.n-quest-remain .n-qr-l { font-size:12px; color:var(--nt-text-2); }
.n-quest-remain:hover .n-qr-n { color:#000; }
.n-quest-cheer { font-size:13px; font-weight:600; color:var(--nt-text); }
.n-quest-meta { font-size:12px; color:var(--nt-text-3); }
.n-quest-today { border:0; background:none; color:var(--nt-text-2); cursor:pointer; font-size:12px; padding:0; text-decoration:underline; }
.n-quest-today:hover { color:var(--nt-text); }
.n-quest-breakdown { border:0; background:none; cursor:pointer; font-size:12px; color:var(--nt-text-3); padding:2px 0 0; text-align:left; }
.n-quest-breakdown:hover { color:var(--nt-text-2); }

/* クイック完了・選択列 */
table.n-table th.n-cellchk, table.n-table td.n-cellchk { width:30px; text-align:center; padding:6px 2px 6px 8px; }
table.n-table th.n-cellquick, table.n-table td.n-cellquick { width:30px; text-align:center; padding:6px 4px; }
.n-selrow, .n-selall { cursor:pointer; }
.n-quickdone { width:19px; height:19px; border:1.6px solid var(--nt-line-2); border-radius:50%; background:#fff; cursor:pointer; display:inline-flex; align-items:center; justify-content:center; padding:0; color:transparent; transition:all .12s; }
.n-quickdone svg { width:12px; height:12px; }
.n-quickdone:hover { border-color:var(--nt-text-2); color:var(--nt-text-2); }
.n-quickdone.on { background:var(--nt-text); border-color:var(--nt-text); color:#fff; }

/* 期限の強調（モノトーン・色アクセントなし）。超過=太字+下線、当日=太字。色バーは使わない */
table.n-table td.due-over { color:var(--nt-text); font-weight:700; text-decoration:underline; text-underline-offset:2px; }
table.n-table td.due-today { color:var(--nt-text); font-weight:700; }
table.n-table td.due-soon { color:var(--nt-text-2); }
table.n-table tbody tr.row-done td { opacity:.5; }
.n-bcard .mini.due-over { color:var(--nt-text); font-weight:700; text-decoration:underline; text-underline-offset:2px; }
.n-bcard .mini.due-today { color:var(--nt-text); font-weight:700; }

/* ステータス/優先度タグは Notion標準の淡いパステル（薄く色付き）を使う。
   ＝強い色バーは廃したまま、In progress 等や高優先度だけ控えめに色で目立たせる。
   優先度の「緊急・高」はやや濃いめにして視線を集める（中・低は淡いまま）。 */
.n-table-tasks .n-tag.c-red, .n-board-tasks .n-tag.c-red,
.n-table-tasks .n-tag.c-orange, .n-board-tasks .n-tag.c-orange { font-weight:600; }

/* 詳細展開 */
.n-detail-toggle { border:0; background:none; cursor:pointer; padding:0 2px; color:var(--nt-text-3); display:inline-flex; align-items:center; vertical-align:middle; transition:transform .12s; }
.n-detail-toggle svg { width:13px; height:13px; }
.n-detail-toggle.open { transform:rotate(90deg); }
table.n-table tbody tr.n-detailrow td { background:#fbfbfa; padding:4px 14px 12px 44px; }
table.n-table tbody tr.n-detailrow:hover td { background:#fbfbfa; }
.n-detailrow .n-doc { font-size:13px; }

/* スプリント・ダッシュボード（週次スクラム） */
.n-sprint { padding:6px 0 24px; }
.n-spr-bar { display:flex; align-items:center; gap:12px; margin-bottom:16px; }
.n-spr-nav, .n-spr-now { border:1px solid var(--nt-line); background:#fff; border-radius:7px; cursor:pointer; color:var(--nt-text-2); display:inline-flex; align-items:center; padding:5px 8px; }
.n-spr-nav svg { width:15px; height:15px; }
.n-spr-now { font-size:12px; padding:5px 11px; }
.n-spr-nav:hover, .n-spr-now:hover { background:#f7f7f5; }
.n-spr-bar-sp { flex:1; }
.n-spr-period { display:flex; flex-direction:column; line-height:1.25; align-items:flex-end; text-align:right; }
.n-spr-period b { font-size:15px; color:var(--nt-text); }
.n-spr-period span { font-size:12px; color:var(--nt-text-3); }
/* タブ行右端の週ヘッダー */
.n-viewbar-right { margin-left:auto; display:flex; align-items:center; gap:6px; padding-bottom:4px; }
.n-viewbar-right .n-spr-period b { font-size:13px; }
.n-viewbar-right .n-spr-period span { font-size:11px; }
.n-spr-top { display:flex; gap:14px; flex-wrap:wrap; align-items:stretch; margin-bottom:22px; }
.n-spr-kpis { display:flex; gap:10px; flex:1 1 500px; }
.n-spr-kpi { flex:1; display:flex; flex-direction:column; gap:5px; min-width:84px; padding:13px 15px; border:1px solid var(--nt-line); border-radius:12px; background:#fff; box-shadow:0 1px 2px rgba(15,23,42,.03); }
.n-spr-kpi .n-spr-kn { font-size:26px; font-weight:700; line-height:1; color:var(--nt-text); font-variant-numeric:tabular-nums; letter-spacing:-.01em; }
.n-spr-kpi .n-spr-kn small { font-size:14px; color:var(--nt-text-3); font-weight:600; }
.n-spr-kpi .n-spr-kl { font-size:11px; color:var(--nt-text-3); line-height:1.35; }
.n-spr-spark { flex:1 1 300px; min-width:260px; padding:13px 18px 11px; border:1px solid var(--nt-line); border-radius:12px; background:#fff; box-shadow:0 1px 2px rgba(15,23,42,.03); }
.n-spk-title { font-size:11px; color:var(--nt-text-3); margin-bottom:6px; }
.n-spk { display:flex; align-items:flex-end; gap:6px; height:88px; padding-top:14px; }
.n-spk-col { flex:1; display:flex; flex-direction:column; align-items:center; height:100%; justify-content:flex-end; gap:3px; position:relative; }
.n-spk-bar { width:28px; max-width:72%; min-height:3px; background:#37352f; border-radius:4px 4px 0 0; transition:height .4s ease; }
.n-spk-bar.today { background:#000; }
.n-spk-bar.future { background:#ededeb; }
.n-spk-n { font-size:11px; color:var(--nt-text-2); font-variant-numeric:tabular-nums; min-height:13px; }
.n-spk-l { font-size:11px; color:var(--nt-text-3); }
.n-spk-l.today { color:var(--nt-text); font-weight:700; }
.n-spr-board-title { font-size:12px; color:var(--nt-text-3); margin-bottom:8px; }
.n-spr-section { font-size:12px; font-weight:600; color:var(--nt-text-2); margin:18px 0 10px; letter-spacing:.02em; }
.n-spr-section:first-child { margin-top:4px; }
.n-spr-board { display:flex; flex-direction:column; gap:8px; }
.n-spr-main { flex:1; display:flex; flex-direction:column; gap:5px; min-width:0; }
.n-spr-row1 { display:flex; align-items:baseline; gap:10px; }
.n-spr-row1 .n-spr-name { flex:1; }
.n-spr-you { margin-left:7px; font-size:10px; font-weight:600; color:var(--nt-text-3); border:1px solid var(--nt-line-2); border-radius:4px; padding:0 5px; vertical-align:middle; }
.n-spr-mvp { margin-left:6px; font-size:10px; font-weight:700; color:#fff; background:#37352f; border-radius:4px; padding:1px 6px; vertical-align:middle; }
.n-spr-track { height:6px; border-radius:3px; background:#f0f0ee; overflow:hidden; }
.n-spr-fill { display:block; height:100%; background:#37352f; border-radius:3px; transition:width .5s ease; }
.n-spr-card.lead .n-spr-fill { background:#000; }
.n-spr-card { border:1px solid var(--nt-line); border-radius:12px; background:#fff; overflow:hidden; box-shadow:0 1px 2px rgba(15,23,42,.03); transition:box-shadow .15s ease; }
.n-spr-card:hover { box-shadow:0 3px 12px rgba(15,23,42,.07); }
.n-spr-card.lead { border-color:#d8d7d3; background:#fbfbfa; }
.n-spr-head { display:flex; align-items:center; gap:12px; padding:11px 16px; cursor:pointer; }
.n-spr-head:hover { background:#f7f7f5; }
.n-spr-rank { width:24px; height:24px; flex-shrink:0; display:inline-flex; align-items:center; justify-content:center; border-radius:50%; background:#f0f0ee; color:var(--nt-text-2); font-size:12px; font-weight:700; font-variant-numeric:tabular-nums; }
.n-spr-card.lead .n-spr-rank { background:#37352f; color:#fff; }
.n-spr-name { font-size:14px; color:var(--nt-text); font-weight:600; flex:1; }
.n-spr-done { display:flex; align-items:baseline; gap:4px; }
.n-spr-done b { font-size:22px; font-weight:700; color:var(--nt-text); font-variant-numeric:tabular-nums; }
.n-spr-done i { font-size:11px; color:var(--nt-text-3); font-style:normal; }
.n-spr-side { display:flex; align-items:center; gap:10px; }
.n-spr-today { font-size:12px; font-weight:600; color:var(--nt-text); border:1px solid var(--nt-line-2); border-radius:5px; padding:1px 7px; }
.n-spr-prog { font-size:12px; color:var(--nt-text-3); }
.n-spr-caret { color:var(--nt-text-3); display:inline-flex; transition:transform .12s; }
.n-spr-caret svg { width:15px; height:15px; }
.n-spr-caret.open { transform:rotate(90deg); }
.n-spr-tasks { border-top:1px solid var(--nt-line); padding:6px 16px 10px 52px; background:#fbfbfa; }
.n-spr-task { display:flex; gap:10px; align-items:baseline; padding:4px 0; font-size:13px; }
.n-spr-when { font-size:11px; color:var(--nt-text-3); font-variant-numeric:tabular-nums; flex-shrink:0; }
.n-spr-empty { font-size:12px; color:var(--nt-text-3); padding:4px 0; }
.n-spr-note { margin-top:14px; padding:10px 14px; border:1px dashed var(--nt-line-2); border-radius:8px; color:var(--nt-text-3); font-size:12px; line-height:1.6; }

/* ===== スプリント・ゲームダッシュボード（モノトーン基調・配色はグレー濃淡のみ） ===== */
.n-sprint.game { --accent:#37352f; --gold:#37352f; --silver:#8d8b86; --bronze:#b6b4af; }
/* ヒーローカード（あなた）＝ダークなモノトーン */
.n-game-hero { display:flex; align-items:center; gap:20px; padding:18px 24px; margin:6px 0 4px; border-radius:16px;
  background:linear-gradient(152deg,#35322d 0%,#2a2723 55%,#211e1b 100%); color:#fff;
  box-shadow:0 12px 32px rgba(0,0,0,.20), inset 0 1px 0 rgba(255,255,255,.06); }
.hero-badge { flex-shrink:0; width:70px; height:70px; border-radius:50%; display:flex; flex-direction:column; align-items:center; justify-content:center;
  background:rgba(255,255,255,.08); border:2px solid rgba(255,255,255,.22); }
.hero-badge.rank-1 { background:rgba(255,255,255,.16); border-color:rgba(255,255,255,.55); }
.hero-badge.rank-2 { background:rgba(255,255,255,.10); border-color:rgba(255,255,255,.32); }
.hero-badge.rank-3 { background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.24); }
.hero-rank-n { font-size:30px; font-weight:800; line-height:1; }
.hero-rank-l { font-size:11px; opacity:.7; }
.hero-body { flex:1; min-width:0; }
.hero-name { font-size:14px; font-weight:600; display:flex; align-items:center; gap:8px; }
.hero-you { font-size:10px; font-weight:700; background:rgba(255,255,255,.85); color:#2c2a27; border-radius:4px; padding:1px 6px; letter-spacing:.05em; }
.hero-lv { font-size:11px; background:rgba(255,255,255,.14); border-radius:4px; padding:1px 7px; }
.hero-big { display:flex; align-items:baseline; gap:8px; margin:4px 0 7px; }
.hero-done { font-size:38px; font-weight:800; line-height:1; color:#fff; font-variant-numeric:tabular-nums; }
.hero-done-l { font-size:12px; opacity:.7; }
.hero-xp { margin-left:8px; font-size:15px; font-weight:700; color:#fff; opacity:.92; }
.hero-xprow { display:flex; align-items:center; gap:9px; margin:2px 0 1px; }
.hero-xprow .lvcap { font-size:10px; font-weight:700; opacity:.6; flex-shrink:0; letter-spacing:.03em; }
.hero-xpbar { flex:1; max-width:300px; height:6px; border-radius:4px; background:rgba(255,255,255,.13); overflow:hidden; box-shadow:inset 0 1px 1px rgba(0,0,0,.2); }
.hero-xpbar span { display:block; height:100%; background:linear-gradient(90deg,rgba(255,255,255,.7),#fff); border-radius:4px; transition:width .6s cubic-bezier(.4,0,.2,1); }
.hero-meta { font-size:11.5px; opacity:.82; margin-top:6px; display:flex; align-items:center; gap:6px; flex-wrap:wrap; }
.hero-chip { background:rgba(255,255,255,.14); border-radius:4px; padding:1px 7px; font-weight:600; }
.hero-goal { flex-shrink:0; text-align:center; min-width:96px; padding-left:16px; border-left:1px solid rgba(255,255,255,.14); }
.hero-goal-n { font-size:30px; font-weight:800; color:#fff; line-height:1; }
.hero-goal-l { font-size:11px; opacity:.72; margin-top:3px; }
/* KPI 強調（無彩色） */
.n-spr-kpi.hot { border-color:#c9c8c4; background:#f5f5f3; }
.n-spr-kpi.hot .n-spr-kn { color:var(--nt-text); }
/* 日別バー＝グレー */
.n-sprint.game .n-spk-bar { background:#bdbcb7; }
.n-sprint.game .n-spk-bar.today { background:#37352f; }
.n-sprint.game .n-spk-bar.future { background:#ededeb; }
/* リーダーボード XPバー＆順位（グレー濃淡） */
.n-spr-row2 { font-size:11.5px; color:var(--nt-text-3); margin-top:5px; display:flex; align-items:center; gap:7px; flex-wrap:wrap; }
.n-spr-xp { display:flex; align-items:baseline; gap:4px; }
.n-spr-xp b { font-size:21px; font-weight:800; color:var(--nt-text); font-variant-numeric:tabular-nums; }
.n-spr-xp i { font-size:11px; color:var(--nt-text-3); font-style:normal; }
.n-sprint.game .n-spr-fill { background:#c6c5c0; }
.n-spr-card.rank-1 { border-color:#c9c8c4; }
.n-spr-card.rank-1 .n-spr-rank { background:#37352f; color:#fff; }
.n-spr-card.rank-1 .n-spr-fill { background:#37352f; }
.n-spr-card.rank-2 .n-spr-rank { background:#8d8b86; color:#fff; }
.n-spr-card.rank-2 .n-spr-fill { background:#8d8b86; }
.n-spr-card.rank-3 .n-spr-rank { background:#b6b4af; color:#fff; }
.n-spr-card.rank-3 .n-spr-fill { background:#b6b4af; }
.n-spr-card.is-you { box-shadow:inset 0 0 0 2px var(--nt-text); }
.n-spr-card.is-you:hover { box-shadow:inset 0 0 0 2px var(--nt-text), 0 3px 12px rgba(15,23,42,.07); }
.n-spr-rank.none { background:transparent; color:var(--nt-text-3); font-weight:400; }
/* 順位変動の矢印（モノトーン: 上昇=濃, 下降=淡） */
.rk-up, .rk-dn, .rk-eq { font-size:10px; font-weight:700; font-variant-numeric:tabular-nums; }
.rk-up { color:var(--nt-text); }
.rk-dn { color:var(--nt-text-3); font-weight:600; }
.rk-eq { color:var(--nt-line-2); }
/* ヒーロー: 時計・先週比・矢印・警告チップ */
.hero-clock { margin-left:auto; display:inline-flex; align-items:baseline; gap:8px; }
.hero-clock .hc-l { font-size:10px; font-weight:600; opacity:.55; letter-spacing:.06em; }
.n-countdown { font-variant-numeric:tabular-nums; letter-spacing:.02em; }
.hero-clock .n-countdown { font-size:19px; font-weight:700; opacity:1; }
.hero-rank-arrow { font-size:10px; margin-top:2px; }
.hero-rank-arrow .rk-up { color:#fff; } .hero-rank-arrow .rk-dn { color:rgba(255,255,255,.6); } .hero-rank-arrow .rk-eq { color:rgba(255,255,255,.4); }
.hero-week { margin-left:10px; font-size:12px; font-weight:700; opacity:.9; }
.hero-week.dn { opacity:.6; }
.hero-chip.warn { background:transparent; border:1px solid rgba(255,255,255,.5); }
/* KPI 先週比 */
.n-spr-kl b { font-weight:700; font-variant-numeric:tabular-nums; }
.n-spr-kl b.up { color:var(--nt-text); } .n-spr-kl b.dn { color:var(--nt-text-3); }
/* セクション見出しの時計 */
.n-spr-section .n-spr-clock { margin-left:10px; font-size:11px; font-weight:500; color:var(--nt-text-3); }
/* バー伸長アニメ（juice） */
@keyframes spr-grow { from { transform:scaleX(0); } to { transform:scaleX(1); } }
.n-sprint.game .n-spr-fill, .n-game-hero .hero-xpbar span { transform-origin:left; animation:spr-grow .6s cubic-bezier(.2,.7,.2,1); }
.n-spr-pt { min-width:34px; }
.n-spr-bdg { font-size:10.5px; font-weight:600; color:var(--nt-text-2); background:#f0f0ee; border-radius:4px; padding:1px 6px; }
.n-spr-bdg.mvp { background:#37352f; color:#fff; }
.n-spr-pt { font-size:11px; font-weight:700; color:var(--nt-text-2); font-variant-numeric:tabular-nums; min-width:30px; }

/* 一括操作バー */
.n-bulkbar { position:sticky; bottom:14px; display:flex; align-items:center; gap:8px; margin:12px auto 0; width:fit-content; padding:8px 14px; background:#37352f; color:#fff; border-radius:10px; box-shadow:0 8px 28px rgba(0,0,0,.22); font-size:13px; z-index:20; }
.n-bulkbar .n-bulk-n { font-weight:700; }
.n-bulk-btn { border:0; border-radius:6px; padding:5px 11px; background:rgba(255,255,255,.16); color:#fff; cursor:pointer; font-size:12px; }
.n-bulk-btn:hover { background:rgba(255,255,255,.28); }
.n-bulk-btn.ghost { background:none; color:#cfcdc8; }
/* Notion のインラインDB「+ New」追加行（最下部・全幅・薄字・ホバーで反転） */
.n-inline-add { display:flex; align-items:center; gap:8px; padding:8px; font-size:14px; color:var(--nt-text-3); cursor:pointer; user-select:none; border-bottom:1px solid var(--nt-line); }
.n-inline-add:hover { background:#f8f8f7; color:var(--nt-text-2); }
.n-inline-add .ic { width:16px; height:16px; display:inline-flex; color:var(--nt-text-3); }
.n-inline-add .ic svg { width:15px; height:15px; }
.n-notsynced { padding:12px 14px; border:1px dashed var(--nt-line-2); border-radius:6px; color:var(--nt-text-3); font-size:13px; line-height:1.6; }
/* 議事録本文（Markdown表示） */
.n-doc { font-size:14px; line-height:1.75; color:var(--nt-text); }
/* タスク詳細インライン編集（ポップアップなし・その場で編集） */
.n-sec-hint { font-size:11px; font-weight:400; color:var(--nt-text-3); margin-left:8px; }
.n-task-desc { min-height:44px; border-radius:5px; padding:8px 10px; margin:2px -10px 0; cursor:text; transition:background .1s; }
.n-task-desc:not(.editing):hover { background:var(--nt-hover); }
/* 編集中は入力ボックス風の枠を出さず、キャレットだけでそのまま書ける（Notion風） */
.n-task-desc.editing { background:transparent; box-shadow:none; outline:none; white-space:pre-wrap; cursor:text; }
.n-task-desc.editing:empty:before { content:"詳細を入力…（マークダウン記法が使えます）"; color:var(--nt-text-3); }
.n-doc-ph { color:var(--nt-text-3); }
/* タスクのアクションボタン（スライド作成など） */
.n-task-actions { margin:10px 0 2px; display:flex; gap:8px; flex-wrap:wrap; }
.n-act-btn { display:inline-flex; align-items:center; gap:6px; border:1px solid var(--nt-line-2); border-radius:8px; background:#fff; color:var(--nt-text); cursor:pointer; padding:7px 13px; font-size:13px; font-weight:500; transition:background .12s, border-color .12s; }
.n-act-btn:hover { background:#f7f7f5; border-color:var(--nt-text-3); }
.n-act-btn svg { width:15px; height:15px; color:var(--nt-text-2); }

/* 今日の作戦（AIプラン） */
.n-plan { padding:4px 0 28px; }
.plan-hero { display:flex; align-items:center; gap:18px; flex-wrap:wrap; padding:16px 20px; border:1px solid var(--nt-line); border-radius:14px; background:#fff; margin:6px 0 6px; box-shadow:0 1px 2px rgba(15,23,42,.03); }
.plan-hero-l { flex:1; min-width:220px; }
.plan-hero-h { font-size:18px; font-weight:700; color:var(--nt-text); }
.plan-hero-sub { font-size:13px; color:var(--nt-text-2); margin-top:3px; }
.plan-hero-r { display:flex; flex-direction:column; align-items:flex-end; gap:6px; }
.plan-load { width:190px; height:8px; border-radius:5px; background:#f0f0ee; overflow:hidden; }
.plan-load span { display:block; height:100%; background:#37352f; border-radius:5px; transition:width .5s cubic-bezier(.4,0,.2,1); }
.plan-load-t { font-size:11px; color:var(--nt-text-3); font-variant-numeric:tabular-nums; }
.plan-btns { display:flex; gap:6px; }
.plan-recalc { border:1px solid var(--nt-line-2); background:#fff; border-radius:7px; padding:4px 12px; font-size:12px; cursor:pointer; color:var(--nt-text-2); }
.plan-recalc:hover { background:#f7f7f5; color:var(--nt-text); }
.plan-recalc:disabled { opacity:.6; cursor:default; }
.plan-ai { border-color:var(--nt-text); color:var(--nt-text); font-weight:600; }
.plan-ai:hover { background:var(--nt-text); color:#fff; }
.plan-list { display:flex; flex-direction:column; gap:6px; margin-bottom:4px; }
.plan-row { display:flex; align-items:center; gap:12px; padding:11px 14px; border:1px solid var(--nt-line); border-radius:10px; background:#fff; box-shadow:0 1px 2px rgba(15,23,42,.03); }
.plan-row.mini { padding:8px 14px; }
.plan-row.resch { border-style:dashed; background:#fbfbfa; }
.plan-main { flex:1; min-width:0; }
.plan-l1 { font-size:14px; color:var(--nt-text); display:flex; align-items:center; gap:8px; }
.plan-l1 a { color:var(--nt-text); }
.plan-l2 { font-size:12px; color:var(--nt-text-3); margin-top:3px; display:flex; align-items:center; gap:7px; flex-wrap:wrap; }
.plan-over { color:var(--nt-text); font-weight:700; }
.plan-arrow { color:var(--nt-text-3); }
.plan-done { width:20px; height:20px; flex-shrink:0; border:1.6px solid var(--nt-line-2); border-radius:50%; background:#fff; cursor:pointer; display:inline-flex; align-items:center; justify-content:center; color:transparent; transition:all .12s; }
.plan-done svg { width:12px; height:12px; }
.plan-done:hover { border-color:var(--nt-text); color:var(--nt-text); }
.plan-eff-tag { font-size:10px; font-weight:700; border:1px solid var(--nt-line-2); border-radius:4px; padding:0 5px; color:var(--nt-text-2); }
.plan-effset { display:inline-flex; gap:3px; flex-shrink:0; }
.plan-eff { width:24px; height:24px; border:1px solid var(--nt-line); background:#fff; border-radius:6px; font-size:11px; font-weight:600; color:var(--nt-text-3); cursor:pointer; }
.plan-eff:hover { background:#f7f7f5; }
.plan-eff.on { background:#37352f; color:#fff; border-color:#37352f; }
.plan-acts { flex-shrink:0; }
.plan-resch-btn { border:1px solid var(--nt-text); background:var(--nt-text); color:#fff; border-radius:7px; padding:6px 13px; font-size:12px; font-weight:600; cursor:pointer; }
.plan-resch-btn:hover { filter:brightness(1.25); }
.plan-toggle { cursor:pointer; display:flex; align-items:center; gap:6px; }
.plan-caret { color:var(--nt-text-3); font-size:11px; }
.n-doc h3, .n-doc h4, .n-doc h5 { font-weight:600; color:var(--nt-text); margin:16px 0 4px; line-height:1.3; }
.n-doc h3 { font-size:18px; } .n-doc h4 { font-size:16px; } .n-doc h5 { font-size:14px; }
.n-doc p { margin:6px 0; } .n-doc ul { margin:6px 0; padding-left:22px; } .n-doc li { margin:3px 0; }
.n-doc code { background:#f1f0ee; border-radius:3px; padding:1px 5px; font-size:13px; }
.n-linkpage { display:flex; align-items:center; gap:8px; padding:5px 6px; border-radius:var(--nt-radius); color:var(--nt-text); cursor:default; }
.n-linkpage .ic { color:#91918e; display:inline-flex; } .n-linkpage .ic svg{ width:16px;height:16px; }

/* 空状態 */
.n-loading { color:var(--nt-text-3); font-size:14px; padding:40px 8px; text-align:center; }

/* インライン編集の可視ヒント */
.n-editable { border-radius:3px; padding:1px 4px; margin:-1px -4px; cursor:pointer; transition:background .08s; display:inline-block; max-width:100%; }
.n-editable:hover { background:var(--nt-hover); }
td.n-editable-cell { cursor:pointer; }
table.n-table tbody td.n-editable-cell:hover { box-shadow:inset 0 0 0 2px rgba(35,131,226,.35); border-radius:2px; }
.n-pop-item:hover { background:var(--nt-hover); }

/* =============================================================================
 * グローバル検索（Cmd+K）モーダル
 * ========================================================================== */
#n-search-overlay { position:fixed; inset:0; background:rgba(15,15,15,.4); z-index:350; display:none; }
#n-search-overlay.open { display:block; }
.n-search-modal {
  position:fixed; top:96px; left:50%; transform:translateX(-50%); width:min(680px,92vw);
  background:#fff; border-radius:10px; box-shadow:0 16px 60px rgba(0,0,0,.28); z-index:351;
  overflow:hidden; max-height:72vh; display:flex; flex-direction:column;
}
.n-search-head { display:flex; align-items:center; gap:10px; padding:12px 16px; border-bottom:1px solid var(--nt-line-2); }
.n-search-head .ic { width:20px; height:20px; color:var(--nt-text-3); display:inline-flex; }
.n-search-head .ic svg { width:19px; height:19px; }
.n-search-head input { flex:1; border:0; outline:none; font-size:16px; color:var(--nt-text); background:none; }
.n-search-head .esc { font-size:11px; color:var(--nt-text-3); border:1px solid var(--nt-line-2); border-radius:4px; padding:1px 6px; }
.n-search-results { overflow-y:auto; padding:6px; }
.n-search-group { padding:8px 8px 2px; font-size:11px; font-weight:600; color:var(--nt-text-3); display:flex; align-items:center; gap:6px; }
.n-search-group .ic { width:14px; height:14px; display:inline-flex; color:#91918e; } .n-search-group .ic svg{ width:13px;height:13px; }
.n-search-item { display:flex; align-items:center; gap:9px; padding:7px 9px; border-radius:5px; cursor:pointer; }
.n-search-item:hover, .n-search-item.sel { background:var(--nt-hover); }
.n-search-item .ic { width:18px; height:18px; color:#91918e; display:inline-flex; flex-shrink:0; } .n-search-item .ic svg{ width:16px;height:16px; }
.n-search-item .t { flex:1; min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; color:var(--nt-text); font-size:14px; }
.n-search-item .sub { font-size:12px; color:var(--nt-text-3); flex-shrink:0; }
.n-search-empty { color:var(--nt-text-3); font-size:13px; padding:24px; text-align:center; }

/* =============================================================================
 * 分析ページ（既存 .panel/.card 群）の Notion 風微調整
 * ========================================================================== */
.n-analytics-head { padding:48px 0 6px; }
.n-analytics-head h1 { font-size:30px; font-weight:700; letter-spacing:-.4px; margin:0 0 6px; color:var(--nt-text); display:flex; align-items:center; gap:10px; }
.n-analytics-head h1 .ic { width:32px;height:32px;display:flex;align-items:center;justify-content:center;color:#91918e; } .n-analytics-head h1 .ic svg{width:28px;height:28px;}
.n-analytics-head .sub { color:var(--nt-text-3); font-size:14px; }

/* =============================================================================
 * モバイル
 * ========================================================================== */
.n-hamburger { display:none; position:fixed; top:8px; left:8px; z-index:130; background:#fff; border:1px solid var(--nt-line-2); border-radius:var(--nt-radius); width:34px; height:34px; cursor:pointer; }
.n-hamburger svg { width:18px; height:18px; }
@media (max-width:860px){
  .n-sidebar { position:fixed; left:0; top:0; z-index:120; transform:translateX(-100%); transition:transform .2s; box-shadow:2px 0 18px rgba(0,0,0,.14); }
  .n-sidebar.open { transform:translateX(0); }
  /* モバイルはハンバーガー運用。デスクトップ用の折りたたみ/幅調整は無効化 */
  .n-side-resizer, .n-side-collapse, .n-side-expand { display:none !important; }
  .n-hamburger { display:flex; align-items:center; justify-content:center; }
  .n-page-wrap, .n-page-wrap.full { padding:0 18px; }
  .n-peek { width:96vw; }
  .n-peek-body { padding:18px 20px 100px; }
  .n-prop > .k { min-width:120px; max-width:120px; }
}

/* =============================================================================
 * 経営サマリー — ミッションコントロール（ライト・SpaceX/Palantir調）
 * 白基調・精密な薄線・ブループリント格子・モノスペース数字・常時アニメーション。
 * ========================================================================== */
.ck-mc {
  --line:rgba(15,23,42,.08); --line2:rgba(15,23,42,.13);
  --tx:#0f172a; --tx2:#475569; --tx3:#94a3b8;
  --ac:#111827; --ac2:#374151; --ok:#111827; --warn:#6b7280; --bad:#e11d48;
  position:relative; border-radius:4px; padding:26px 26px 18px; margin:14px 0 30px;
  color:var(--tx); border:1px solid var(--line2);
  background:
    linear-gradient(rgba(15,23,42,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(15,23,42,.04) 1px, transparent 1px),
    radial-gradient(900px 360px at 85% -10%, rgba(15,23,42,.05), transparent 60%),
    linear-gradient(180deg,#ffffff,#fafafa);
  background-size:28px 28px, 28px 28px, auto, auto;
}
.ck-mc * { font-feature-settings:"tnum"; }
.ck-num { font-variant-numeric:tabular-nums; }
.ck-loading { color:var(--tx3); font-size:13px; padding:18px; text-align:center; }
@keyframes ckfade { from { opacity:0; transform:translateY(7px); } to { opacity:1; transform:none; } }
@keyframes ckpulse { 0%{box-shadow:0 0 0 0 color-mix(in srgb, currentColor 45%, transparent);} 70%{box-shadow:0 0 0 7px transparent;} 100%{box-shadow:0 0 0 0 transparent;} }
@keyframes ckping { 0%{transform:scale(.6);opacity:.9;} 80%,100%{transform:scale(1.9);opacity:0;} }
@keyframes ckscan { 0%{left:-18%;} 100%{left:118%;} }
@keyframes ckgrow { from { transform:scaleX(0); } to { transform:scaleX(1); } }
@keyframes ckblink { 0%,100%{opacity:1;} 50%{opacity:.35;} }
/* HERO */
.ck-hero { margin-bottom:12px; animation:ckfade .5s ease both; }
.ck-greet { display:flex; align-items:baseline; gap:14px; flex-wrap:wrap; margin-bottom:6px; }
#ck-greet-line { font-size:25px; font-weight:700; letter-spacing:-.3px; }
.ck-greet-sub { font-size:11px; color:var(--tx3); letter-spacing:.14em; text-transform:uppercase; }
/* データパルス（連携状態のミニ表示） */
.ck-pulse { display:flex; align-items:center; gap:10px; flex-wrap:wrap; margin:2px 0 16px; font-size:11px; color:var(--tx2); }
.ck-pulse a { display:inline-flex; align-items:center; gap:6px; color:var(--tx2); text-decoration:none; border:1px solid var(--line); background:#fff; border-radius:2px; padding:4px 10px; transition:border-color .15s; }
.ck-pulse a:hover { border-color:var(--ac); }
.ck-pulse .pd { position:relative; width:8px; height:8px; border-radius:50%; }
.ck-pulse .pd::after { content:""; position:absolute; inset:0; border-radius:50%; animation:ckping 1.8s cubic-bezier(0,0,.2,1) infinite; background:inherit; }
.ck-pulse .ok { background:#111827; color:#111827; }
.ck-pulse .warn { background:#9ca3af; color:#9ca3af; }
.ck-pulse .error { background:var(--bad); color:var(--bad); animation:ckblink 1s linear infinite; }
.ck-pulse .off { background:#cbd5e1; } .ck-pulse .off::after { animation:none; }
.ck-pulse .plabel { letter-spacing:.02em; }
/* 主要数値 */
.ck-herostats { display:grid; grid-template-columns:repeat(4,1fr); gap:0; border:1px solid var(--line2); border-radius:2px; background:#fff; overflow:hidden; }
.ck-stat { display:block; background:#fff; border:0; border-left:1px solid var(--line); border-radius:0; padding:14px 16px; position:relative; overflow:hidden; text-decoration:none; color:var(--tx); transition:background .15s; animation:ckfade .5s ease both; }
.ck-stat:first-child { border-left:0; }
.ck-stat:nth-child(2){animation-delay:.06s;} .ck-stat:nth-child(3){animation-delay:.12s;} .ck-stat:nth-child(4){animation-delay:.18s;}
a.ck-stat:hover { background:#f8fafc; }
.ck-stat-lbl { font-size:10px; color:var(--tx2); letter-spacing:.12em; text-transform:uppercase; margin-bottom:6px; }
.ck-stat-val { font-size:24px; font-weight:700; letter-spacing:-.4px; font-variant-numeric:tabular-nums; }
.ck-stat-sub { font-size:11px; color:var(--tx3); margin-top:5px; }
/* チップ */
.ck-chips { display:flex; flex-wrap:wrap; gap:8px; margin:0 0 16px; }
.ck-chip { display:inline-flex; align-items:center; gap:8px; font-size:12px; color:var(--tx); background:#fff; border:1px solid var(--line2); border-radius:2px; padding:6px 12px; text-decoration:none; transition:all .15s; animation:ckfade .45s ease both; }
.ck-chip:hover { border-color:var(--accent); box-shadow:0 4px 14px -8px var(--accent); }
.ck-chip .dot { width:7px; height:7px; border-radius:50%; background:var(--accent); color:var(--accent); animation:ckpulse 2s infinite; }
.ck-chip .arr { color:var(--tx3); }
.ck-chip.alert { border-color:#fecdd3; background:#fff1f2; }
/* パネル */
.ck-panel { background:#fff; border:1px solid var(--line2); border-radius:2px; padding:0; margin-bottom:14px; animation:ckfade .5s ease both; }
.ck-panel > :not(.ck-ptitle) { margin:12px 14px; }
.ck-ptitle { font-size:10.5px; color:var(--tx2); letter-spacing:.14em; font-weight:700; text-transform:uppercase; background:#f4f5f8; border-bottom:1px solid var(--line2); padding:7px 12px; margin:0; display:flex; align-items:center; gap:8px; }
.ck-ptitle::before { content:""; width:7px; height:7px; background:#111827; flex-shrink:0; }
.ck-grid2 { display:grid; grid-template-columns:minmax(0,1fr) minmax(0,1fr); gap:14px; margin-bottom:14px; }
.ck-grid2 .ck-panel { margin-bottom:0; min-width:0; }   /* min-width:0 で中身(canvas/長文)にカラムが押し広げられるのを防ぐ */
.ck-chartbox { position:relative; height:240px; min-width:0; }
.ck-chartbox canvas { max-width:100% !important; }
/* 航路バー */
.ck-orbit-bar { position:relative; height:26px; border-radius:999px; background:#eef2f7; overflow:hidden; border:1px solid var(--line); }
.ck-orbit-bar .seg { position:absolute; top:0; bottom:0; transform-origin:left; animation:ckgrow .9s cubic-bezier(.2,.8,.2,1) both; }
.ck-orbit-bar .s1 { background:linear-gradient(90deg,#0b0f19,#1f2937); }
.ck-orbit-bar .s2 { background:linear-gradient(90deg,#374151,#4b5563); animation-delay:.15s; }
.ck-orbit-bar .s3 { background:linear-gradient(90deg,#6b7280,#9ca3af); animation-delay:.3s; }
.ck-orbit-bar .s4 { background:linear-gradient(90deg,#b6bcc6,#d6dade); animation-delay:.45s; }
.ck-orbit-bar::after { content:""; position:absolute; top:0; bottom:0; width:14%; left:-14%; background:linear-gradient(90deg, transparent, rgba(255,255,255,.65), transparent); animation:ckscan 2.6s linear infinite; }
.ck-orbit-legend { display:grid; grid-template-columns:repeat(4,1fr); gap:10px; margin-top:12px; font-size:12px; color:var(--tx2); }
.ck-orbit-legend b { color:var(--tx); font-variant-numeric:tabular-nums; margin-left:4px; }
.ck-orbit-legend .n { color:var(--tx3); margin-left:6px; font-size:11px; }
.ck-orbit-legend .sw { display:inline-block; width:10px; height:10px; border-radius:3px; margin-right:6px; vertical-align:-1px; }
.ck-orbit-legend .s1{background:#111827;} .ck-orbit-legend .s2{background:#4b5563;} .ck-orbit-legend .s3{background:#9ca3af;} .ck-orbit-legend .s4{background:#d6dade;}
/* フィード */
.ck-feed { display:flex; flex-direction:column; gap:2px; max-height:240px; overflow-y:auto; min-width:0; }
.ck-feeditem { display:flex; align-items:center; gap:9px; font-size:12px; padding:7px 8px; border-radius:7px; animation:ckfade .4s ease both; min-width:0; }
.ck-feeditem:nth-child(1){animation-delay:.05s;} .ck-feeditem:nth-child(2){animation-delay:.1s;} .ck-feeditem:nth-child(3){animation-delay:.15s;} .ck-feeditem:nth-child(4){animation-delay:.2s;} .ck-feeditem:nth-child(5){animation-delay:.25s;}
.ck-feeditem:hover { background:#f1f5f9; }
.ck-feeditem .fd { width:7px; height:7px; border-radius:50%; flex-shrink:0; color:inherit; animation:ckpulse 2.4s infinite; }
.ck-feeditem .fdate { color:var(--tx3); font-variant-numeric:tabular-nums; flex-shrink:0; }
.ck-feeditem .ftag { font-weight:700; flex-shrink:0; }
.ck-feeditem .fname { color:var(--tx2); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; flex:1; min-width:0; }
.ck-feeditem .famt { color:var(--tx); font-variant-numeric:tabular-nums; flex-shrink:0; font-weight:600; }
/* テーブル */
.ck-table { width:100%; border-collapse:collapse; font-size:12.5px; }
.ck-table th { text-align:left; color:var(--tx3); font-weight:600; font-size:11px; padding:6px 8px; border-bottom:1px solid var(--line2); white-space:nowrap; letter-spacing:.04em; }
.ck-table th.num, .ck-table td.num { text-align:right; font-variant-numeric:tabular-nums; }
.ck-table td { padding:7px 8px; border-bottom:1px solid var(--line); color:var(--tx); }
.ck-table tbody tr:hover { background:#f8fafc; }
.ck-table .ck-total td { border-top:1px solid var(--line2); font-weight:700; }
.ck-mini { color:var(--tx3); font-size:11px; }
.ck-detail td { background:#f8fafc; }
.ck-dname { padding-left:24px !important; color:var(--tx2) !important; font-size:12px; }
.ck-dlabel { color:var(--tx3); font-size:11px; margin-left:6px; }
.ck-dval { color:var(--tx2) !important; font-size:12px; }
.ck-dsub { color:var(--tx3) !important; font-size:11px; }
/* ミニ統計 */
.ck-ministats { display:flex; gap:10px; margin-bottom:10px; flex-wrap:wrap; }
.ck-ms { background:#fff; border:1px solid var(--line2); border-radius:8px; padding:7px 12px; font-size:11px; color:var(--tx2); display:flex; flex-direction:column; gap:2px; min-width:110px; }
.ck-ms b { color:var(--tx); font-size:15px; font-variant-numeric:tabular-nums; }
.ck-ms.warn b { color:var(--bad); } .ck-ms.ok b { color:#111827; }
/* クライアントバー */
.ck-cbar { margin-bottom:10px; }
.ck-cbar-top { display:flex; justify-content:space-between; font-size:12px; color:var(--tx2); margin-bottom:4px; }
.ck-cbar-top .vl { color:var(--tx); font-variant-numeric:tabular-nums; font-weight:600; }
.ck-cbar-track { height:8px; border-radius:999px; background:#eef2f7; overflow:hidden; }
.ck-cbar-fill { height:100%; border-radius:999px; background:linear-gradient(90deg,#111827,#6b7280); transform-origin:left; animation:ckgrow .8s cubic-bezier(.2,.8,.2,1) both; }
.ck-cbar-total { font-size:11px; color:var(--tx3); margin-top:8px; text-align:right; }
.ck-foot { font-size:11px; color:var(--tx3); padding:4px 4px 0; line-height:1.7; }
.ck-foot b { color:#374151; }
@media (max-width:900px){ .ck-herostats{grid-template-columns:1fr 1fr;} .ck-grid2{grid-template-columns:1fr;} .ck-orbit-legend{grid-template-columns:1fr 1fr;} }
/* =============================================================================
 * 連携ページ（データソース・ヘルス）
 * ========================================================================== */
.sy-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:14px; margin-top:14px; }
.sy-card { position:relative; background:#fff; border:1px solid rgba(15,23,42,.13); border-radius:12px; padding:16px 18px; overflow:hidden; animation:ckfade .45s ease both; }
.sy-card.warn { background:#fafaf9; }
.sy-card.error { background:#fff7f8; }
.sy-card.error::before { content:""; position:absolute; inset:0; border-radius:12px; pointer-events:none; box-shadow:inset 0 0 0 1px rgba(225,29,72,.25); animation:ckblink 1.6s linear infinite; }
.sy-card.off { opacity:.75; }
.sy-head { display:flex; align-items:center; gap:10px; margin-bottom:8px; }
.sy-dot { position:relative; width:10px; height:10px; border-radius:50%; flex-shrink:0; }
.sy-dot::after { content:""; position:absolute; inset:0; border-radius:50%; background:inherit; animation:ckping 1.8s cubic-bezier(0,0,.2,1) infinite; }
.sy-card.ok .sy-dot { background:#111827; }
.sy-card.warn .sy-dot { background:#9ca3af; }
.sy-card.error .sy-dot { background:#e11d48; }
.sy-card.off .sy-dot { background:#cbd5e1; } .sy-card.off .sy-dot::after { animation:none; }
.sy-name { font-weight:700; font-size:14px; color:#0f172a; flex:1; }
.sy-badge { font-size:10px; font-weight:700; letter-spacing:.08em; padding:3px 9px; border-radius:999px; }
.sy-card.ok .sy-badge { background:#f1f5f9; color:#111827; }
.sy-card.warn .sy-badge { background:#f1f5f9; color:#6b7280; }
.sy-card.error .sy-badge { background:#ffe4e6; color:#be123c; }
.sy-card.off .sy-badge { background:#e2e8f0; color:#64748b; }
.sy-meta { font-size:12px; color:#475569; line-height:1.8; }
.sy-meta b { color:#0f172a; font-variant-numeric:tabular-nums; }
.sy-bar { height:5px; border-radius:999px; background:#eef2f7; overflow:hidden; margin-top:10px; }
.sy-bar i { display:block; height:100%; border-radius:999px; transform-origin:left; animation:ckgrow .8s ease both; }
.sy-card.ok .sy-bar i { background:linear-gradient(90deg,#111827,#4b5563); }
.sy-card.warn .sy-bar i { background:linear-gradient(90deg,#9ca3af,#c7ccd3); }
.sy-card.error .sy-bar i { background:linear-gradient(90deg,#e11d48,#fb7185); }
.sy-alertbanner { display:flex; align-items:center; gap:10px; background:#fff1f2; border:1px solid #fecdd3; color:#be123c; border-radius:10px; padding:12px 16px; font-size:13px; font-weight:600; margin-top:14px; }
.sy-alertbanner .pd { width:9px; height:9px; border-radius:50%; background:#e11d48; position:relative; }
.sy-alertbanner .pd::after { content:""; position:absolute; inset:0; border-radius:50%; background:inherit; animation:ckping 1.4s infinite; }
.sy-okbanner { display:flex; align-items:center; gap:10px; background:#f8fafc; border:1px solid rgba(15,23,42,.13); color:#111827; border-radius:10px; padding:12px 16px; font-size:13px; font-weight:600; margin-top:14px; }
.sy-okbanner .pd { width:9px; height:9px; border-radius:50%; background:#111827; position:relative; }
.sy-okbanner .pd::after { content:""; position:absolute; inset:0; border-radius:50%; background:inherit; animation:ckping 1.8s infinite; }

/* Palantir風コーナーブラケット（外枠4隅） */
.ck-mc::before, .ck-mc::after, .ck-corner::before, .ck-corner::after { content:""; position:absolute; width:16px; height:16px; border-color:#111827; border-style:solid; opacity:.55; }
.ck-mc::before { top:-1px; left:-1px; border-width:2px 0 0 2px; }
.ck-mc::after { bottom:-1px; right:-1px; border-width:0 2px 2px 0; }
.ck-corner { position:absolute; inset:0; pointer-events:none; }
.ck-corner::before { top:-1px; right:-1px; border-width:2px 2px 0 0; }
.ck-corner::after { bottom:-1px; left:-1px; border-width:0 0 2px 2px; }
.ck-ptitle .meta { margin-left:auto; font-size:10px; color:var(--tx3); letter-spacing:.08em; display:flex; align-items:center; gap:6px; }
.ck-ptitle .meta .live { width:6px; height:6px; background:#111827; border-radius:50%; animation:ckblink 1.6s linear infinite; }
/* ============================================================
 * 連携 — DB中心アーキテクチャ図（データ供給フロー）
 * ============================================================ */
.sy-arch { background:#fff; border:1px solid rgba(15,23,42,.13); border-radius:2px; padding:0; margin-top:14px; position:relative; overflow:hidden; }
.sy-arch .ck-ptitle { border-radius:0; }
.sy-arch svg { display:block; width:100%; height:auto; }
.sy-flow { fill:none; stroke-width:1.6; stroke-dasharray:5 7; }
.sy-flow.ok { stroke:#111827; animation:syflow 1.05s linear infinite; }
.sy-flow.warn { stroke:#9ca3af; animation:syflow 2.4s linear infinite; }
.sy-flow.error { stroke:#e11d48; stroke-dasharray:3 6; animation:ckblink 1.1s linear infinite; }
.sy-flow.off { stroke:#cbd5e1; stroke-dasharray:2 7; }
@keyframes syflow { to { stroke-dashoffset:-12; } }
.sy-node rect { fill:#fff; stroke:#111827; stroke-width:1.1; }
.sy-node.warn rect { stroke:#9ca3af; }
.sy-node.error rect { stroke:#e11d48; fill:#fff5f6; }
.sy-node.error { animation:ckblink 1.4s linear infinite; }
.sy-node.off rect { stroke:#cbd5e1; stroke-dasharray:3 3; }
.sy-node text { fill:#0f172a; font-size:11px; font-weight:600; }
.sy-node .sub { fill:#64748b; font-size:9.5px; font-weight:400; }
.sy-node.error .sub { fill:#be123c; font-weight:600; }
.sy-node { cursor:pointer; }
.sy-hub rect { fill:#0b0f19; stroke:#0b0f19; }
.sy-hub text { fill:#fff; font-size:12px; font-weight:700; letter-spacing:.06em; }
.sy-hub .sub { fill:#94a3b8; font-size:9px; letter-spacing:.14em; }
.sy-hub .ring { fill:none; stroke:#111827; stroke-opacity:.25; animation:syring 2.6s ease-out infinite; transform-origin:center; transform-box:fill-box; }
@keyframes syring { 0%{transform:scale(.92);opacity:.7;} 100%{transform:scale(1.25);opacity:0;} }

/* =============================================================================
 * 分析ページ全体 — Palantirモジュール統一（モノトーン・アクセントバー無し）
 * ========================================================================== */
#analytics-wrap .card { border-radius:2px; border-color:rgba(15,23,42,.13); }
#analytics-wrap .card h2 {
  background:#f4f5f8; border-bottom:1px solid rgba(15,23,42,.13);
  margin:-18px -20px 12px; padding:8px 14px; font-size:12.5px; font-weight:700;
  letter-spacing:.04em; color:#0f172a; display:flex; align-items:center; gap:9px;
}
#analytics-wrap .card h2::before { content:""; width:7px; height:7px; background:#475569; flex-shrink:0; }
#analytics-wrap .kpis { gap:0; border:1px solid rgba(15,23,42,.13); border-radius:2px; background:#fff; overflow:hidden; }
#analytics-wrap .kpi { border:0; border-left:1px solid rgba(15,23,42,.08); border-radius:0; background:#fff; }
#analytics-wrap .kpi:first-child { border-left:0; }
#analytics-wrap .kpi .lbl { font-size:10px; letter-spacing:.1em; text-transform:uppercase; }
#analytics-wrap .kpi .dot { display:none; }
#analytics-wrap .scope-banner { background:#f8fafc; border-color:rgba(15,23,42,.13); color:#475569; border-radius:2px; }
#analytics-wrap .scope-banner b { color:#111827; }
#analytics-wrap .legend-note b { color:#374151; }
#analytics-wrap .toolbar input, #analytics-wrap .toolbar select { border-radius:2px; }
/* 分析ページ内のタグはモノトーン（赤=警告のみ維持） */
#analytics-wrap .n-tag { background:#f1f5f9; color:#111827; }
#analytics-wrap .n-tag.c-red { background:#ffe4e6; color:#be123c; }
#analytics-wrap .n-tag.status::before { background:#6b7280; }
.sy-pkt { fill:#111827; }
.sy-pkt.warn { fill:#9ca3af; }
.sy-arch #sync-arch { background:
  linear-gradient(rgba(15,23,42,.035) 1px, transparent 1px),
  linear-gradient(90deg, rgba(15,23,42,.035) 1px, transparent 1px);
  background-size:24px 24px; }
.ck-mc .sy-grid { margin-top:0; }
.ck-mc .sy-card { border-radius:2px; }
.sy-arch text.col { font-size:9px; font-weight:700; letter-spacing:.14em; fill:#9ca3af; text-transform:uppercase; font-family:ui-monospace,Menlo,monospace; }
.sy-node .sq { fill:#111827; }
.sy-node.warn .sq { fill:#9ca3af; }
.sy-node.error .sq { fill:#e11d48; animation:ckblink 1.1s steps(2,start) infinite; }
.sy-node.off .sq { fill:#d1d5db; }
.sy-brackets path { fill:none; stroke:#111827; stroke-width:1.5; opacity:.55; }
.ck-endtag { display:inline-block; margin-left:6px; font-size:11px; color:#6b7280; background:#f3f4f6; border:1px solid #e5e7eb; border-radius:2px; padding:0 5px; vertical-align:1px; }
/* ===== 確度定義・カバレッジ・AI分析 ===== */
.conf-table td { vertical-align:middle; }
.conf-chip { display:inline-block; min-width:64px; text-align:center; font-size:11px; font-weight:700; letter-spacing:.06em; padding:3px 8px; border-radius:2px; border:1px solid transparent; }
.conf-chip.t-paid { background:#111827; color:#fff; }
.conf-chip.t-locked { background:#1f2937; color:#fff; }
.conf-chip.t-a { background:#4b5563; color:#fff; }
.conf-chip.t-b { background:#9ca3af; color:#fff; }
.conf-chip.t-c { background:#e5e7eb; color:#374151; }
.cov-head { display:flex; align-items:baseline; gap:14px; margin-bottom:10px; flex-wrap:wrap; }
.cov-pct { font-size:13px; color:#374151; }
.cov-pct b { font-size:22px; font-weight:700; font-variant-numeric:tabular-nums; color:#111827; }
.cov-sub { font-size:12px; color:#6b7280; }
.cov-miss { color:#e11d48; }
.cov-scroll { overflow-x:auto; }
.cov-table { border-collapse:collapse; width:100%; font-size:12px; }
.cov-table th { text-align:center; font-size:10px; font-weight:600; letter-spacing:.08em; color:#6b7280; text-transform:uppercase; padding:6px 8px; border-bottom:1px solid var(--line2); white-space:nowrap; }
.cov-table th.cov-cl { text-align:left; }
.cov-table td { border-bottom:1px solid #f1f2f4; padding:0; }
.cov-table td.cov-cl { max-width:200px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; padding:7px 8px; font-weight:500; color:#111827; }
.cov-table td.cov-avg { padding:7px 8px; color:#6b7280; font-variant-numeric:tabular-nums; white-space:nowrap; }
.cov-cell { text-align:center; min-width:86px; cursor:pointer; transition:filter .12s; }
.cov-cell:hover { filter:brightness(.94); }
.cov-cell .amt { display:block; font-weight:600; font-variant-numeric:tabular-nums; padding:5px 6px 0; }
.cov-cell .tier { display:block; font-size:9px; letter-spacing:.08em; opacity:.75; padding:0 6px 5px; }
.cov-cell.t-paid { background:#111827; color:#fff; }
.cov-cell.t-locked { background:#374151; color:#fff; }
.cov-cell.t-a { background:#6b7280; color:#fff; }
.cov-cell.t-b { background:#d1d5db; color:#111827; }
.cov-cell.t-c { background:#f3f4f6; color:#374151; }
.cov-cell.t-miss { background:#fff; color:#e11d48; font-size:11px; font-weight:600; outline:1.5px dashed #fda4af; outline-offset:-3px; padding:10px 6px; }
.cov-cell.t-empty { color:#d1d5db; cursor:default; padding:10px 6px; }
.ai-stream { padding:4px 0 8px; min-height:120px; }

/* ===== AI REVIEW（広告運用プロ所見）読みやすい構造化表示＋事前スペース確保 ===== */
#ai-review-body { min-height:300px; transition:opacity .18s ease; }
#ai-review-body.air-updating { opacity:.4; pointer-events:none; }
.air { display:flex; flex-direction:column; gap:15px; animation:ckfade .35s ease both; }
.air-notice { display:inline-block; align-self:flex-start; font-size:11px; font-weight:600; color:#8a6500; background:#fff7e6; border:1px solid #f0dca8; border-radius:5px; padding:3px 9px; }
.air-summary { font-size:13.5px; font-weight:600; color:var(--tx1); line-height:1.75; padding:1px 0 11px; border-bottom:1px solid var(--line2); }
.air-sec { display:flex; flex-direction:column; gap:8px; }
/* セクション見出しは severity ごとに色分けしたピル（最優先=濃色／良い点=緑／注視=橙）で一目で区別 */
.air-sec-h { display:inline-flex; align-self:flex-start; align-items:center; gap:6px; font-size:11px; font-weight:700; letter-spacing:.02em; padding:3px 10px; border-radius:5px; }
.air-sev-act .air-sec-h { color:#fff; background:#111827; }
.air-sev-good .air-sec-h { color:#127a40; background:#e8f6ee; border:1px solid #bfe6cf; }
.air-sev-watch .air-sec-h { color:#9a6800; background:#fdf4e3; border:1px solid #f0dca8; }
/* 最優先：番号バッジ＋所見＋アクションボックス */
.air-item { display:flex; gap:10px; align-items:flex-start; }
.air-num { flex-shrink:0; width:20px; height:20px; border-radius:50%; background:#111827; color:#fff; font-size:11px; font-weight:700; display:flex; align-items:center; justify-content:center; margin-top:1px; }
.air-item-body { flex:1; min-width:0; }
.air-obs { font-size:13px; color:var(--tx1); line-height:1.65; font-weight:600; }
.air-act { margin-top:5px; background:#f4f5f8; border:1px solid var(--line2); border-radius:6px; padding:6px 9px; font-size:12.5px; color:var(--tx1); line-height:1.6; }
.air-act-l { display:inline-block; font-size:9.5px; font-weight:700; letter-spacing:.06em; color:#fff; background:#111827; border-radius:3px; padding:1px 6px; margin-right:7px; vertical-align:1px; }
/* 良い点/注視：ドット付きリスト */
.air-li { display:flex; gap:8px; align-items:flex-start; font-size:12.5px; line-height:1.65; color:var(--tx1); }
.air-li .air-dot { flex-shrink:0; width:6px; height:6px; border-radius:50%; background:#111827; margin-top:6px; }
.air-sev-good .air-dot { background:#1a8f4c; }
.air-sev-watch .air-dot { background:#c08a00; }
.air-obs2 { font-weight:500; }
.air-act-inline { color:var(--tx2); }
/* AIに質問: 右下のFAB（チャットボット起動ボタン）。基本は対象ページでのみ表示 */
.ai-fab { position:fixed; right:24px; bottom:24px; z-index:1900; display:none; align-items:center; gap:0; height:56px; padding:0; width:56px; border:none; border-radius:28px; background:linear-gradient(135deg,#1f2937,#111827); color:#fff; cursor:pointer; box-shadow:0 8px 24px rgba(17,24,39,.32); transition:width .25s cubic-bezier(.4,0,.2,1), transform .15s ease, box-shadow .2s ease; overflow:hidden; justify-content:center; }
.ai-fab.show { display:inline-flex; }
.ai-fab:hover { width:150px; transform:translateY(-2px); box-shadow:0 12px 30px rgba(17,24,39,.4); }
.ai-fab-ic { flex-shrink:0; }
.ai-fab-label { font-size:13px; font-weight:700; white-space:nowrap; max-width:0; opacity:0; overflow:hidden; transition:max-width .25s ease, opacity .2s ease, margin .25s ease; }
.ai-fab:hover .ai-fab-label { max-width:90px; opacity:1; margin-left:8px; margin-right:4px; }
.ai-fab.hidden-by-drawer { display:none !important; }
/* 軽いパルスで存在を知らせる（控えめ） */
.ai-fab::after { content:""; position:absolute; inset:0; border-radius:28px; box-shadow:0 0 0 0 rgba(17,24,39,.35); animation:aifabpulse 3.2s ease-out infinite; }
.ai-fab:hover::after { animation:none; }
@keyframes aifabpulse { 0%{box-shadow:0 0 0 0 rgba(17,24,39,.30)} 70%{box-shadow:0 0 0 14px rgba(17,24,39,0)} 100%{box-shadow:0 0 0 0 rgba(17,24,39,0)} }

/* AIに質問（右サイドパネル／ドロワー・基本は閉じ） */
.ai-drawer-overlay { position:fixed; inset:0; background:rgba(17,24,39,.22); z-index:2000; opacity:0; pointer-events:none; transition:opacity .2s ease; }
.ai-drawer-overlay.open { opacity:1; pointer-events:auto; }
.ai-drawer { position:fixed; top:0; right:0; height:100vh; width:min(440px,94vw); background:#fff; border-left:1px solid var(--line2); box-shadow:-10px 0 34px rgba(17,24,39,.16); transform:translateX(100%); transition:transform .26s cubic-bezier(.4,0,.2,1); z-index:2001; display:flex; flex-direction:column; }
.ai-drawer.open { transform:translateX(0); }
.ai-drawer-head { display:flex; align-items:center; justify-content:space-between; gap:10px; padding:14px 16px; border-bottom:1px solid var(--line2); flex-shrink:0; }
.ai-drawer-title { font-size:13px; font-weight:700; color:var(--tx1); letter-spacing:.02em; }
.ai-drawer-sub { font-size:11px; font-weight:500; color:var(--tx3); margin-left:8px; }
.ai-drawer-close { background:none; border:none; font-size:22px; line-height:1; color:var(--tx3); cursor:pointer; padding:0 4px; }
.ai-drawer-close:hover { color:var(--tx1); }
.ai-drawer-empty { font-size:12px; color:var(--tx3); line-height:1.8; padding:8px 2px; }
.air-qa-thread { flex:1; min-height:0; overflow-y:auto; display:flex; flex-direction:column; gap:12px; padding:16px; }
.air-qa-item { display:flex; flex-direction:column; gap:6px; }
.air-qa-q { align-self:flex-end; max-width:90%; background:#111827; color:#fff; font-size:12.5px; font-weight:600; line-height:1.6; padding:7px 11px; border-radius:10px 10px 2px 10px; }
.air-qa-a { font-size:13px; line-height:1.7; color:var(--tx1); background:#f7f8fa; border:1px solid var(--line2); border-radius:2px 10px 10px 10px; padding:10px 13px; }
.air-qa-a .air { gap:8px; }
/* Markdown表示（文字サイズはほぼ均一・過度な装飾なし・空行で読みやすく） */
.md-body { font-size:13px; line-height:1.8; color:var(--tx1); word-break:break-word; }
.md-body > *:first-child { margin-top:0; }
.md-body > *:last-child { margin-bottom:0; }
/* 見出しは本文と同サイズ＋太字のみ（大きくしない）。上に少し余白で区切る */
.md-body h1, .md-body h2, .md-body h3, .md-body h4 { font-size:13px; font-weight:700; line-height:1.6; margin:14px 0 4px; }
.md-body p { margin:9px 0; }
.md-body ul, .md-body ol { margin:9px 0; padding-left:20px; }
.md-body li { margin:4px 0; }
.md-body strong { font-weight:700; }
.md-body em { font-style:normal; }   /* 斜体は使わない（過度な装飾を避ける） */
.md-body code { background:#eceef2; border-radius:4px; padding:1px 5px; font-size:12px; font-family:ui-monospace,SFMono-Regular,Menlo,monospace; }
.md-body pre { background:#f4f5f8; color:var(--tx1); border:1px solid var(--line2); padding:10px 12px; border-radius:6px; overflow-x:auto; margin:9px 0; }
.md-body pre code { background:none; padding:0; font-size:12px; }
/* 表は横スクロールで崩さない（狭いパネルでも折り返さない） */
.md-tw { overflow-x:auto; margin:9px 0; -webkit-overflow-scrolling:touch; }
.md-body table { border-collapse:collapse; font-size:12.5px; }
.md-body th, .md-body td { border:1px solid var(--line2); padding:5px 9px; text-align:left; vertical-align:top; white-space:nowrap; }
.md-body th { background:#f4f5f8; font-weight:700; }
.md-body blockquote { border-left:3px solid var(--line2); margin:9px 0; padding:2px 0 2px 12px; color:var(--tx2); }
.md-body a { color:#2563eb; text-decoration:underline; }
.md-body hr { border:none; border-top:1px solid var(--line2); margin:12px 0; }
.air-qa-typing { color:var(--tx3); }
.air-qa-input { display:flex; gap:8px; padding:12px 16px; border-top:1px solid var(--line2); flex-shrink:0; }
.air-qa-input { align-items:flex-end; }
.air-qa-input input, .air-qa-input textarea { flex:1; min-width:0; font-size:12.5px; padding:9px 11px; border:1px solid var(--line2); border-radius:7px; background:#fff; color:var(--tx1); font-family:inherit; line-height:1.5; resize:none; max-height:120px; overflow-y:auto; }
.air-qa-input textarea { height:38px; }
.air-qa-input input:focus, .air-qa-input textarea:focus { outline:none; border-color:#111827; }
.air-qa-input button { flex-shrink:0; font-size:12px; font-weight:700; padding:9px 16px; border:none; border-radius:7px; background:#111827; color:#fff; cursor:pointer; }
.air-qa-input button:hover { background:#374151; }

/* スケルトン（生成中の事前スペース） */
.air-sk-bar { height:11px; border-radius:4px; background:linear-gradient(90deg,#eef0f4 25%,#e3e6ec 37%,#eef0f4 63%); background-size:400% 100%; animation:airshimmer 1.4s ease infinite; margin:4px 0; }
.air-act-sk { background:#f4f5f8; border:1px solid var(--line2); border-radius:6px; padding:5px 8px; margin-top:5px; }
@keyframes airshimmer { 0%{background-position:100% 0} 100%{background-position:0 0} }
.ai-line { display:flex; gap:8px; align-items:baseline; font-size:13px; line-height:1.8; color:#1f2937; animation:ckfade .3s ease both; }
.ai-marker { color:#9ca3af; flex:none; font-size:11px; }
.ai-cursor { display:inline-block; width:7px; height:14px; background:#111827; margin-left:2px; animation:ckblink .8s steps(2,start) infinite; vertical-align:-2px; }
.sy-arch text.ing { font-size:8.5px; fill:#9ca3af; font-family:ui-monospace,Menlo,monospace; letter-spacing:.04em; }
.sy-arch text.ing.error { fill:#e11d48; opacity:.7; }
.sy-chip rect { fill:#1f2937; stroke:#374151; stroke-width:.5; }
.sy-chip text { font-size:9px; font-weight:700; fill:#fff; font-family:ui-monospace,Menlo,monospace; }
.sy-chip text.jp { font-size:7.5px; font-weight:400; fill:#9ca3af; }
/* ===================================================================
   Linear.app 風ライトテーマ — 連携ページ (.lnp)
   tokens: text #282a30 / secondary #6b6f76 / tertiary #9ca0a8
           border #e9e9eb / hover #f8f9fa / accent #5e6ad2
           on-track #4cb782 / at-risk #f2c94c / off-track #eb5757 / none #bec2c8
   =================================================================== */
.lnp { font-family:"Inter","Inter Variable",-apple-system,BlinkMacSystemFont,"Segoe UI","Hiragino Sans","Noto Sans JP",sans-serif; letter-spacing:-0.01em; color:#282a30; animation:ckfade .3s ease both; }
.lnp-head { margin:4px 0 20px; }
.lnp-title-row { display:flex; align-items:baseline; gap:10px; }
.lnp-title { font-size:21px; font-weight:600; letter-spacing:-0.02em; color:#282a30; margin:0; }
.lnp-count { font-size:13px; color:#9ca0a8; font-weight:500; background:#f4f5f8; border-radius:6px; padding:1px 7px; }
.lnp-sub { font-size:13px; color:#6b6f76; margin-top:6px; line-height:1.6; }
/* メトリクスカード */
.lnp-metrics { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; margin-bottom:16px; }
.lnp-metric { background:#fff; border:1px solid #e9e9eb; border-radius:8px; padding:14px 16px; box-shadow:0 1px 1px rgba(0,0,0,.02); transition:border-color .15s; animation:ckfade .35s ease both; }
.lnp-metric:hover { border-color:#d0d3d9; }
.lnp-metric-lbl { display:flex; align-items:center; gap:7px; font-size:12px; font-weight:500; color:#6b6f76; }
.lnp-metric-val { font-size:24px; font-weight:600; letter-spacing:-0.02em; color:#282a30; margin-top:6px; font-variant-numeric:tabular-nums; }
.lnp-metric-val.alert { color:#eb5757; }
.lnp-metric-sub { font-size:12px; color:#9ca0a8; margin-top:3px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
/* ステータスドット（Linear project health） */
.lnp-dot { display:inline-block; width:9px; height:9px; border-radius:50%; flex:none; }
.lnp-dot.ok { background:#4cb782; }
.lnp-dot.warn { background:#f2c94c; }
.lnp-dot.error { background:#eb5757; animation:lnpulse 1.6s ease-in-out infinite; }
.lnp-dot.off { background:#bec2c8; }
@keyframes lnpulse { 0%,100%{ box-shadow:0 0 0 0 rgba(235,87,87,.35);} 50%{ box-shadow:0 0 0 5px rgba(235,87,87,0);} }
/* バナー */
.lnp-banner { display:flex; align-items:center; gap:9px; font-size:13px; font-weight:500; border-radius:8px; padding:10px 14px; margin-bottom:16px; border:1px solid; animation:ckfade .35s ease both; }
.lnp-banner.error { background:#fef5f5; border-color:#f8dcdc; color:#c64545; }
.lnp-banner.warn { background:#fdf9ee; border-color:#f3e8c8; color:#9a7b1d; }
.lnp-banner.ok { background:#f2faf6; border-color:#d5edE1; color:#34835d; }
/* カード */
.lnp-card { background:#fff; border:1px solid #e9e9eb; border-radius:8px; box-shadow:0 1px 1px rgba(0,0,0,.02); margin-bottom:16px; overflow:hidden; animation:ckfade .4s ease both; }
.lnp-card-head { display:flex; align-items:center; justify-content:space-between; padding:12px 16px; border-bottom:1px solid #f1f1f3; }
.lnp-card-title { font-size:13px; font-weight:600; color:#282a30; }
.lnp-card-meta { font-size:12px; color:#9ca0a8; }
.lnp-live { display:flex; align-items:center; gap:6px; font-size:12px; font-weight:500; color:#6b6f76; }
.lnp-livedot { width:7px; height:7px; border-radius:50%; background:#4cb782; animation:lnpulse2 2s ease-in-out infinite; }
@keyframes lnpulse2 { 0%,100%{opacity:1;} 50%{opacity:.45;} }
#sync-arch { padding:8px 12px 14px; }
/* フィード一覧（イシューリスト風の行） */
.lnp-list { padding:4px 0; }
.lnp-row { display:flex; align-items:center; gap:12px; padding:0 16px; height:46px; font-size:13px; border-radius:0; cursor:default; transition:background .12s; animation:ckfade .3s ease both; }
.lnp-row:hover { background:#f8f9fa; }
.lnp-row.flash { background:#eef0fb; }
.lnp-row-name { font-weight:500; color:#282a30; min-width:230px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.lnp-badge { font-size:11px; font-weight:500; border-radius:6px; padding:2px 8px; flex:none; }
.lnp-badge.ok { color:#34835d; background:#eef8f2; }
.lnp-badge.warn { color:#9a7b1d; background:#fbf4dd; }
.lnp-badge.error { color:#c64545; background:#fdeeee; }
.lnp-badge.off { color:#6b6f76; background:#f4f5f8; }
.lnp-row-meta { color:#6b6f76; font-variant-numeric:tabular-nums; white-space:nowrap; }
.lnp-row-meta .sep { margin:0 6px; color:#d0d3d9; }
.lnp-row-detail { color:#9ca0a8; font-size:12px; flex:1; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.lnp-fresh { width:90px; height:4px; border-radius:2px; background:#f1f1f3; flex:none; overflow:hidden; }
.lnp-fresh i { display:block; height:100%; border-radius:2px; background:#4cb782; }
.lnp-fresh i.warn { background:#f2c94c; }
.lnp-fresh i.error { background:#eb5757; }
.lnp-fresh i.off { background:#bec2c8; }
.lnp-foot { font-size:12px; color:#9ca0a8; line-height:1.7; padding:0 2px; }
/* アーキ図（SVG・Linear配色） */
.lnp svg { width:100%; height:auto; display:block; }
.lnp text.lncol { font-size:11px; font-weight:600; fill:#9ca0a8; letter-spacing:0; }
.lnp text.lning { font-size:9.5px; fill:#9ca0a8; }
.lnflow { fill:none; stroke:#d0d3d9; stroke-width:1.3; stroke-dasharray:4 4; }
.lnflow.ok { stroke:#c9cdd4; animation:lnflowmove 1.4s linear infinite; }
.lnflow.warn { stroke:#e9d9a0; animation:lnflowmove 3s linear infinite; }
.lnflow.error { stroke:#f0b9b9; animation:none; }
.lnflow.off { stroke:#e9e9eb; }
@keyframes lnflowmove { to { stroke-dashoffset:-16; } }
.lnpkt { fill:#6b6f76; }
.lnpkt.warn { fill:#d4af37; }
.lnpkt.accent { fill:#5e6ad2; }
.lnnode rect { fill:#fff; stroke:#e9e9eb; stroke-width:1.2; }
.lnnode[data-k] { cursor:pointer; }
.lnnode[data-k]:hover rect { stroke:#c9cdd4; }
.lnnode text { font-size:12.5px; font-weight:500; fill:#282a30; }
.lnnode text.sub { font-size:10px; font-weight:400; fill:#9ca0a8; }
.lnnode .dot { fill:#4cb782; }
.lnnode.warn .dot { fill:#f2c94c; }
.lnnode.error .dot { fill:#eb5757; }
.lnnode.error rect { stroke:#f0b9b9; }
.lnnode.off .dot { fill:#bec2c8; }
.lnnode.consumer rect { fill:#fbfbfc; }
.lnhub .halo { fill:none; stroke:#e4e6f5; stroke-width:1.5; }
.lnhub .card { fill:#fff; stroke:#d6d9f0; stroke-width:1.3; }
.lnhub .topbar { fill:#5e6ad2; }
.lnhub text { font-size:14px; font-weight:600; fill:#282a30; letter-spacing:-0.01em; }
.lnhub text.sub { font-size:10.5px; font-weight:400; fill:#9ca0a8; }
.lnchip rect { fill:#f4f5f8; stroke:#e9e9eb; stroke-width:1; }
.lnchip text { font-size:9.5px; font-weight:600; fill:#5e6ad2; font-family:ui-monospace,Menlo,monospace; }
.lnchip text.jp { font-size:7.5px; font-weight:400; fill:#9ca0a8; }
/* ===== Animated Beam (jolyui風) — 連携アーキ図 ===== */
.lnflow { stroke:#e6e7ea; stroke-width:1.6; stroke-dasharray:none; animation:none; }
.lnflow.ok { stroke:#e6e7ea; animation:none; }
.lnflow.warn { stroke:#f0e7c8; animation:none; }
.lnflow.error { stroke:#f0b9b9; stroke-dasharray:none; animation:lnerrfade 1.6s ease-in-out infinite; }
.lnflow.off { stroke:#eeeef0; stroke-dasharray:3 4; }
@keyframes lnerrfade { 0%,100%{ stroke-opacity:1; } 50%{ stroke-opacity:.35; } }
.lnbeam { fill:none; stroke-width:2; stroke-linecap:round; }
/* ===== 連携ページ モノトーン統一（SpaceX踏襲・Notion風・全体UIとフォント統一） ===== */
.lnp { font-family:inherit; letter-spacing:0; }
.lnp-title { font-size:20px; letter-spacing:-0.01em; }
.lnp-sub, .lnp-row, .lnp-card-title { font-size:13px; }
.lnp-metric-lbl { font-size:12px; }
.lnp-metric-val { font-size:22px; letter-spacing:-0.01em; }
/* ドット・バッジ・バー: モノトーン（意味色は赤=停止のみ） */
.lnp-dot.ok { background:#111827; }
.lnp-dot.warn { background:#9ca3af; }
.lnp-dot.error { background:#e11d48; }
.lnp-dot.off { background:#d1d5db; }
@keyframes lnpulse { 0%,100%{ box-shadow:0 0 0 0 rgba(225,29,72,.3);} 50%{ box-shadow:0 0 0 5px rgba(225,29,72,0);} }
.lnp-badge.ok { color:#1f2937; background:#f3f4f6; }
.lnp-badge.warn { color:#6b7280; background:#f3f4f6; }
.lnp-badge.error { color:#be123c; background:#fdf0f3; }
.lnp-fresh i { background:#111827; }
.lnp-fresh i.warn { background:#9ca3af; }
.lnp-fresh i.error { background:#e11d48; }
.lnp-banner.ok { background:#f8f9fa; border-color:#e9e9eb; color:#374151; }
.lnp-banner.warn { background:#f8f9fa; border-color:#e0e1e4; color:#6b7280; }
.lnp-banner.error { background:#fdf0f3; border-color:#f6d3dc; color:#be123c; }
.lnp-livedot { background:#111827; }
.lnp-metric-val.alert { color:#e11d48; }
/* アーキ図: 文字サイズ統一（本文13/サブ11/キャプション11） */
.lnp text.lncol { font-size:11px; font-weight:600; fill:#9ca0a8; letter-spacing:.04em; }
.lnp text.lning { font-size:10px; fill:#9ca0a8; }
.lnnode text { font-size:13px; font-weight:500; fill:#1f2937; }
.lnnode text.sub { font-size:11px; fill:#9ca0a8; }
.lnnode .dot { fill:#111827; }
.lnnode.warn .dot { fill:#9ca3af; }
.lnnode.error .dot { fill:#e11d48; }
.lnnode.off .dot { fill:#d1d5db; }
/* ハブ: SpaceX風の黒（アクセントバーなし） */
.lnhub .halo { stroke:#e5e7eb; }
.lnhub .card { fill:#111827; stroke:#111827; }
.lnhub text { font-size:14px; fill:#fff; }
.lnhub text.sub { font-size:10.5px; fill:#9ca3af; }
.lnchip rect { fill:#1f2937; stroke:#374151; }
.lnchip text { fill:#f9fafb; }
.lnchip text.jp { fill:#9ca3af; }
/* アーキ図の文字: SVG拡大率(viewBox960→実幅~1.2倍)を考慮し実効サイズを本文に合わせる */
.lnp text.lncol { font-size:9.5px; }
.lnp text.lning { font-size:8.5px; }
.lnnode text { font-size:11px; }
.lnnode text.sub { font-size:9px; }
.lnhub text { font-size:12px; }
.lnhub text.sub { font-size:9px; }
.lnchip text { font-size:8.5px; }
.lnchip text.jp { font-size:7px; }
/* アーキ図ミニマル化: 文字を半分・線を細く（SVG拡大率込みで実効6-7px） */
.lnp text.lncol { font-size:5.5px; letter-spacing:.08em; }
.lnp text.lning { font-size:4.5px; }
.lnnode text { font-size:6px; }
.lnnode text.sub { font-size:4.8px; }
.lnhub text { font-size:6.5px; letter-spacing:.02em; }
.lnhub text.sub { font-size:4.8px; }
.lnchip text { font-size:4.8px; }
.lnchip text.jp { font-size:3.8px; }
.lnnode rect { stroke-width:.8; }
.lnhub .card { stroke-width:.8; }
.lnhub .halo { stroke-width:.8; }
.lnchip rect { stroke-width:.5; }
.lnflow { stroke-width:.9; }
.lnbeam { stroke-width:1.3; }
#sync-arch { padding:6px 12px 12px; max-width:1060px; margin:0 auto; }
/* アーキ図: 文字サイズ中間値＋画面フィット調整 */
.lnp text.lncol { font-size:7.5px; }
.lnp text.lning { font-size:6.5px; }
.lnnode text { font-size:8.5px; }
.lnnode text.sub { font-size:6.8px; }
.lnhub text { font-size:9.5px; }
.lnhub text.sub { font-size:7px; }
.lnchip text { font-size:6.5px; }
.lnchip text.jp { font-size:5.2px; }
.lnnode rect { stroke-width:1; }
.lnflow { stroke-width:1.1; }
.lnbeam { stroke-width:1.6; }
#sync-arch { max-width:none; padding:6px 14px 14px; }
/* ===== UX修正: 税表記・⌘Kヒント・レスポンシブ強化 ===== */
.n-taxnote { font-size:10px; color:#9ca0a8; font-weight:400; margin:0 1px; }
.n-kbd { margin-left:auto; font-size:10px; color:#9ca0a8; border:1px solid #e5e7eb; border-radius:4px; padding:0 5px; line-height:16px; font-family:ui-monospace,Menlo,monospace; }
/* 狭幅（ノートPC半画面〜タブレット） */
@media (max-width:1100px){
  .lnp-metrics { grid-template-columns:repeat(2,1fr); }
  .kpis { grid-template-columns:repeat(2,1fr) !important; }
  #analytics-wrap .kpis { grid-template-columns:repeat(2,1fr) !important; }
  .ck-herostats { grid-template-columns:repeat(2,1fr) !important; }
  #sync-arch { overflow-x:auto; }
  #sync-arch svg { min-width:820px; }
  .lnp-row-detail { display:none; }
}
@media (max-width:760px){
  .lnp-metrics { grid-template-columns:1fr; }
  .kpis, #analytics-wrap .kpis { grid-template-columns:1fr !important; }
  .lnp-row-meta { display:none; }
  .cov-table td.cov-cl { max-width:120px; }
}
.cov-cell { min-width:64px; }
.cov-cell .amt { font-size:11px; }
.cov-clsub { display:block; font-size:10px; color:#9ca0a8; font-weight:400; }
/* カバレッジ: グルーピング・過去列・未登録 */
.cov-grouprow td { background:#f4f5f8; font-weight:600; color:#111827; padding:6px 8px !important; border-top:1px solid var(--line2); }
.cov-table td.cov-cl { padding-left:8px; }
.cov-grouprow + tr td.cov-cl, tr:not(.cov-grouprow) td.cov-cl { }
tbody tr:not(.cov-grouprow) td.cov-cl { padding-left:18px; }
.cov-pastcol, .cov-pastcell { opacity:.55; }
.cov-curcol { border-left:2px solid #111827; }
.cov-cell.t-open { color:#9ca0a8; cursor:pointer; font-size:14px; padding:8px 6px; }
.cov-cell.t-open:hover { background:#f4f5f8; color:#111827; }
.cov-nobudget { display:inline-block; margin-left:6px; font-size:9px; font-weight:700; color:#e11d48; background:#fdf0f3; border:1px solid #f6d3dc; border-radius:2px; padding:1px 5px; vertical-align:1px; }
.cov-uncov { font-size:12.5px; color:#9f1239; background:#fdf0f3; border:1px solid #f6d3dc; border-radius:4px; padding:10px 14px; margin-bottom:12px; line-height:1.7; }
.cov-uncov-list { display:flex; flex-wrap:wrap; gap:6px; margin-top:8px; }
.cov-uncov-item { background:#fff; border:1px solid #f0c7d2; border-radius:3px; padding:3px 9px; cursor:pointer; font-size:12px; color:#111827; transition:border-color .12s; }
.cov-uncov-item:hover { border-color:#e11d48; }
.cov-uncov-item i { font-style:normal; color:#9ca0a8; margin-left:6px; font-size:10.5px; }
/* 仕分けボタン・提案中パイプライン */
.cov-uncov-item { display:inline-flex; align-items:center; gap:8px; }
.cov-uncov-item .nm { cursor:pointer; color:#111827; font-weight:500; }
.cov-uncov-item .nm:hover { text-decoration:underline; }
.cov-uncov-item .acts { display:inline-flex; gap:4px; }
.cu-btn { font-size:11px; border:1px solid #111827; background:#111827; color:#fff; border-radius:3px; padding:2px 8px; cursor:pointer; }
.cu-btn:hover { opacity:.85; }
.cu-btn.ghost { background:#fff; color:#374151; border-color:#d1d5db; }
.cu-btn.ghost:hover { border-color:#6b7280; }
.cu-btn:disabled { opacity:.5; cursor:default; }
.cov-pipe { font-size:12.5px; color:#374151; background:#f8f9fa; border:1px solid #e9e9eb; border-radius:4px; padding:10px 14px; margin-bottom:12px; line-height:1.7; }
.cov-pipe-item { background:#fff; border:1px solid #e0e1e4; border-radius:3px; padding:3px 9px; cursor:pointer; font-size:12px; color:#111827; transition:border-color .12s; }
.cov-pipe-item:hover { border-color:#6b7280; }
.cov-pipe-item i { font-style:normal; color:#9ca0a8; margin-left:6px; font-size:10.5px; }
tbody tr:not(.cov-grouprow) td.cov-cl.cov-link { cursor:pointer; }
tbody tr:not(.cov-grouprow) td.cov-cl.cov-link:hover { color:#111827; text-decoration:underline; text-underline-offset:3px; background:#f8f9fa; }

/* ============================================================================
 * 請求設定（billing_settings）— 料率 / 係数の編集UI
 * ========================================================================== */
.bs-block { margin-top: 6px; }
.bs-block h3 { color: var(--nt-text); }
.bs-kv { display: flex; gap: 10px; padding: 4px 0; border-bottom: 1px solid var(--nt-line); font-size: 13px; }
.bs-kv .bs-k { width: 160px; flex: none; color: var(--nt-text-2); }
.bs-kv .bs-v { color: var(--nt-text); }
.bs-coef-table { width: 100%; border-collapse: collapse; font-size: 13px; margin-top: 4px; }
.bs-coef-table th, .bs-coef-table td { text-align: left; padding: 6px 10px; border-bottom: 1px solid var(--nt-line); }
.bs-coef-table th { color: var(--nt-text-2); font-weight: 600; }
.bs-coef-table td.num, .bs-coef-table th.num { text-align: right; font-variant-numeric: tabular-nums; }
.bs-coef-table tr.ck-total td { font-weight: 700; border-top: 2px solid var(--nt-line-2); }

/* モーダル */
.bs-modal-ov { position: fixed; inset: 0; background: rgba(15,23,42,.34); display: flex; align-items: flex-start; justify-content: center; z-index: 9000; padding: 48px 16px; overflow-y: auto; }
.bs-modal { background: #fff; border: 1px solid var(--nt-line-2); border-radius: 8px; width: 100%; max-width: 640px; box-shadow: 0 16px 48px rgba(15,23,42,.22); }
.bs-modal-head { display: flex; align-items: center; justify-content: space-between; padding: 14px 18px; border-bottom: 1px solid var(--nt-line); }
.bs-modal-head strong { font-size: 15px; color: var(--nt-text); }
.bs-modal-x { border: none; background: none; font-size: 22px; line-height: 1; cursor: pointer; color: var(--nt-text-2); }
.bs-modal-x:hover { color: var(--nt-text); }
.bs-modal-body { padding: 16px 18px; }
.bs-form-row { display: flex; align-items: center; gap: 10px; margin: 8px 0; }
.bs-form-row label { width: 200px; flex: none; font-size: 13px; color: var(--nt-text-2); }
.bs-form-row input, .bs-form-row select { flex: 1; padding: 6px 9px; border: 1px solid var(--nt-line-2); border-radius: 4px; font-size: 13px; background: #fff; color: var(--nt-text); }
.bs-modal-foot { margin-top: 14px; padding-top: 12px; border-top: 1px solid var(--nt-line); }
.bs-modal-err { display: none; background: #fef2f2; border: 1px solid #fecaca; color: #b91c1c; border-radius: 4px; padding: 8px 11px; font-size: 13px; margin-bottom: 10px; }

/* ============================================================================
 * 広告 運用ダッシュボード（ops-dash）— 運用担当者向け
 * ========================================================================== */
.ops-head { margin: 4px 0 10px; }
.ops-title { font-size: 17px; font-weight: 700; color: var(--nt-text); }
.ops-sub { font-size: 12.5px; color: var(--nt-text-2); margin-top: 2px; }
.ops-section-label { font-size: 12.5px; font-weight: 600; color: var(--nt-text-2); letter-spacing: .02em; }
/* 判定セル（色＋テキスト・色だけに頼らない） */
.ops-judge { display: inline-block; padding: 1px 8px; border-radius: 4px; font-size: 12px; font-weight: 600; white-space: nowrap; }
.ops-good { background: #ecfdf3; color: #15803d; }      /* 達成 */
.ops-bad  { background: #fef2f2; color: #b91c1c; }       /* 未達 / 超過 */
.ops-warn { background: #fffbeb; color: #b45309; }       /* 予算余り */
.ops-over { background: #fef2f2; color: #b91c1c; }       /* 予算超過 */
.ops-neutral { color: var(--nt-text-2); }
.ops-cell-good { color: #15803d; font-weight: 600; }
.ops-cell-bad  { color: #b91c1c; font-weight: 600; }
.ops-cell-warn { color: #b45309; font-weight: 600; }
/* 機会損失コールアウト */
.ops-oppo-row { display: flex; align-items: center; gap: 12px; padding: 9px 12px; border: 1px solid var(--nt-line); border-radius: 6px; margin-bottom: 7px; font-size: 13px; }
.ops-oppo-row.hi { border-color: #fdba74; background: #fff7ed; }
.ops-oppo-plat { font-weight: 600; color: var(--nt-text); min-width: 130px; }
.ops-oppo-msg { color: var(--nt-text); }
.ops-oppo-msg b { color: #c2410c; }
.ops-oppo-sub { margin-left: auto; color: var(--nt-text-2); font-size: 12px; white-space: nowrap; }
.ops-bdnote { color: var(--nt-text-2); }
#ops-summary-table tr.ops-total td { font-weight: 700; border-top: 2px solid var(--nt-line-2); }

/* ============================================================================
 * 広告 運用ゾーン 再設計（コントロールバー / AIアクション / 異常モニタ）
 * ========================================================================== */
.ops-control { align-items: center; flex-wrap: wrap; gap: 6px 8px; }
.ops-basis-pill { display: inline-block; padding: 2px 10px; border-radius: 999px; background: #eef2ff; color: #3730a3; font-size: 12px; font-weight: 600; margin-left: 8px; }
.ops-basis-note { font-size: 11.5px; color: var(--nt-text-2); margin: 2px 0 10px; }
/* AIネクストアクション（アクセントバー・色面は不使用。優先度は文字色のみで表現） */
.ops-ai-card { border: 1px solid var(--nt-line); }
.ops-ai-summary { background: #fff; border: 1px solid var(--nt-line); border-radius: 6px; padding: 10px 12px; font-size: 13.5px; color: var(--nt-text); margin: 4px 0 12px; line-height: 1.6; }
.ops-ai-summary b { color: var(--nt-text); }
.ops-ai-list { display: flex; flex-direction: column; gap: 8px; }
.ops-ai-item { display: flex; gap: 12px; align-items: flex-start; padding: 10px 12px; border: 1px solid var(--nt-line); border-radius: 6px; background: #fff; }
.ops-ai-item.p1, .ops-ai-item.p2, .ops-ai-item.p3, .ops-ai-item.p4 { border: 1px solid var(--nt-line); background: #fff; }
.ops-ai-pri { flex: none; min-width: 84px; }
.ops-ai-pbadge { display: inline-block; padding: 1px 8px; border-radius: 4px; font-size: 11.5px; font-weight: 700; border: 1px solid var(--nt-line); background: #fff; }
.ops-ai-pbadge.p1 { color: #b91c1c; }
.ops-ai-pbadge.p2 { color: #c2410c; }
.ops-ai-pbadge.p3 { color: #b45309; }
.ops-ai-pbadge.p4 { color: #15803d; }
.ops-ai-body { flex: 1; font-size: 13px; }
.ops-ai-plat { font-weight: 700; color: var(--nt-text); }
.ops-ai-diag { color: var(--nt-text-2); margin: 2px 0; }
.ops-ai-action { color: var(--nt-text); }
.ops-ai-action b { color: #1e293b; }
.ops-ai-future { color: #94a3b8; font-size: 11px; margin-top: 3px; }
/* 日次 異常モニタ */
#ops-anomaly-table tr.anom-bad td { background: #fef2f2; }
#ops-anomaly-table tr.anom-warn td { background: #fff7ed; }
.anom-flag { display: inline-block; padding: 1px 7px; border-radius: 4px; font-size: 11.5px; font-weight: 600; margin-right: 4px; }
.anom-flag.bad { background: #fee2e2; color: #b91c1c; }
.anom-flag.warn { background: #ffedd5; color: #c2410c; }

/* ===== メンバー管理 ===== */
.mem-add { display:flex; gap:8px; flex-wrap:wrap; align-items:center; margin:4px 0 16px; }
.mem-add input, .mem-add select, .mem-role, .mem-in-role { border:1px solid var(--nt-line-2); border-radius:8px; padding:8px 10px; font-size:13px; font-family:inherit; background:#fff; }
.mem-add .mem-in-mail { flex:1; min-width:240px; }
.mem-add .mem-in-name { width:160px; }
.mem-add-btn { border:1px solid var(--nt-text); background:var(--nt-text); color:#fff; border-radius:8px; padding:8px 14px; font-size:13px; font-weight:600; cursor:pointer; }
.mem-add-btn:hover { filter:brightness(1.2); }
.mem-list { display:flex; flex-direction:column; gap:8px; }
.mem-row { display:flex; align-items:center; gap:12px; padding:11px 14px; border:1px solid var(--nt-line); border-radius:10px; background:#fff; box-shadow:0 1px 2px rgba(15,23,42,.03); }
.mem-row.off { opacity:.55; }
.mem-av { width:32px; height:32px; flex-shrink:0; border-radius:50%; background:#eef3f8; color:#5a86b8; display:flex; align-items:center; justify-content:center; font-weight:700; font-size:13px; }
.mem-id { flex:1; min-width:0; }
.mem-name { font-size:14px; font-weight:600; color:var(--nt-text); }
.mem-off { font-size:10px; color:#fff; background:#9b9a97; border-radius:4px; padding:1px 6px; font-weight:600; }
.mem-mail { font-size:12px; color:var(--nt-text-3); }
.mem-role { min-width:280px; cursor:pointer; }
.mem-deact { border:1px solid var(--nt-line-2); background:#fff; color:var(--nt-text-2); border-radius:7px; padding:6px 12px; font-size:12px; cursor:pointer; }
.mem-deact:hover { background:#f7f7f5; border-color:#d23f3f; color:#d23f3f; }
.mem-grant { font-size:11px; color:var(--nt-text-3); }

.n-sidebar .n-foot #setpw-btn { margin-right:12px; color:var(--nt-text-2); }
