/* ============================================================
   components.css — UIパーツ（ボタン / ヘッダー / Explorer /
   ツールバー / コンテキストメニュー）
   色は theme.css の変数のみを参照します。
   ============================================================ */

/* ---- ボタン全般 ---- */
button,.file-button{
  border:1px solid var(--brand-tint-4);
  background:var(--button-bg);
  color:var(--brand-ink);
  border-radius:var(--btn-radius);padding:6px 10px;font-size:var(--btn-font);font-weight:var(--btn-weight);
  cursor:pointer;user-select:none;
  box-shadow:0 1px 0 rgba(124,58,237,.05);
  transition:var(--btn-transition);
}
button:hover,.file-button:hover{
  border-color:var(--brand-soft);
  background:var(--brand-tint-2);
  color:var(--brand-ink-strong);
}
button:disabled{opacity:var(--btn-disabled-op);cursor:not-allowed}

.primary{
  color:#fff!important;
  background:var(--button-primary-bg)!important;
  border-color:var(--brand)!important;
  box-shadow:0 7px 16px rgba(124,58,237,.25)!important;
}
.primary:hover{background:var(--button-primary-bg-hover)!important;color:#fff!important}

.danger{color:#fff;border-color:var(--danger);background:var(--danger)}
.danger:hover{color:#fff;background:var(--danger);border-color:var(--danger);filter:brightness(1.08)}

.ghost{border-color:transparent;background:transparent;box-shadow:none;color:var(--muted)}
.ghost:hover{background:var(--brand-tint-2);color:var(--brand-ink)}

.icon{display:inline-grid;place-items:center;width:32px;height:32px;padding:0}
.icon.toggle-on{
  background:var(--button-primary-bg);
  border-color:var(--brand);color:#fff;
  box-shadow:inset 0 2px 6px rgba(76,29,149,.28),0 5px 12px rgba(124,58,237,.2);
  transform:translateY(1px);
}
.icon.toggle-on:hover{background:var(--button-primary-bg-hover);color:#fff}

/* ヘッダーのドロップダウンメニュー（テーマ・言語切り替え）
   親の overflow:hidden に切られないよう position:fixed で表示し、
   座標は JS（main.js）でボタン位置から算出する。 */
.hdr-menu-wrap{position:relative;display:inline-flex}
.hdr-ic{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}
/* #17: F5/Ctrl+R 抑制トグル。
   既定（抑制ON）= active で「禁止スラッシュ」を表示する。
   解除（OFF）   = active なしでスラッシュを隠す。 */
#reloadGuardBtn .rg-slash{display:none}
#reloadGuardBtn.active .rg-slash{display:inline}
#reloadGuardBtn.active{color:var(--accent, #d97706)}
.hdr-menu{
  position:fixed;top:0;left:0;display:none;min-width:160px;padding:6px;z-index:9000;
  border:1px solid var(--border);border-radius:12px;background:var(--panel);
  box-shadow:var(--shadow-pop);
}
.hdr-menu.open{display:grid;grid-template-columns:1fr;gap:2px;animation:hdrMenuIn .14s ease}
/* アウトライン（目次）メニュー */
.outline-menu{min-width:220px;max-width:320px;max-height:60vh;overflow:auto}
.outline-item{
  text-align:left;padding:5px 8px;border:0;background:transparent;border-radius:6px;
  color:var(--text);font-size:13px;cursor:pointer;white-space:nowrap;overflow:hidden;
  text-overflow:ellipsis;
}
.outline-item:hover{background:var(--brand-tint-2);color:var(--brand-ink)}
.outline-item.lv1{font-weight:800}
.outline-item.lv2{padding-left:18px}
.outline-item.lv3{padding-left:30px;font-size:12.5px}
.outline-item.lv4{padding-left:42px;font-size:12px;color:var(--muted)}
.outline-item.lv5,.outline-item.lv6{padding-left:54px;font-size:12px;color:var(--muted)}
.outline-empty{padding:10px;color:var(--muted);font-size:13px;text-align:center}
@keyframes hdrMenuIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.hdr-menu-item{
  display:flex;align-items:center;gap:9px;width:100%;text-align:left;
  border:0;background:transparent;box-shadow:none;border-radius:8px;
  padding:0 10px;height:34px;font-size:13px;font-weight:600;color:var(--text);
}
.hdr-menu-item:hover{background:var(--brand-tint-2);color:var(--brand-ink)}
.hdr-menu-item.active{background:var(--brand-tint-3);color:var(--brand-ink);font-weight:800}
.hdr-menu-item .theme-dot{width:14px;height:14px;border-radius:50%;flex:none;border:1px solid rgba(0,0,0,.1)}
/* 言語コードバッジ（言語メニュー・言語ボタン） */
.lang-badge{
  flex:none;display:inline-grid;place-items:center;min-width:22px;height:18px;padding:0 4px;
  border-radius:5px;background:var(--brand-tint-3);color:var(--brand-ink-strong);
  font-size:11px;font-weight:800;letter-spacing:.02em;
}
.lang-btn-badge{min-width:24px;height:20px;font-size:12px}
#langMenuBtn{display:inline-grid;place-items:center}
/* テーマボタンの色玉 */
.theme-btn-dot{width:14px;height:14px;border-radius:50%;border:1px solid rgba(0,0,0,.15);display:inline-block;box-shadow:0 0 0 1px rgba(255,255,255,.15) inset}
#themeMenuBtn{display:inline-grid;place-items:center}
@media (prefers-reduced-motion: reduce){.hdr-menu.open{animation:none}}

/* ---- ヘッダー ---- */
header{
  display:flex;align-items:center;justify-content:space-between;
  gap:12px;min-height:50px;padding:8px 12px;
}
.title{display:flex;align-items:center;gap:11px}
.app-logo{width:40px;height:40px;border-radius:9px;flex:0 0 auto;display:block}
.title-text{min-width:0}
.title h1{margin:0;font-size:18px}
.title p{margin:2px 0 0;font-size:11px;color:var(--muted)}
.section-title,.explorer-title,.pane-head strong{
  font-family:var(--ui-font);font-size:13px;font-weight:800;color:var(--text);
}
.actions{display:flex;gap:6px;align-items:center;justify-content:flex-end;flex-wrap:wrap}
/* ヘッダーの Diff Viewer 起動ボタン（目立たせる・ブランド淡色） */
.hdr-launch{border-color:var(--brand-border)!important;background:var(--brand-tint-2)!important;color:var(--brand-ink)!important}
.hdr-launch::before{content:"";display:inline-block;width:13px;height:13px;margin-right:5px;vertical-align:-2px;background:currentColor;-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Crect x='3' y='4' width='8' height='16' rx='1.5'/%3E%3Crect x='13' y='4' width='8' height='16' rx='1.5'/%3E%3C/svg%3E") center/contain no-repeat;mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Crect x='3' y='4' width='8' height='16' rx='1.5'/%3E%3Crect x='13' y='4' width='8' height='16' rx='1.5'/%3E%3C/svg%3E") center/contain no-repeat}
.hdr-launch:hover{background:var(--brand-tint-3)!important}
.file-name{
  min-width:0;max-width:420px;overflow:hidden;text-overflow:ellipsis;
  white-space:nowrap;color:var(--muted);font-size:12px;font-weight:700;
}

.pane-title-wrap{min-width:0;display:flex;align-items:center;gap:8px}
.pane-title-wrap strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dirty-dot{display:none;color:var(--brand);font-size:13px;font-weight:900;line-height:1}
.dirty-dot.show{display:inline-flex}

/* ---- Explorer ---- */
.explorer{min-height:0;display:flex;flex-direction:column;overflow:hidden;container-type:inline-size}
.workspace-info{
  padding:7px 9px;border-bottom:1px solid var(--border);background:var(--panel);
  color:var(--muted);font-size:12px;line-height:1.45;word-break:break-all;
}
.workspace-info strong{display:block;color:var(--text);font-size:12px;margin-bottom:2px}
.workspace-info .folder-status{display:block}
.explorer-head{
  height:36px;display:flex;align-items:center;justify-content:space-between;
  padding:7px 8px;border-bottom:1px solid var(--border);background:var(--soft);
  font-size:13px;font-weight:800;
}
.explorer-title{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.explorer-actions{display:flex;gap:4px;flex:0 0 auto}
.explorer-actions button{width:28px;height:26px;padding:0}
/* エクスプローラーが狭いときは段階的にアイコンを減らす（まず「取消」「やり直し」を隠して残り5個を確保） */
@container (max-width: 252px){
  .explorer-actions #fsUndoBtn,.explorer-actions #fsRedoBtn{display:none}
}

.tree{flex:1;min-height:0;overflow:auto;padding:8px;font-size:13px}
.tree-row{
  display:flex;align-items:center;gap:6px;width:100%;border:0;background:transparent;
  box-shadow:none;border-radius:8px;text-align:left;padding:5px 6px;
  color:var(--text);font-weight:500;white-space:nowrap;
}
.tree-row:hover{background:var(--brand-tint-2);color:var(--brand-ink)}
.tree-row.active{background:var(--brand-tint-3);color:var(--brand-ink);font-weight:800}
.tree-row.selected{background:var(--brand-tint-4);color:var(--brand-ink-strong);font-weight:800}
.tree-row.drop-target{outline:2px dashed var(--brand-soft);background:var(--brand-tint-1);color:var(--brand-ink)}
.tree-row.dir{font-weight:700}
/* 開ける上限サイズを超えるファイル：少し薄くして「開けない（けど名前変更・コピー・削除等は可能）」を示す。
   cursor:not-allowed は「メニュー操作も不可」と誤解されやすいので使わない。 */
.tree-row.tree-row-toolarge{opacity:.6}
/* 選択中・アクティブの容量超過ファイルは選択色がはっきり見えるよう不透明度を上げ、
   かつ hover での透明化（下行）の対象外にして選択ハイライトを維持する */
.tree-row.tree-row-toolarge.selected,.tree-row.tree-row-toolarge.active{opacity:.92}
.tree-row.tree-row-toolarge:hover:not(.selected):not(.active){background:transparent;color:inherit}
.indent{display:inline-block;width:calc(var(--depth,0)*14px);flex:none}
.tree-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.tree-rename-input{flex:1;min-width:0;font:inherit;line-height:1.2;color:var(--text);background:var(--surface);border:1px solid var(--brand);border-radius:4px;padding:1px 5px;margin:-2px 0;outline:none}
/* ツリーのLint状態マーク（警告=黄, エラー=赤）。ファイル名の右に表示 */
.lint-mark{flex:none;display:inline-grid;place-items:center;width:15px;height:15px}
.lint-mark svg{width:13px;height:13px}
.lint-mark.warning svg{fill:var(--warn)}
.lint-mark.error svg{fill:var(--danger)}
.lint-mark.unscanned{color:var(--muted);opacity:.7}
.tree-ic{width:15px;height:15px;flex:none;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;opacity:.75}
.tree-row.dir .tree-ic{fill:var(--brand-tint-3);stroke:var(--brand-soft);opacity:.95}

/* 開閉トグル（▼/▶）。折りたたみ時は -90度回転して右向きに */
.twisty{
  flex:none;display:inline-grid;place-items:center;width:16px;height:16px;
  color:var(--brand-ink);transition:transform .18s ease;
  transform:rotate(90deg); /* 既定（展開時）は下向き */
}
.twisty svg{width:11px;height:11px;fill:currentColor}
.twisty.collapsed{transform:rotate(0deg)} /* 折りたたみ時は右向き */
.twisty-leaf{visibility:hidden}

/* 行の登場アニメ（展開時にフェードインしながら少し下から、なめらかに） */
@keyframes treeRowEnter{
  from{opacity:0;transform:translateY(-6px);max-height:0}
  to{opacity:1;transform:translateY(0);max-height:40px}
}
.tree-row-enter{animation:treeRowEnter .22s cubic-bezier(.22,.61,.36,1) both}
/* 行の退場アニメ（折りたたみ時にフェードアウトしながら上へ） */
@keyframes treeRowLeave{
  from{opacity:1;transform:translateY(0);max-height:40px}
  to{opacity:0;transform:translateY(-6px);max-height:0}
}
.tree-row-leave{animation:treeRowLeave .16s cubic-bezier(.4,0,.7,.4) both;pointer-events:none;overflow:hidden}
@media (prefers-reduced-motion: reduce){
  .twisty{transition:none}
  .tree-row-enter,.tree-row-leave{animation:none}
}

.empty{color:var(--muted);padding:10px;line-height:1.6}
.empty button{margin-top:8px;width:100%;justify-content:center}
.browser-note{display:block;margin-top:8px;color:var(--warn);font-size:12px;line-height:1.55}

/* ---- Explorer折りたたみ時のレール ---- */
.explorer-hidden .explorer{
  padding:0;align-items:center;justify-content:center;
  background:var(--panel-translucent);
  border:1px solid var(--border-strong);
  border-radius:var(--radius);box-shadow:var(--shadow);
}
/* 通常時：中身は表示。畳み/開き時に opacity でフェードする */
.explorer-head,
.workspace-info,
.tree{
  opacity:1;
  transition:opacity .16s ease;
}
/* 畳み中は素早くフェードアウト（幅が縮む前に消えて、崩れが見えないように） */
.explorer-hidden .explorer-head,
.explorer-hidden .workspace-info,
.explorer-hidden .tree{
  opacity:0;visibility:hidden;pointer-events:none;
  white-space:nowrap;overflow:hidden;
  transition:opacity .1s ease,visibility 0s linear .1s;
}
@media (prefers-reduced-motion: reduce){
  .explorer-head,.workspace-info,.tree{transition:none}
}

.rail-button{
  display:none;place-items:center;width:32px;height:88px;border-radius:999px;
  padding:0;background:var(--brand-tint-1);border:1px solid var(--brand-tint-4);
  color:var(--brand-strong);box-shadow:none;white-space:nowrap;
}
.explorer-hidden #showExplorerRail{display:grid}
.preview-hidden #showPreviewRail{display:grid}
.workspace.explorer-hidden .explorer,.main.preview-hidden .preview-pane{position:relative}
.workspace.explorer-hidden #showExplorerRail,
.main.preview-hidden #showPreviewRail{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%)}

/* ---- ペインヘッダー / ツールバー ---- */
.pane-head{
  height:36px;display:flex;align-items:center;justify-content:space-between;
  padding:8px 10px;border-bottom:1px solid var(--border);background:var(--soft);
}
.pane-tools{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted)}
.pane-tools .icon{width:28px;height:28px;border-radius:8px}

.toolbar{
  min-height:39px;display:flex;align-items:center;flex-wrap:wrap;gap:3px 4px;
  padding:5px 7px;border-bottom:1px solid var(--border);background:var(--panel);
  overflow:visible;white-space:normal;position:relative;z-index:3;
}
.tool,.tool-menu-toggle{
  display:inline-flex;align-items:center;justify-content:center;
  border:0;background:transparent;box-shadow:none;width:32px;height:30px;min-width:32px;
  padding:0;color:var(--muted);border-radius:8px;
  transition:background .14s ease,color .14s ease,transform .1s ease;
}
.tool:hover,.tool-menu-toggle:hover{background:var(--brand-tint-2);color:var(--brand-ink)}
.tool:active,.tool-menu-toggle:active{transform:translateY(1px)}
.tool:disabled,.tool-menu-toggle:disabled{opacity:var(--btn-disabled-op);cursor:not-allowed;background:transparent;color:var(--muted)}
.tool.wide{width:auto;padding:0 8px}

/* ツールバーアイコン（SVG線画）。色は currentColor で文字色に追従 */
.ti{width:19px;height:19px;display:block;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}
.ti-t{font-size:9px;font-weight:800;fill:currentColor;stroke:none;font-family:var(--ui-font)}
.ti-t2{font-size:7px;font-weight:800;fill:currentColor;stroke:none;font-family:var(--ui-font)}

.tool-group{position:relative;display:inline-flex;align-items:center}
.tool-menu-toggle{border-radius:8px;width:auto;min-width:34px;padding:0 4px}
.tool-menu-toggle::after{content:"▾";font-size:9px;margin-left:1px;color:var(--muted)}
.tool-menu{
  position:absolute;top:34px;left:0;display:none;min-width:150px;padding:6px;
  border:1px solid var(--border);border-radius:12px;background:var(--panel);
  box-shadow:var(--shadow-pop);z-index:30;
}
.tool-group.open .tool-menu{display:grid;grid-template-columns:1fr;gap:2px}
/* メニュー内はアイコン＋ラベルの横並び */
.tool-menu .tool{
  width:100%;justify-content:flex-start;text-align:left;border-radius:8px;
  padding:0 10px;height:32px;gap:9px;font-size:13px;font-weight:600;color:var(--text);
}
.tool-menu .tool:hover{background:var(--brand-tint-2);color:var(--brand-ink)}
.tool-menu .mi{display:inline-flex;align-items:center;justify-content:center;width:20px;flex:none;color:var(--muted)}
.tool-menu .tool:hover .mi{color:var(--brand-ink)}
.sep{width:1px;height:20px;background:var(--border);margin:0 5px;flex:none}

/* ---- コンテキストメニュー ---- */
.context-menu{
  position:fixed;z-index:60;min-width:170px;padding:6px;
  border:1px solid var(--brand-tint-4);border-radius:12px;
  background:var(--panel);box-shadow:var(--shadow-pop);
}
.context-menu[hidden]{display:none}
.context-menu button{
  display:flex;width:100%;align-items:center;gap:8px;border:0;background:transparent;
  box-shadow:none;border-radius:8px;padding:8px 10px;color:var(--text);
  font-weight:700;text-align:left;
}
.context-menu button:hover{background:var(--brand-tint-2);color:var(--brand-ink)}
.context-menu button:disabled{opacity:var(--btn-disabled-op);cursor:not-allowed;background:transparent;color:var(--muted)}
.context-menu button.danger{color:var(--danger)}
.context-menu button.danger:hover{background:var(--danger-tint-2);color:var(--danger)}

/* ===== トースト通知（検索・置換などの一時メッセージ） ===== */
.toast{
  position:fixed;top:64px;left:50%;transform:translateX(-50%) translateY(-12px);
  z-index:9999;padding:10px 18px;border-radius:10px;
  /* テーマによって --brand-ink-strong がほぼ白の場合があり、白文字が読めなく
     なるため、トーストはテーマに依存しない固定の濃い配色にする。 */
  background:#1e293b;color:#fff;font-size:13px;font-weight:700;
  border:1px solid rgba(255,255,255,.12);
  box-shadow:0 8px 24px rgba(15,23,42,.35);
  opacity:0;pointer-events:none;transition:opacity .2s ease,transform .2s ease;
  max-width:80vw;text-align:center;
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.toast-error{background:var(--danger)}
@media (prefers-reduced-motion: reduce){.toast{transition:none}}

/* 全エラー共通：画面上部から下へスライドインする警告カード */
.app-error{
  position:fixed;top:14px;left:50%;transform:translateX(-50%) translateY(-180%);
  margin:0;z-index:10000;display:flex;align-items:center;gap:10px;
  min-width:260px;max-width:min(92vw,520px);padding:12px 14px;
  border:1px solid rgba(0,0,0,.12);border-left:5px solid var(--banner-error-border);border-radius:12px;
  background:var(--banner-error-bg);color:var(--banner-error-fg);box-shadow:0 14px 36px rgba(127,29,29,.4);
  font-size:13px;font-weight:700;opacity:0;
  transition:transform .28s cubic-bezier(.2,.8,.2,1),opacity .2s ease;
}
.app-error.show{transform:translateX(-50%) translateY(0);opacity:1}
.app-error.warn{background:var(--banner-warn-bg);color:var(--banner-warn-fg);border-left-color:var(--banner-warn-border);box-shadow:0 14px 36px rgba(180,83,9,.38)}
.app-error.warn .app-error-x,.app-error.warn .app-error-action{color:var(--banner-warn-fg)}
.app-error.warn .app-error-x:hover{background:rgba(0,0,0,.12)}
.app-error.info{background:var(--banner-info-bg);color:var(--banner-info-fg);border-left-color:var(--banner-info-border);box-shadow:0 14px 36px rgba(37,99,235,.38)}
.app-error.info .app-error-x{color:var(--banner-info-fg)}
.app-error.info .app-error-x:hover{background:rgba(255,255,255,.18)}
.app-error::backdrop{background:transparent}
.app-error-ic{flex:none;font-size:16px;line-height:1}
.app-error-msg{flex:1 1 auto;line-height:1.45;text-align:left}
.app-error-action{flex:none;display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border:1px solid currentColor;background:rgba(255,255,255,.16);color:inherit;cursor:pointer;font-size:12px;font-weight:700;line-height:1;border-radius:var(--btn-radius-sm);white-space:nowrap}
.app-error-action:hover{background:rgba(255,255,255,.28)}
.app-error-action[hidden]{display:none}
.app-error-x{flex:none;display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;border:0;background:transparent;color:#fff;cursor:pointer;font-size:13px;line-height:1;opacity:.85;border-radius:var(--btn-radius-sm)}
.app-error-x:hover{background:rgba(255,255,255,.18);opacity:1}
@media (prefers-reduced-motion: reduce){.app-error{transition:opacity .2s ease}}

/* 削除（ゴミ箱）の赤をトーンダウン：ベタ赤の背景をやめ、淡い赤＋赤アイコンに */
.tree-action{background:transparent;border-color:transparent;color:var(--text)}
.tree-action:hover{background:var(--brand-tint-2);border-color:transparent}
.tree-action.danger{background:transparent;border-color:transparent;color:var(--danger)}
.tree-action.danger:hover{background:var(--danger-tint-2);border-color:transparent;color:var(--danger)}
.context-menu button.danger{color:var(--danger);background:transparent}
.context-menu button.danger:hover{background:var(--brand-tint-2);color:var(--danger)}

/* バグ3: コンテキストメニューの仕切り線 */
.context-menu .ctx-sep{height:1px;margin:4px 6px;background:var(--border)}
.context-menu .ctx-key{margin-left:auto;padding-left:16px;font-size:11px;font-weight:600;color:var(--muted);opacity:.8;white-space:nowrap}

/* エディター右クリックのコンテキストメニュー */
.ctx-menu[hidden]{display:none}
.ctx-menu{position:fixed;z-index:200;min-width:210px;max-width:320px;max-height:70vh;overflow:auto;padding:6px;
  border:1px solid var(--border);border-radius:12px;background:var(--panel);box-shadow:var(--shadow-pop)}
.ctx-menu .ctx-item{display:flex;align-items:center;gap:8px;width:100%;text-align:left;justify-content:flex-start;
  border:0;background:transparent;color:var(--text);font-size:13px;font-weight:600;padding:0 10px;height:32px;
  border-radius:8px;cursor:pointer}
.ctx-menu .ctx-item:hover{background:var(--brand-tint-2);color:var(--brand-ink)}
.ctx-menu .ctx-ic{flex:none;width:18px;text-align:center;font-size:14px;line-height:1}
.ctx-menu .ctx-label{flex:1 1 auto;min-width:0}
.ctx-menu .ctx-item.ctx-disabled,.ctx-menu .ctx-item:disabled{opacity:var(--btn-disabled-op);cursor:default;background:transparent;color:var(--muted)}
.ctx-sep{height:1px;margin:5px 6px;background:var(--brand-tint-3)}
.ctx-head{padding:4px 10px 2px;font-size:11px;font-weight:700;color:var(--muted)}
.ctx-empty{padding:4px 10px 6px;font-size:12px;color:var(--muted)}
.ctx-snips{display:flex;flex-direction:column;gap:1px}
.ctx-snip-row{display:flex;align-items:center;gap:2px}
.ctx-star{flex:none;display:inline-flex;align-items:center;justify-content:center;width:22px;height:24px;padding:0;border:0;background:transparent;cursor:pointer;font-size:12px;line-height:1;color:var(--muted);border-radius:var(--btn-radius-sm)}
.ctx-star:hover{background:var(--brand-tint-2)}
.ctx-star.on{color:#f5a623}
.ctx-snip{flex:1 1 auto;min-width:0}
.ctx-snip .ctx-genre{margin-left:auto;padding-left:8px;font-size:10px;font-weight:700;color:var(--muted);white-space:nowrap}
.snip-preview{max-height:120px;overflow:auto;margin:0;padding:8px 10px;border:1px solid var(--border);border-radius:8px;
  background:var(--brand-tint-1);font-size:12px;white-space:pre-wrap;word-break:break-word;color:var(--text)}

/* 設定画面：テンプレート一覧 */
.tpl-manage-head{display:flex;align-items:center;justify-content:space-between;gap:8px}
.tpl-manage-head h4{margin:0;font-size:13px}
.tpl-list{display:flex;flex-direction:column;gap:4px;margin-top:6px;max-height:240px;overflow-y:auto;padding-right:2px}
.tpl-list-foot{margin-top:8px}
/* .set-divider は dialog.css に一本化（旧: ここで margin:18px 0 4px に二重定義していた） */
.tpl-row{display:flex;align-items:center;gap:6px;padding:4px 6px;border:1px solid var(--border);border-radius:8px}
.tpl-row-info{flex:1 1 auto;min-width:0;display:flex;align-items:center;gap:8px}
.tpl-row-name{font-weight:700;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tpl-row-genre{font-size:10px;font-weight:700;color:var(--muted);background:var(--brand-tint-1);padding:1px 7px;border-radius:999px;white-space:nowrap;max-width:120px;overflow:hidden;text-overflow:ellipsis;flex:0 1 auto}
.tpl-row button{white-space:nowrap;flex:0 0 auto}
.snip-body-block{display:flex;flex-direction:column;gap:6px;margin-top:10px}
.snip-body-block > span{color:var(--muted);font-size:13px}
.snip-body{width:100%;resize:vertical;font-family:inherit;font-size:13px;line-height:1.5;padding:8px 10px;border:1px solid var(--border);border-radius:8px;background:var(--field);color:var(--text)}
button.small,.small{height:28px;padding:0 10px;font-size:var(--btn-font-sm);border-radius:var(--btn-radius-sm)}
.tpl-row .danger{background:transparent;border:1px solid transparent;color:var(--danger)}
.tpl-row .danger:hover{background:var(--danger-tint-2);color:var(--danger)}

/* テンプレ一覧：並び替えトグルとD&D */
.tpl-sort{display:flex;align-items:center;gap:6px;margin:8px 0 2px}
.tpl-sort-label{font-size:11px;color:var(--muted);margin-right:2px}
.tpl-sort button{height:26px;padding:0 12px;font-size:12px;font-weight:700;border:1px solid var(--border);border-radius:999px;background:transparent;color:var(--muted);cursor:pointer}
.tpl-sort button:hover{background:var(--brand-tint-2)}
.tpl-sort button.active{background:var(--brand);border-color:var(--brand);color:#fff}
.tpl-row.draggable{cursor:grab}
.tpl-row.draggable .tpl-drag-handle{flex:none;width:18px;text-align:center;color:var(--muted);cursor:grab;font-size:13px;user-select:none}
.tpl-row.dragging{opacity:.5}
.tpl-row.drop-before{box-shadow:0 -2px 0 0 var(--brand)}
.tpl-row.drop-after{box-shadow:0 2px 0 0 var(--brand)}

/* 右クリック挿入メニューのサブメニュー（横展開） */
.ctx-submenu-trigger{display:flex;align-items:center;gap:8px;width:100%}
.ctx-submenu-trigger .ctx-arrow{margin-left:auto;color:var(--muted);font-size:12px}
.ctx-submenu{min-width:200px;max-width:300px}
.ctx-pager{display:flex;align-items:center;justify-content:center;gap:10px;padding:6px 4px 2px;margin-top:4px;border-top:1px solid var(--brand-tint-3)}
.ctx-page-btn{width:28px;height:26px;border:0;background:transparent;border-radius:6px;cursor:pointer;color:var(--text);font-size:var(--btn-font-sm)}
.ctx-page-btn:hover:not(:disabled){background:var(--brand-tint-2)}
.ctx-page-btn:disabled{opacity:var(--btn-disabled-op);cursor:default}
.ctx-page-lbl{font-size:11px;color:var(--muted);min-width:46px;text-align:center}

/* サブ設定を開くボタン（インデント/新規ファイル/MDS/標準Lint を共通の見た目に統一） */
.sub-open{display:inline-flex;align-items:center;gap:7px;margin-top:8px}
.sub-open::after{content:"\203A";font-size:15px;line-height:1;color:var(--muted);margin-left:2px}
.sub-open:hover::after{color:var(--brand-ink-strong)}

/* WS設定ロックバー（設定→ワークスペース節の冒頭） */
.ws-lock-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  margin: 0 0 12px;
  border: 1px solid var(--warn);
  border-radius: var(--btn-radius);
  background: rgba(245, 158, 11, 0.08);
  color: var(--text);
  font-size: 13px;
  line-height: 1.5;
}
.ws-lock-bar-icon { font-size: 18px; line-height: 1; flex: 0 0 auto; }
.ws-lock-bar-text { flex: 1 1 auto; }
.ws-lock-bar.unlocked { border-color: var(--brand); background: rgba(124, 58, 237, 0.08); }
.ws-lock-toggle {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  font-size: 12px;
  border: 1px solid var(--border);
  border-radius: var(--btn-radius);
  background: var(--soft);
  color: var(--text);
  cursor: pointer;
  transition: background .15s, border-color .15s;
}
.ws-lock-toggle:hover { background: var(--surface); border-color: var(--brand); }
.ws-lock-toggle.unlocked { background: rgba(124, 58, 237, 0.12); border-color: var(--brand); }
.ws-lock-icon { font-size: 14px; line-height: 1; }
.ws-lock-label { font-weight: 600; }

/* 個人設定エクスポート／インポート */
.personal-io-group { margin-top: 4px; }
.personal-io-head { margin: 0 0 6px; font-size: 14px; font-weight: 600; }
.personal-io-actions { gap: 8px; flex-wrap: wrap; }

/* プレビューヘッダー左側（Preview＋ファイルパス） */
.pane-head .ph-left{display:flex;align-items:center;gap:8px;min-width:0;overflow:hidden}
.pane-head .ph-left .pwb-path{color:var(--muted);font-size:12px;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}

/* ============================================================
   Stellia 共通リストボックス（select → カスタムドロップダウン）
   ネイティブ select は隠し、JS（SME.styleSelect）が作る
   .ss-trigger（現在値＋▼）と .ss-panel（候補リスト）で見せる。
   候補リストも div なので、ホバー・選択色までテーマに追従する。
   ============================================================ */
.ss-wrap{position:relative;display:inline-block;width:100%;min-width:0}
.ss-wrap > select{position:absolute;width:1px;height:1px;padding:0;margin:0;opacity:0;pointer-events:none;border:0}
.ss-trigger{
  display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;
  font:inherit;font-size:13px;color:var(--text);background:var(--surface);
  border:1px solid var(--border);border-radius:8px;padding:6px 10px;min-height:36px;
  box-sizing:border-box;cursor:pointer;text-align:left;
}
.ss-trigger:hover{border-color:var(--brand)}
.ss-trigger.open{border-color:var(--brand);box-shadow:0 0 0 2px var(--brand-tint-2)}
.ss-trigger:disabled{opacity:.5;cursor:default}
.ss-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1 1 auto;min-width:0}
.ss-arrow{flex:0 0 auto;color:var(--muted);font-size:18px;line-height:1;transition:transform .15s ease}
.ss-trigger.open .ss-arrow{transform:rotate(180deg)}
.ss-panel{
  position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:1200;
  max-height:260px;overflow:auto;
  background:var(--surface);border:1px solid var(--border);border-radius:8px;
  box-shadow:var(--shadow-pop);padding:4px;
}
.ss-option{
  padding:7px 10px;border-radius:6px;font-size:13px;color:var(--text);cursor:pointer;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.ss-option:hover{background:var(--brand-tint-2)}
.ss-option.current{background:var(--brand-tint-3);color:var(--text);font-weight:700}

/* カスタムドロップダウンのラッパーに、各文脈のレイアウト（幅・flex）を引き継ぐ */
.grid .ss-wrap{width:100%}
.grid .ss-trigger{min-height:36px}
.grep-panel .ss-wrap{flex:1 1 auto;min-width:0}
.grep-panel .ss-trigger{min-height:32px}
.grep-scope-row .ss-wrap{flex:0 0 auto;width:auto;min-width:120px}
.subpage-dialog .ss-trigger{height:34px;min-height:0}
.compact-dialog .indent-default-row .ss-wrap{flex:1;width:auto;min-width:0}
.indent-default-row .ss-wrap{width:150px}
.newfile-row .ss-wrap{width:100%}
.trash-loc-row .ss-wrap{width:100%}
.inline .ss-wrap{width:auto;min-width:180px;flex:1 1 auto}

/* ============================================================
   検索履歴のカスタムドロップダウン（入力欄の履歴リスト）
   標準 datalist の代わり。候補リストもテーマ色に追従し、▼を縦中央に。
   ============================================================ */
.sh-wrap{position:relative;display:inline-flex;align-items:center;flex:1 1 auto;min-width:0}
.sh-wrap > input{flex:1 1 auto;min-width:0;width:100%;padding-right:30px}
.sh-toggle{
  position:absolute;right:8px;top:50%;transform:translateY(-50%);
  display:flex;align-items:center;justify-content:center;
  border:0;background:transparent;color:var(--muted);cursor:pointer;
  font-size:18px;line-height:1;padding:0;width:18px;height:18px;
  transition:transform .15s ease;
}
.sh-toggle:hover{color:var(--brand)}
.sh-toggle.open{transform:translateY(-50%) rotate(180deg)}
.sh-panel{
  position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:1300;
  max-height:240px;overflow:auto;
  background:var(--surface);border:1px solid var(--border);border-radius:8px;
  box-shadow:var(--shadow-pop);padding:4px;
}
.sh-item{
  padding:7px 10px;border-radius:6px;font-size:13px;color:var(--text);cursor:pointer;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.sh-item:hover{background:var(--brand-tint-2)}


/* ============================================================
   記法ショートカットのヘルプパネル（Ctrl+Shift+H で右下にトグル）
   ============================================================ */
.notation-help{
  position:fixed;right:16px;bottom:16px;z-index:80;
  width:min(330px,calc(100vw - 32px));
  background:var(--panel);color:var(--text);
  border:1px solid var(--border);border-radius:12px;
  box-shadow:var(--shadow-pop);
  padding:12px 14px;
}
.notation-help[hidden]{display:none;}
.notation-help .nh-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin:0 0 6px;}
.notation-help h3{margin:0;font-size:13px;font-weight:700;color:var(--text);}
.notation-help .nh-close{background:none;border:none;cursor:pointer;color:var(--muted);font-size:18px;line-height:1;padding:0 6px;border-radius:6px;}
.notation-help .nh-close:hover{background:var(--surface);color:var(--text);}
.notation-help .shortcut-sheet dt{font-size:12.5px;}


/* ============================================================
   リンク/画像のパス補完ポップアップ（path-complete.js）
   ============================================================ */
.path-complete{
  position:fixed;z-index:90;min-width:200px;max-width:min(440px,90vw);
  display:flex;flex-direction:column;
  background:var(--panel);color:var(--text);
  border:1px solid var(--border);border-radius:8px;
  box-shadow:var(--shadow-pop);padding:0;font-size:13px;overflow:hidden;
}
.path-complete[hidden]{display:none;}
.path-complete .pc-list{max-height:240px;overflow:auto;padding:4px;}
.path-complete .pc-item{display:flex;align-items:center;gap:8px;padding:5px 8px;border-radius:6px;cursor:pointer;white-space:nowrap;}
.path-complete .pc-item .pc-ic{flex:0 0 auto;width:16px;text-align:center;opacity:.85;}
.path-complete .pc-item .pc-name{overflow:hidden;text-overflow:ellipsis;}
.path-complete .pc-item:hover{background:var(--brand-tint-2);}
/* 選択中の候補ははっきり分かるようブランド色で塗る（薄すぎて見えない問題の対策） */
.path-complete .pc-item.sel{background:var(--brand);color:#fff;}
.path-complete .pc-item.sel .pc-ic{opacity:1;}
.path-complete .pc-empty{padding:6px 10px;color:var(--muted);}
/* 操作ガイド（キー説明）。リスト下部に固定表示する */
.path-complete .pc-hint{
  flex:0 0 auto;padding:5px 10px;font-size:11px;color:var(--muted);
  border-top:1px solid var(--border);background:var(--surface);white-space:nowrap;
  overflow:hidden;text-overflow:ellipsis;
}
