/* =============================================
   Document Manager – Frontend CSS v1.3
   ============================================= */

.dm-wrap {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  max-width: 1000px;
  margin: 0 auto;
  padding: 24px 16px;
  color: #1a1a2e;
}

/* ---- ログイン ---- */
.dm-login-required { text-align:center; padding:40px; background:#f0f4ff; border-radius:12px; }
.dm-login-required a { display:inline-block; padding:10px 24px; background:#4f46e5; color:#fff; border-radius:8px; text-decoration:none; font-weight:600; }

/* ---- ツールバー ---- */
.dm-toolbar { display:flex; align-items:center; justify-content:space-between; margin-bottom:20px; gap:12px; flex-wrap:wrap; }
.dm-page-title { margin:0; font-size:1.4rem; font-weight:700; }
.dm-toolbar-actions { display:flex; gap:8px; }

/* ---- ボタン ---- */
.dm-btn { display:inline-block; padding:8px 18px; border-radius:8px; font-size:.9rem; font-weight:600; text-decoration:none; cursor:pointer; border:2px solid #d1d5db; background:#fff; color:#374151; transition:all .15s; }
.dm-btn:hover { border-color:#9ca3af; background:#f9fafb; }
.dm-btn-primary { background:#4f46e5; color:#fff; border-color:#4f46e5; }
.dm-btn-primary:hover { background:#4338ca; border-color:#4338ca; color:#fff; }
.dm-btn-approve { background:#10b981; color:#fff; border-color:#10b981; }
.dm-btn-approve:hover { background:#059669; border-color:#059669; }
.dm-btn-revoke  { background:#f59e0b; color:#fff; border-color:#f59e0b; }
.dm-btn-revoke:hover  { background:#d97706; border-color:#d97706; }
.dm-btn-sm { padding:4px 10px; font-size:.8rem; border-radius:6px; }
.dm-btn-secondary { background:#f3f4f6; border-color:#d1d5db; color:#374151; }
.dm-btn-secondary:hover { background:#e5e7eb; }

/* ---- レイアウトフィルタータブ ---- */
.dm-layout-filter { display:flex; align-items:center; gap:12px; margin-bottom:18px; flex-wrap:wrap; }
.dm-filter-label { font-weight:600; font-size:.9rem; white-space:nowrap; }
.dm-filter-tabs  { display:flex; gap:6px; flex-wrap:wrap; }
.dm-tab { padding:5px 14px; border-radius:20px; background:#e5e7eb; color:#374151; font-size:.85rem; text-decoration:none; font-weight:500; transition:all .15s; }
.dm-tab:hover, .dm-tab.active { background:#4f46e5; color:#fff; }

/* ---- 文書一覧テーブル ---- */
.dm-table-wrap { overflow-x:auto; }
.dm-doc-table { width:100%; border-collapse:collapse; font-size:.9rem; background:#fff; border:1px solid #e5e7eb; border-radius:10px; overflow:hidden; }
.dm-doc-table th { background:#f8fafc; padding:10px 14px; text-align:left; font-weight:700; color:#374151; border-bottom:2px solid #e5e7eb; white-space:nowrap; }
.dm-doc-table td { padding:10px 14px; border-bottom:1px solid #f0f0f0; vertical-align:middle; }
.dm-doc-table tr:last-child td { border-bottom:none; }
.dm-doc-table tr:hover td { background:#f9fafb; }
.dm-doc-row.status-approved td:first-child { border-left:3px solid #10b981; }
.dm-doc-row.status-draft    td:first-child { border-left:3px solid #9ca3af; }
.dm-doc-table a { color:#4f46e5; text-decoration:none; font-weight:600; }
.dm-doc-table a:hover { text-decoration:underline; }
.dm-col-date    { white-space:nowrap; color:#6b7280; }
.dm-col-actions { white-space:nowrap; }
.dm-cell-truncate { max-width:160px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.dm-cell-thumb  { width:36px; height:36px; object-fit:cover; border-radius:4px; vertical-align:middle; }

/* ---- ステータスバッジ ---- */
.dm-status-badge { display:inline-block; padding:2px 10px; border-radius:12px; font-size:.75rem; font-weight:700; }
.dm-status-approved { background:#d1fae5; color:#065f46; }
.dm-status-draft    { background:#f3f4f6; color:#374151; }

/* ---- 空表示 ---- */
.dm-empty { text-align:center; padding:60px 20px; background:#f9fafb; border-radius:12px; color:#6b7280; }
.dm-empty a { color:#4f46e5; }

/* ---- フォーム ---- */
.dm-form-wrap { background:#fff; border:1px solid #e5e7eb; border-radius:12px; padding:28px; }
.dm-form-row  { margin-bottom:20px; }
.dm-label { display:block; font-weight:600; margin-bottom:6px; font-size:.9rem; color:#374151; }
.dm-required { color:#ef4444; margin-left:2px; }
.dm-input, .dm-select, .dm-textarea { width:100%; padding:10px 14px; border:1px solid #d1d5db; border-radius:8px; font-size:.95rem; box-sizing:border-box; transition:border-color .15s; font-family:inherit; }
.dm-input:focus, .dm-select:focus, .dm-textarea:focus { outline:none; border-color:#4f46e5; box-shadow:0 0 0 3px rgba(79,70,229,.1); }
.dm-textarea { min-height:100px; resize:vertical; }
.dm-static-value { margin:0; color:#6b7280; }
.dm-dynamic-fields { margin-top:20px; }
.dm-form-actions { margin-top:28px; }
.dm-form-msg { margin-top:14px; padding:12px 16px; border-radius:8px; font-size:.9rem; }
.dm-form-msg.success { background:#d1fae5; color:#065f46; }
.dm-form-msg.error   { background:#fee2e2; color:#991b1b; }

/* ---- ラジオ / チェックボックス ---- */
.dm-radio-group, .dm-checkbox-group { display:flex; flex-direction:column; gap:8px; }
.dm-radio-label, .dm-checkbox-label { display:flex; align-items:center; gap:8px; cursor:pointer; font-size:.9rem; }

/* ---- 画像フィールド ---- */
.dm-image-field { display:flex; flex-direction:column; gap:10px; } /* wrapper */
.dm-image-preview img.dm-preview-img { max-width:160px; max-height:160px; object-fit:cover; border-radius:8px; border:1px solid #e5e7eb; display:block; }
.dm-image-actions { display:flex; gap:8px; align-items:center; }
.dm-btn-upload { display:inline-block; padding:7px 14px; background:#f3f4f6; border:2px dashed #9ca3af; border-radius:8px; font-size:.88rem; font-weight:600; cursor:pointer; transition:border-color .15s, background .15s; }
.dm-btn-upload:hover { border-color:#4f46e5; background:#eef2ff; }
.dm-btn-remove-image { color:#ef4444; font-size:.85rem; padding:6px 10px; }
.dm-image-uploading { font-size:.85rem; color:#6b7280; }

/* ---- 繰り返しグループ（フォーム） ---- */
.dm-group-block { margin-bottom:24px; border:2px solid #e0e7ff; border-radius:12px; overflow:hidden; }
.dm-group-title { display:flex; align-items:center; gap:8px; padding:12px 18px; background:linear-gradient(135deg,#eef2ff,#e0e7ff); font-weight:700; font-size:.95rem; color:#3730a3; }
.dm-group-badge { font-size:.72rem; background:#4f46e5; color:#fff; padding:2px 8px; border-radius:10px; font-weight:600; }
.dm-group-icon  { font-size:1rem; }
.dm-group-rows  { padding:0 12px; }
.dm-group-row   { border:1px solid #e5e7eb; border-radius:8px; margin:12px 0; background:#fff; }
.dm-group-row-header { display:flex; align-items:center; justify-content:space-between; padding:6px 14px; background:#f8fafc; border-bottom:1px solid #f0f0f0; }
.dm-row-num     { font-size:.8rem; font-weight:700; color:#6b7280; }
.dm-btn-remove-row { color:#ef4444; font-size:.8rem; cursor:pointer; padding:2px 6px; background:none; border:none; }
.dm-group-row-fields { padding:12px 14px; display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); gap:12px; }
.dm-btn-add-row { display:block; width:calc(100% - 24px); margin:8px 12px 14px; text-align:center; background:#f0f4ff; border:2px dashed #a5b4fc; color:#4f46e5; border-radius:8px; padding:8px; cursor:pointer; font-weight:600; font-size:.88rem; transition:background .15s; }
.dm-btn-add-row:hover { background:#e0e7ff; }

/* ---- 文書閲覧 ---- */
.dm-doc-view  { background:#fff; border:1px solid #e5e7eb; border-radius:12px; padding:28px; }
.dm-doc-meta-bar { display:flex; flex-wrap:wrap; gap:10px; align-items:center; margin-bottom:20px; padding-bottom:16px; border-bottom:1px solid #f0f0f0; }
.dm-meta-item { font-size:.85rem; color:#6b7280; }
.dm-doc-fields { margin-top:20px; }
.dm-view-field { padding:14px 0; border-bottom:1px solid #f3f4f6; }
.dm-view-label { font-weight:600; font-size:.85rem; color:#6b7280; margin-bottom:4px; }
.dm-view-value { font-size:.95rem; color:#1f2937; }
.dm-admin-actions { margin-top:24px; padding-top:20px; border-top:1px solid #e5e7eb; display:flex; align-items:center; gap:12px; }

/* ---- グループ閲覧テーブル ---- */
.dm-view-group { margin-bottom:20px; border:1px solid #e0e7ff; border-radius:10px; overflow:hidden; }
.dm-view-group-title { display:flex; align-items:center; gap:8px; padding:10px 16px; background:#eef2ff; font-weight:700; color:#3730a3; font-size:.95rem; }
.dm-group-count { font-size:.78rem; background:#6366f1; color:#fff; padding:1px 8px; border-radius:10px; }
.dm-view-group-table { width:100%; border-collapse:collapse; font-size:.9rem; }
.dm-view-group-table th { background:#f8fafc; padding:8px 12px; text-align:left; font-weight:600; color:#374151; border-bottom:1px solid #e5e7eb; white-space:nowrap; }
.dm-view-group-table td { padding:8px 12px; border-bottom:1px solid #f3f4f6; vertical-align:top; }
.dm-view-group-table tr:last-child td { border-bottom:none; }
.dm-view-group-rownum { width:36px; text-align:center; color:#9ca3af; font-size:.8rem; }
.dm-view-empty-group  { padding:16px; color:#9ca3af; font-size:.9rem; margin:0; }

/* ---- アラート ---- */
.dm-alert { padding:12px 16px; border-radius:8px; margin-bottom:16px; font-size:.9rem; }
.dm-alert-info  { background:#eff6ff; color:#1e40af; border:1px solid #bfdbfe; }
.dm-alert-error { background:#fee2e2; color:#991b1b; border:1px solid #fca5a5; }

@media (max-width:600px) {
  /* dm-view-field は常に1カラム */
  .dm-group-row-fields { grid-template-columns:1fr; }
  .dm-toolbar { flex-direction:column; align-items:flex-start; }
}

/* dt/dd リセット（古いバージョンとの互換性） */
.dm-view-field dt, .dm-view-field dd { margin:0; padding:0; }

/* ---- グループ縦1列 / 横並び ---- */
.dm-fields-block  { display:flex; flex-direction:column; gap:14px; padding:12px 14px; }
.dm-fields-inline { display:flex; flex-wrap:wrap; gap:14px; padding:12px 14px; align-items:flex-start; }
.dm-fields-inline .dm-field-row { flex:1 1 200px; min-width:160px; margin:0; }

/* ---- 複数画像 ---- */
.dm-image-list  { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:10px; }
.dm-image-item  { position:relative; display:inline-block; vertical-align:top; }
.dm-image-item .dm-preview-img { width:80px; height:80px; object-fit:cover; border-radius:8px; border:1px solid #e5e7eb; display:block; }
.dm-image-item .dm-img-placeholder { width:80px; height:80px; background:#f3f4f6; border-radius:8px; display:flex; align-items:center; justify-content:center; font-size:.75rem; color:#6b7280; }
.dm-btn-remove-one-image { position:absolute; top:-6px; right:-6px; width:20px; height:20px; border-radius:50%; background:#ef4444; color:#fff; border:none; cursor:pointer; font-size:.75rem; line-height:20px; text-align:center; padding:0; }

/* ---- 削除ボタン ---- */
.dm-btn-danger { background:#ef4444; color:#fff; border-color:#ef4444; }
.dm-btn-danger:hover { background:#dc2626; border-color:#dc2626; }

/* ---- 更新履歴 ---- */
.dm-history-section { margin-top:32px; padding-top:20px; border-top:1px solid #e5e7eb; }
.dm-history-title   { font-size:1rem; font-weight:700; margin-bottom:12px; color:#374151; }
.dm-history-table   { width:100%; border-collapse:collapse; font-size:.85rem; }
.dm-history-table th { background:#f8fafc; padding:8px 12px; text-align:left; font-weight:600; border-bottom:1px solid #e5e7eb; }
.dm-history-table td { padding:8px 12px; border-bottom:1px solid #f3f4f6; }
.dm-history-action   { display:inline-block; padding:1px 8px; border-radius:10px; font-size:.78rem; font-weight:700; background:#e5e7eb; color:#374151; }
.dm-action-作成   { background:#dbeafe; color:#1e40af; }
.dm-action-更新   { background:#fef3c7; color:#92400e; }
.dm-action-承認   { background:#d1fae5; color:#065f46; }
.dm-action-承認取消 { background:#ffe4e6; color:#9f1239; }
.dm-action-削除   { background:#fee2e2; color:#991b1b; }
.dm-action-復活   { background:#ede9fe; color:#5b21b6; }

/* ---- 複数画像 閲覧表示 ---- */


/* =============================================
   絞り込みパネル
   ============================================= */
.dm-filter-form {
  background: #f8fafc;
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  padding: 16px 20px;
  margin-bottom: 16px;
}
.dm-filter-fields {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  align-items: flex-end;
  margin-bottom: 12px;
}
.dm-filter-item {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 160px;
}
.dm-filter-item .dm-filter-label {
  font-size: .82rem;
  font-weight: 600;
  color: #374151;
  margin-bottom: 0;
}
.dm-input-sm, .dm-select-sm {
  padding: 6px 10px;
  border: 1px solid #d1d5db;
  border-radius: 6px;
  font-size: .88rem;
  background: #fff;
  font-family: inherit;
}
.dm-input-sm:focus, .dm-select-sm:focus {
  outline: none;
  border-color: #4f46e5;
  box-shadow: 0 0 0 2px rgba(79,70,229,.1);
}
.dm-date-range {
  display: flex;
  align-items: center;
  gap: 6px;
}
.dm-date-range .dm-input-sm { width: 130px; }
.dm-date-sep { color: #9ca3af; font-size: .9rem; }
.dm-filter-actions {
  display: flex;
  gap: 8px;
}
.dm-result-count {
  font-size: .85rem;
  color: #6b7280;
  margin: 0 0 10px;
}

/* =============================================
   リッチテキストエディタ (TinyMCE)
   ============================================= */

/* エディタコンテナ */
.dm-richtext-wrap {
  border: 1px solid #d1d5db;
  border-radius: 8px;
  overflow: hidden;
  background: #fff;
}
.dm-richtext-wrap:focus-within {
  border-color: #4f46e5;
  box-shadow: 0 0 0 3px rgba(79,70,229,.1);
}
/* TinyMCE の textarea（エディタ初期化前は非表示にしない） */
.dm-richtext-textarea {
  width: 100%;
  min-height: 200px;
  font-family: inherit;
  font-size: .95rem;
  line-height: 1.7;
  padding: 10px;
  box-sizing: border-box;
  border: none;
}

/* 閲覧時の表示 */
.dm-richtext-view {
  line-height: 1.8;
  font-size: .95rem;
  color: #1a1a2e;
}
.dm-richtext-view h1 { font-size: 1.5em; font-weight: 700; margin: .5em 0; }
.dm-richtext-view h2 { font-size: 1.3em; font-weight: 700; margin: .5em 0; }
.dm-richtext-view h3 { font-size: 1.1em; font-weight: 700; margin: .5em 0; }
.dm-richtext-view strong { font-weight: 700; }
.dm-richtext-view em     { font-style: italic; }
.dm-richtext-view u      { text-decoration: underline; }
.dm-richtext-view s      { text-decoration: line-through; }
.dm-richtext-view ul { list-style: disc; padding-left: 1.5em; margin: .4em 0; }
.dm-richtext-view ol { list-style: decimal; padding-left: 1.5em; margin: .4em 0; }
.dm-richtext-view a  { color: #4f46e5; }
.dm-richtext-view p  { margin: .3em 0; }

/* グループテーブル内（閲覧時は全文表示） */
.dm-richtext-compact {
  font-size: .88rem;
}

/* 文書カテゴリーフィルタータブ（レイアウトタブの下に表示） */
.dm-category-filter { margin-top: -8px; margin-bottom: 16px; }
.dm-category-filter .dm-tab {
  background: #f0fdf4;
  color: #166534;
}
.dm-category-filter .dm-tab:hover,
.dm-category-filter .dm-tab.active {
  background: #16a34a;
  color: #fff;
}
.dm-col-category { white-space: nowrap; }

/* 絞り込みフォーム縦1列レイアウト */
.dm-filter-vertical { flex-direction: column; gap: 10px; }
.dm-filter-item-row {
  display: flex;
  align-items: center;
  gap: 12px;
}
.dm-filter-item-label {
  width: 140px;
  flex-shrink: 0;
  font-size: .88rem;
  font-weight: 600;
  color: #374151;
}
.dm-select-filter {
  flex: 1;
  max-width: 280px;
  padding: 6px 10px;
  border: 1px solid #d1d5db;
  border-radius: 6px;
  font-size: .88rem;
  background: #fff;
}

/* 文書カテゴリーチェックボックス */
.dm-category-checks {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.dm-label-note {
  font-size: .78rem;
  font-weight: 400;
  color: #6b7280;
  margin-left: 4px;
}

/* 上部保存ボタン */
.dm-form-actions-top {
  margin-bottom: 20px;
  padding-bottom: 16px;
  border-bottom: 1px solid #e5e7eb;
}

/* ============================================================
   DM Simple Rich Text Editor
============================================================ */
.dm-editor-toolbar {
    border: 1px solid #ccc;
    border-bottom: none;
    background: #f7f7f7;
    border-radius: 4px 4px 0 0;
    padding: 4px 6px;
}
.dm-editor-toolbar-inner {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 2px;
}
.dm-ed-btn {
    background: #fff;
    border: 1px solid #ccc;
    border-radius: 3px;
    padding: 3px 8px;
    cursor: pointer;
    font-size: 13px;
    min-width: 28px;
    line-height: 1.4;
}
.dm-ed-btn:hover { background: #e0e0e0; }
.dm-ed-sep {
    width: 1px;
    height: 20px;
    background: #ccc;
    margin: 0 3px;
    display: inline-block;
}
.dm-ed-fontsize {
    font-size: 12px;
    padding: 2px 4px;
    border: 1px solid #ccc;
    border-radius: 3px;
    background: #fff;
    cursor: pointer;
}
.dm-ed-color-label {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 26px;
    border: 1px solid #ccc;
    border-radius: 3px;
    background: #fff;
    cursor: pointer;
    font-weight: bold;
    font-size: 13px;
    overflow: hidden;
}
.dm-ed-color-label:hover { background: #e0e0e0; }
.dm-ed-color {
    position: absolute;
    width: 100%;
    height: 100%;
    opacity: 0;
    cursor: pointer;
    top: 0; left: 0;
}
.dm-ed-bg-label { text-decoration: underline; background-color: #ffff0044; }
.dm-editor-body {
    border: 1px solid #ccc;
    border-radius: 0 0 4px 4px;
    min-height: 150px;
    padding: 10px 12px;
    font-family: sans-serif;
    font-size: 14px;
    line-height: 1.8;
    background: #fff;
    outline: none;
    overflow-y: auto;
    max-height: 400px;
}
.dm-editor-body:focus { border-color: #2271b1; box-shadow: 0 0 0 1px #2271b1; }

/* ============================================================
   グループ閲覧：縦1列（block）表示
============================================================ */
.dm-view-group-blocks {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.dm-view-group-block-row {
  border: 1px solid #e5e7eb;
  border-radius: 8px;
  padding: 12px 16px;
  background: #fafafa;
}
.dm-view-group-block-num {
  font-size: .78rem;
  font-weight: 600;
  color: #6b7280;
  margin-bottom: 8px;
  padding-bottom: 6px;
  border-bottom: 1px solid #e5e7eb;
}
.dm-view-group-block-field {
  display: block;
  padding: 6px 0;
  border-bottom: 1px dashed #f3f4f6;
}
.dm-view-group-block-field:last-child {
  border-bottom: none;
}
.dm-view-group-block-label {
  font-size: .8rem;
  font-weight: 600;
  color: #6b7280;
  margin-bottom: 4px;
  padding-bottom: 4px;
  border-bottom: 1px solid #e5e7eb;
}
.dm-view-group-block-value {
  font-size: .9rem;
  color: #1f2937;
}

/* ============================================================
   閲覧画面 画像：横並び・折り返し
============================================================ */
.dm-view-images {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  align-items: flex-start !important;
}
.dm-view-images a,
.dm-view-images a:link,
.dm-view-images a:visited {
  display: inline-flex !important;
  line-height: 0 !important;
  flex-shrink: 0 !important;
}
.dm-view-img-thumb {
  width: 120px !important;
  height: 120px !important;
  object-fit: cover !important;
  border-radius: 8px !important;
  border: 1px solid #e5e7eb !important;
  display: block !important;
  transition: transform .15s;
}
.dm-view-img-thumb:hover { transform: scale(1.05); }

/* ============================================================
   文書一覧：2列レイアウト（作成日列 ＋ タイトル列）
============================================================ */
.dm-doc-table .dm-col-date-head { width: 90px; white-space: nowrap; }

.dm-row-link {
  display: flex;
  flex-direction: column;
  gap: 2px;
  text-decoration: none;
  color: inherit;
}
.dm-row-link:hover { text-decoration: none; }

/* 左列：作成日 */
.dm-col-date .dm-list-date {
  font-size: .9rem;
  font-weight: 600;
  color: #374151;
  white-space: nowrap;
}
.dm-col-date .dm-list-author {
  font-size: .75rem;
  color: #9ca3af;
  white-space: nowrap;
}

/* 右列 */
.dm-list-status {
  font-size: .72rem;
  font-weight: 600;
  color: #9ca3af;
}
.dm-status-approved .dm-list-status { color: #059669; }
.dm-status-draft    .dm-list-status { color: #6b7280; }

.dm-list-title {
  font-size: .95rem;
  font-weight: 600;
  color: #1f2937;
}
.dm-row-link:hover .dm-list-title { color: #4f46e5; }

.dm-list-category {
  font-size: .75rem;
  color: #6b7280;
}

/* ============================================================
   ページネーション
============================================================ */
.dm-pagination {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 20px;
  flex-wrap: wrap;
}
.dm-page-btn {
  display: inline-block;
  padding: 6px 12px;
  border-radius: 6px;
  border: 1px solid #d1d5db;
  background: #fff;
  color: #374151;
  font-size: .88rem;
  font-weight: 600;
  text-decoration: none;
  transition: all .15s;
}
.dm-page-btn:hover { background: #f3f4f6; border-color: #9ca3af; text-decoration: none; }
.dm-page-btn.active { background: #4f46e5; border-color: #4f46e5; color: #fff; }
.dm-page-ellipsis { color: #9ca3af; padding: 0 4px; }

/* ============================================================
   ファイルフィールド
============================================================ */
.dm-file-field { display: flex; flex-direction: column; gap: 8px; }
.dm-file-list  { display: flex; flex-direction: column; gap: 6px; }
.dm-file-item  {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 10px; background: #f8fafc;
  border: 1px solid #e5e7eb; border-radius: 6px;
  font-size: .88rem;
}
.dm-file-icon  { font-size: 1rem; flex-shrink: 0; }
.dm-file-name  { color: #4f46e5; text-decoration: none; flex: 1; word-break: break-all; }
.dm-file-name:hover { text-decoration: underline; }
.dm-file-size  { font-size: .78rem; color: #9ca3af; white-space: nowrap; }
.dm-btn-remove-file {
  background: none; border: none; cursor: pointer;
  color: #ef4444; font-size: .85rem; padding: 0 4px;
  flex-shrink: 0;
}
.dm-btn-remove-file:hover { color: #b91c1c; }
.dm-file-uploading { font-size: .85rem; color: #6b7280; }

/* 閲覧画面のファイル表示 */
.dm-view-files { display: flex; flex-direction: column; gap: 6px; }
.dm-view-file-item {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 10px; background: #f8fafc;
  border: 1px solid #e5e7eb; border-radius: 6px;
  font-size: .9rem;
}

/* ============================================================
   フィールド表示：ラベル位置（top / side）
============================================================ */
/* top（デフォルト）: ラベル上、値下 */
.dm-view-field.dm-label-top {
  display: block;
  padding: 14px 0;
  border-bottom: 1px solid #f3f4f6;
}
.dm-view-field.dm-label-top .dm-view-label {
  font-weight: 600;
  font-size: .85rem;
  color: #6b7280;
  margin-bottom: 4px;
}
.dm-view-field.dm-label-top .dm-view-value {
  font-size: .95rem;
  color: #1f2937;
}

/* side: ラベル左、値右、1行で表示 */
.dm-view-field.dm-label-side {
  display: flex;
  align-items: baseline;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid #f3f4f6;
}
.dm-view-field.dm-label-side .dm-view-label {
  font-weight: 600;
  font-size: .85rem;
  color: #6b7280;
  white-space: nowrap;
  flex-shrink: 0;
  min-width: 100px;
}
.dm-view-field.dm-label-side .dm-view-value {
  font-size: .95rem;
  color: #1f2937;
  flex: 1;
}

/* ============================================================
   トグルスイッチ（入力フォーム）
============================================================ */
.dm-toggle-field { display: flex; align-items: center; gap: 10px; }
.dm-toggle-switch { position: relative; display: inline-block; width: 48px; height: 26px; }
.dm-toggle-switch input { opacity: 0; width: 0; height: 0; }
.dm-toggle-slider {
  position: absolute; inset: 0;
  background: #d1d5db; border-radius: 26px;
  cursor: pointer; transition: .25s;
}
.dm-toggle-slider::before {
  content: ''; position: absolute;
  width: 20px; height: 20px; left: 3px; bottom: 3px;
  background: #fff; border-radius: 50%;
  transition: .25s;
}
.dm-toggle-input:checked + .dm-toggle-slider { background: #4f46e5; }
.dm-toggle-input:checked + .dm-toggle-slider::before { transform: translateX(22px); }
.dm-toggle-label-text { font-size: .9rem; color: #374151; font-weight: 600; min-width: 40px; }

/* トグル閲覧表示 */
.dm-toggle-view { display: inline-block; padding: 2px 12px; border-radius: 12px; font-size: .85rem; font-weight: 700; }
.dm-toggle-on  { background: #ede9fe; color: #4f46e5; }
.dm-toggle-off { background: #f3f4f6; color: #6b7280; }

/* ラベルタイプ（静的テキスト） */
.dm-label-display { font-size: .95rem; color: #374151; padding: 6px 0; }

/* ============================================================
   フィールドグループ（閲覧画面）
============================================================ */
.dm-fg-table {
  border-collapse: collapse !important;
  width: 100% !important;
  margin: 12px 0 !important;
  border: 1px solid #e5e7eb !important;
  border-radius: 8px !important;
  overflow: hidden !important;
  display: table !important;
}
.dm-fg-table thead { display: table-header-group !important; }
.dm-fg-table tbody { display: table-row-group !important; }
.dm-fg-table tr { display: table-row !important; }
.dm-fg-table th,
.dm-fg-table td { display: table-cell !important; }
.dm-fg-th {
  background: #f1f5f9;
  padding: 8px 12px;
  font-size: .82rem;
  font-weight: 700;
  color: #475569;
  border: 1px solid #e5e7eb;
  text-align: left;
  white-space: nowrap;
}
.dm-fg-td {
  padding: 8px 12px;
  border: 1px solid #e5e7eb;
  vertical-align: top;
  font-size: .9rem;
  color: #1f2937;
}
.dm-fg-caption {
  text-align: left;
  font-weight: 700;
  font-size: .85rem;
  color: #6b7280;
  padding: 4px 0;
  caption-side: top;
}
.dm-fg-column {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 8px;
  border: 1px solid #e5e7eb;
  border-radius: 8px;
  margin: 8px 0;
}
.dm-fg-label {
  font-weight: 700;
  font-size: .85rem;
  color: #6b7280;
  padding-bottom: 4px;
  border-bottom: 1px solid #e5e7eb;
}
.dm-fg-field-label {
  font-size: .8rem;
  font-weight: 600;
  color: #6b7280;
  margin-bottom: 2px;
}

/* フォーム側 */
.dm-fg-form-wrap { margin: 12px 0; }
.dm-fg-form-title {
  font-weight: 700; font-size: .88rem; color: #4f46e5;
  margin-bottom: 6px; padding-bottom: 4px;
  border-bottom: 2px solid #e0e7ff;
}
.dm-fg-form-row .dm-fg-form-children {
  display: flex !important; flex-wrap: wrap !important; gap: 12px !important; align-items: flex-start !important;
}
.dm-fg-form-row .dm-fg-form-field { flex: 1 1 160px !important; min-width: 120px !important; }
.dm-fg-form-column .dm-fg-form-children {
  display: flex !important; flex-direction: column !important; gap: 8px !important;
}

/* 管理画面 フィールドグループ */
.dm-field-group-def {
  border: 2px solid #a5b4fc !important;
  background: #f5f3ff !important;
}
.dm-fg-header {
  background: linear-gradient(135deg, #ede9fe, #ddd6fe) !important;
  color: #4f46e5 !important;
}
.dm-fg-actions { padding: 4px 8px 8px; display: flex; gap: 6px; }

/* ラベルタイプのフィールドラベルは常に非表示 */
[data-field-type="label"] .dm-view-label,
[data-field-type="label"] .dm-label,
[data-field-type="label"] .dm-fg-field-label {
    display: none !important;
}

/* field-renderer.php 経由のラベルタイプも確実に非表示 */
.dm-field-row[data-field-type="label"] .dm-label {
    display: none !important;
}

/* ============================================================
   入力フォーム ラベル位置制御
============================================================ */
/* top（デフォルト）: ラベル上、入力欄下 */
.dm-field-row.dm-label-top {
  display: block;
}
.dm-field-row.dm-label-top .dm-label {
  display: block;
  margin-bottom: 4px;
}

/* side: ラベル左、入力欄右 */
.dm-field-row.dm-label-side {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: nowrap;
}
.dm-field-row.dm-label-side .dm-label {
  font-weight: 600;
  font-size: .85rem;
  color: #6b7280;
  white-space: nowrap;
  flex-shrink: 0;
  min-width: 100px;
}
.dm-field-row.dm-label-side .dm-input,
.dm-field-row.dm-label-side .dm-textarea,
.dm-field-row.dm-label-side .dm-select,
.dm-field-row.dm-label-side .dm-radio-group,
.dm-field-row.dm-label-side .dm-checkbox-group,
.dm-field-row.dm-label-side .dm-toggle-field,
.dm-field-row.dm-label-side .dm-richtext-wrap,
.dm-field-row.dm-label-side .dm-image-field,
.dm-field-row.dm-label-side .dm-file-field {
  flex: 1;
}

/* ============================================================
   繰り返しグループ：表形式（inline）
============================================================ */
.dm-group-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin: 8px 0;
}
.dm-group-input-table {
  border-collapse: collapse;
  min-width: 100%;
  white-space: nowrap;
}
.dm-group-input-table th,
.dm-group-input-table td {
  border: 1px solid #e5e7eb;
  padding: 6px 8px;
  vertical-align: middle;
}
.dm-group-col-th {
  background: #f1f5f9;
  font-weight: 700;
  font-size: .82rem;
  color: #475569;
  text-align: left;
  white-space: nowrap;
}
.dm-group-rownum-th,
.dm-group-del-th { width: 32px; background: #f8fafc; }
.dm-group-rownum-td {
  text-align: center;
  color: #9ca3af;
  font-size: .8rem;
  font-weight: 600;
}
.dm-group-col-td { vertical-align: top; min-width: 120px; }
.dm-group-del-td { text-align: center; vertical-align: middle; }
/* 表形式のセル内では field-row のマージンを縮小 */
.dm-group-col-td .dm-field-row { margin: 0; }
.dm-inline-label {
  font-size: .88rem;
  color: #6b7280;
  margin-left: 2px;
}

/* 閲覧：表形式ラップ */
.dm-view-group-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin: 8px 0;
}

/* 閲覧：列形式のFG横並び */
.dm-fg-block-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: flex-start;
}
.dm-fg-block-col {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
/* ラベル位置制御（列形式内） */
.dm-view-group-block-field.dm-label-side {
  display: flex;
  align-items: baseline;
  gap: 8px;
}
.dm-view-group-block-field.dm-label-side .dm-view-group-block-label {
  white-space: nowrap;
  flex-shrink: 0;
  min-width: 80px;
}
