/* ============================================================
   _dashboard/assets/css/dashboard.css — 総合管理画面 共通スタイル
   ============================================================ */
:root{
  --bg:#f6f4fb; --card:#ffffff; --line:#e7e2f0; --text:#2c2540; --sub:#7a7290;
  --accent:#8E6FC4; --radius:14px; --shadow:0 2px 10px rgba(90,70,140,.08);
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--text);
  font-family:-apple-system,"Hiragino Sans","Yu Gothic",sans-serif;line-height:1.6}
a{color:var(--accent);text-decoration:none}

/* ヘッダ */
.dash-head{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;
  background:var(--card);padding:14px 20px;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10}
.dash-logo{font-weight:700;font-size:1.05rem;color:var(--text)}
.dash-nav a{margin-left:4px;padding:5px 11px;border-radius:999px;font-size:.92rem;color:var(--sub)}
.dash-nav a:hover{color:var(--accent)}
.dash-nav a.active{background:#ffe3ee;color:#c44d77;font-weight:700}

/* ハンバーガーメニュー（スマホ用）*/
.nav-toggle{display:none}
.nav-burger{display:none;cursor:pointer;font-size:1.6rem;line-height:1;color:var(--sub);
  padding:2px 10px;user-select:none;border-radius:8px}
.nav-burger:hover{color:var(--accent);background:#f3eefb}
@media (max-width:760px){
  .nav-burger{display:block}
  .dash-nav{display:none;flex-basis:100%;flex-direction:column;gap:6px;margin-top:12px}
  .nav-toggle:checked ~ .dash-nav{display:flex}
  .dash-nav a{margin-left:0;display:block;padding:9px 12px;font-size:1rem;
    border-bottom:1px solid var(--line)}
  .dash-nav a:last-child{border-bottom:none}
}

.dash-main{max-width:1000px;margin:0 auto;padding:24px 18px 60px}
.dash-foot{text-align:center;color:var(--sub);font-size:.8rem;padding:24px}

/* サマリー */
.dash-summary{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:24px}
.dash-stat{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:14px 20px;box-shadow:var(--shadow);min-width:110px}
.dash-stat b{font-size:1.7rem;display:block;line-height:1.2}
.dash-stat span{font-size:.8rem;color:var(--sub)}

/* 部署ブロック */
.dept{margin-bottom:26px}
.dept-title{font-size:1.05rem;font-weight:700;margin:0 0 12px;padding-left:10px;border-left:4px solid var(--accent)}

/* 社員カード */
.agent-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:14px}
.agent-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:14px;box-shadow:var(--shadow);border-top:4px solid var(--c,#888);position:relative}
.agent-card .avatar{width:76px;height:76px;border-radius:50%;object-fit:cover;flex-shrink:0;
  background:var(--c,#ddd);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1.7rem}
.agent-card .head{display:flex;align-items:center;gap:12px;margin-bottom:8px}
.agent-card .name{font-weight:700}
.agent-card .ka{font-size:.78rem;color:var(--sub)}
.agent-card .role{font-size:.84rem;color:var(--text);margin:6px 0 4px}
.agent-card .seikaku{font-size:.78rem;color:var(--sub)}
.badge{display:inline-block;font-size:.7rem;padding:2px 8px;border-radius:999px;background:#efe9f8;color:var(--accent);margin-left:6px}
.badge.veto{background:#2e2e38;color:#fff}

.note{font-size:.82rem;color:var(--sub);background:#fff;border:1px dashed var(--line);
  border-radius:var(--radius);padding:12px 14px;margin-top:10px}


/* ===== STEP4後半: 編集フォーム ===== */
/* ============================================================
   社員一覧（agents.php）/ 社員編集（agent_edit.php）追加スタイル
   ============================================================ */

/* フラッシュメッセージ */
.flash{border-radius:var(--radius);padding:12px 16px;margin-bottom:18px;font-size:.9rem}
.flash.ok{background:#e8f6ec;border:1px solid #bfe3c9;color:#1f7a3d}
.flash.err{background:#fdecec;border:1px solid #f3c2c2;color:#b3261e}
.flash.err div{margin:2px 0}

/* カードフッタ（一覧の編集リンク／状態） */
.card-foot{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:10px;
  padding-top:10px;border-top:1px solid var(--line)}
.status-pill{font-size:.72rem;padding:2px 9px;border-radius:999px;background:#efe9f8;color:var(--accent)}
.edit-link{font-size:.82rem;font-weight:600;padding:4px 12px;border-radius:8px;
  background:var(--accent);color:#fff}
.edit-link:hover{opacity:.88}

/* パンくず */
.crumbs{font-size:.84rem;color:var(--sub);margin:0 0 16px}
.crumbs span{color:var(--text)}

/* 編集レイアウト */
.edit-wrap{display:grid;grid-template-columns:minmax(0,1fr) 260px;gap:20px;align-items:start}
@media (max-width:760px){.edit-wrap{grid-template-columns:1fr}}

.edit-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:20px}
.edit-title{font-size:1rem;font-weight:700;margin:18px 0 12px;padding-left:9px;
  border-left:4px solid var(--accent)}
.edit-title:first-of-type{margin-top:0}

/* 入力フィールド */
.fld{display:block;margin-bottom:14px}
.fld>span{display:block;font-size:.8rem;color:var(--sub);margin-bottom:5px}
.fld input[type=text],.fld select,.fld input[type=file]{
  width:100%;padding:9px 11px;border:1px solid var(--line);border-radius:9px;
  background:#fff;color:var(--text);font-size:.92rem;font-family:inherit}
.fld input[type=text]:focus,.fld select:focus{outline:none;border-color:var(--accent)}
.fld input[type=color]{width:60px;height:40px;padding:2px;border:1px solid var(--line);
  border-radius:9px;background:#fff;cursor:pointer}
.fld-row{display:flex;gap:14px;flex-wrap:wrap}
.fld-row>.fld{flex:1;min-width:140px}
.fld-color{flex:0 0 auto;min-width:0}

/* 画像エリア */
.img-area{display:flex;gap:18px;align-items:flex-start;flex-wrap:wrap}
.img-preview{flex:0 0 auto}
.img-preview img,.img-none{width:96px;height:96px;border-radius:14px;object-fit:cover}
.img-none{display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;
  font-size:2rem;background:#888}
.img-up{flex:1;min-width:200px}
.hint{font-size:.76rem;color:var(--sub);margin:6px 0 0}
.hint code,.side-v code{background:#f1edf8;padding:1px 6px;border-radius:5px;font-size:.92em}

/* ボタン */
.edit-actions{display:flex;gap:10px;margin-top:20px;flex-wrap:wrap}
.btn{display:inline-block;padding:9px 18px;border-radius:10px;font-size:.9rem;font-weight:600;
  border:1px solid var(--line);background:#fff;color:var(--text);cursor:pointer;font-family:inherit}
.btn:hover{border-color:var(--accent);color:var(--accent)}
.btn.primary{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn.primary:hover{opacity:.9;color:#fff}

/* サイド情報 */
.edit-side{display:flex;flex-direction:column;gap:12px}
.side-box{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:14px}
.side-k{font-size:.75rem;color:var(--sub);margin-bottom:5px}
.side-v{font-size:.8rem;word-break:break-all}

/* ===== STEP4後半: スキル一覧 ===== */
/* ============================================================
   スキル一覧 / スキル本文ビュー 用スタイル（skills.php / skill_view.php）
   ============================================================ */
.skill-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}
.skill-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);border-top:4px solid var(--accent);overflow:hidden;
  transition:box-shadow .15s ease,transform .15s ease}
.skill-card:hover{box-shadow:0 6px 18px rgba(90,70,140,.16);transform:translateY(-2px)}
.skill-link{display:block;padding:14px 16px;color:inherit}
.skill-name{font-weight:700;font-size:1rem;word-break:break-word}
.skill-title{font-size:.82rem;color:var(--accent);margin-top:2px;word-break:break-word}
.skill-summary{font-size:.8rem;color:var(--sub);margin:8px 0 6px}
.skill-more{font-size:.76rem;color:var(--accent)}

/* 本文ビュー */
.skill-breadcrumb{display:flex;align-items:center;gap:12px;flex-wrap:wrap;
  font-size:.82rem;color:var(--sub);margin:0 0 12px}
.skill-folder{font-family:ui-monospace,Menlo,Consolas,monospace;background:#efe9f8;
  color:var(--accent);padding:2px 8px;border-radius:999px}
.skill-body{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:16px 18px;font-size:.84rem;line-height:1.7;
  font-family:ui-monospace,Menlo,Consolas,"Hiragino Sans",monospace;
  white-space:pre-wrap;word-break:break-word;overflow-wrap:anywhere;margin:0}

/* ===== STEP4後半: 日課トップ ===== */
/* ============================================================
   daily.php — 日課トップ専用スタイル（このページ用の追加分のみ）
   ============================================================ */
.daily-h1{font-size:1.3rem;font-weight:700;margin:0 0 18px}
.daily-h1 .daily-sub{font-size:.82rem;color:var(--sub);font-weight:400}

/* 空状態 */
.daily-empty{text-align:center;background:var(--card);border:1px dashed var(--line);
  border-radius:var(--radius);padding:46px 20px;box-shadow:var(--shadow);color:var(--text)}
.daily-empty-emoji{font-size:2.6rem;margin-bottom:8px}
.daily-empty p{margin:4px 0}
.daily-empty-note{color:var(--sub);font-size:.86rem}
.daily-skip{color:var(--sub);font-size:.78rem;margin:10px 0}

/* セクション間隔 */
.daily-block{margin-bottom:28px}

/* 活動フィード */
.daily-feed{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.daily-feed-item{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:12px 14px;box-shadow:var(--shadow);border-left:4px solid var(--accent)}
.daily-feed-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:4px}
.daily-proj{font-size:.72rem;font-weight:700;color:var(--accent);background:#efe9f8;
  padding:2px 8px;border-radius:999px}
.daily-agent{font-size:.8rem;font-weight:700;color:var(--text)}
.daily-time{font-size:.72rem;color:var(--sub);margin-left:auto}
.daily-action{font-size:.9rem;color:var(--text)}
.daily-reason{font-size:.78rem;color:var(--sub);margin-top:3px}

/* プロジェクト別カード */
.daily-proj-card{border-top:4px solid var(--accent)}
.daily-task-row{display:flex;gap:6px;flex-wrap:wrap;margin:8px 0}
.daily-pill{font-size:.72rem;padding:3px 9px;border-radius:999px;font-weight:700}
.daily-pill.todo{background:#f0eef5;color:var(--sub)}
.daily-pill.doing{background:#fff3d9;color:#b07d10}
.daily-pill.done{background:#e3f4e8;color:#2f8a4d}

/* 知見リスト */
.daily-learn-title{font-size:.74rem;color:var(--sub);font-weight:700;margin:8px 0 4px}
.daily-learn{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}
.daily-learn li{font-size:.8rem;color:var(--text);line-height:1.45}
.daily-effect{display:inline-block;font-weight:700;color:var(--accent);margin-right:4px}
.daily-genre{display:inline-block;font-size:.68rem;color:var(--sub);background:#f0eef5;
  padding:1px 7px;border-radius:999px;margin-left:4px}
.daily-cond{font-size:.72rem;color:var(--sub);margin-top:2px}

/* ===== コスト/予算ページ ===== */
.cost-bar-wrap{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:18px 20px;margin-bottom:18px}
.cost-bar-top{display:flex;justify-content:space-between;align-items:baseline;font-size:.86rem;color:var(--sub);margin-bottom:8px}
.cost-bar-top strong{color:var(--text);font-size:1rem}
.cost-bar{height:14px;background:#eee6f5;border-radius:999px;overflow:hidden}
.cost-bar-fill{height:100%;background:var(--accent);border-radius:999px;transition:width .3s}
.cost-bar-fill.warn{background:#e6a817}
.cost-bar-fill.over{background:#d2433a}
.cost-bar-foot{font-size:.78rem;color:var(--sub);margin-top:7px}
.cost-form{max-width:420px;margin-bottom:24px}
.toggle-fld .switch{display:flex;align-items:center;gap:8px;font-size:.92rem}
.toggle-fld em{font-style:normal;color:var(--sub)}
.cost-table{width:100%;border-collapse:collapse;background:var(--card);border:1px solid var(--line);
  border-radius:var(--radius);overflow:hidden;font-size:.86rem}
.cost-table th,.cost-table td{padding:9px 12px;text-align:left;border-bottom:1px solid var(--line)}
.cost-table th{background:var(--bg);color:var(--sub);font-weight:700;font-size:.78rem}
.cost-table tr:last-child td{border-bottom:0}


/* ===== 稼働タイムテーブル（schedule.php）===== */
.tt-wrap{overflow-x:auto;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:8px}
.tt{border-collapse:collapse;width:100%;min-width:760px;font-size:.72rem}
.tt th,.tt td{text-align:center;padding:0}
.tt-name{text-align:left!important;width:180px;min-width:160px;padding:6px 10px!important}
.tt thead .tt-name{color:var(--sub);font-weight:700}
.tt-h{color:var(--sub);font-weight:600;height:22px;position:relative}
.tt-h.now,.tt-c.now{box-shadow:inset 1px 0 0 #d2433a}
.tt tbody tr{border-top:1px solid var(--line)}
.tt-job{display:block;font-weight:700;color:var(--text)}
.tt-meta{display:block;font-size:.68rem;color:var(--sub)}
.tt-c{height:30px;border-left:1px solid #f3eff8}
.tr.off,.tt tbody tr.off{opacity:.5}
.dot{display:inline-block;width:11px;height:11px;border-radius:3px;vertical-align:middle}
.dot.iv{background:#3b82c4}
.dot.fx{background:#7b5bd6}
.dot.dis{background:#bbb}
.tt-legend{display:flex;gap:18px;flex-wrap:wrap;margin:12px 2px;font-size:.78rem;color:var(--sub);align-items:center}
.tt-legend .dot{margin-right:5px}
.tt-nowlabel{color:#d2433a}
/* 頻度編集 */
.sched-edit{display:flex;flex-direction:column;gap:8px}
.sched-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;background:var(--card);
  border:1px solid var(--line);border-radius:12px;padding:10px 14px;box-shadow:var(--shadow)}
.sched-title{font-weight:700;min-width:150px}
.sched-title small{color:var(--sub);font-weight:400;font-size:.78rem}
.sched-row select,.sched-row input[type=text]{padding:6px 9px;border:1px solid var(--line);border-radius:8px;font-family:inherit;font-size:.85rem}
.sched-fh{width:90px}
.sched-on{font-size:.85rem;color:var(--sub);display:flex;align-items:center;gap:5px}
.sched-row .btn{padding:6px 14px;margin-left:auto}


/* ===== gallery ===== */
/* ===== ギャラリー（gallery.php）稼働中の全AIエージェントたち ===== */
.gallery-h1{font-size:1.3rem;font-weight:700;margin:0 0 20px}
.gallery-h1 .gallery-sub{font-size:.84rem;color:var(--sub);font-weight:400}

/* 空状態 */
.gallery-empty{text-align:center;background:var(--card);border:1px dashed var(--line);
  border-radius:var(--radius);padding:46px 20px;box-shadow:var(--shadow);color:var(--text)}
.gallery-empty-emoji{font-size:2.6rem;margin-bottom:8px}
.gallery-empty p{margin:4px 0}
.gallery-empty-note{color:var(--sub);font-size:.86rem}

/* グリッド（大きめカード） */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:22px}

/* カード本体（リンク全体がカード） */
.gallery-card{position:relative;display:flex;flex-direction:column;align-items:center;text-align:center;
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  border-top:5px solid var(--c,#888);box-shadow:var(--shadow);padding:16px 16px 18px;color:inherit;
  transition:box-shadow .15s ease,transform .15s ease}
.gallery-card:hover{box-shadow:0 8px 22px rgba(90,70,140,.18);transform:translateY(-3px)}
.gallery-card.is-off{opacity:.62}

/* 通し番号 No.x（左上） */
.gallery-no{position:absolute;top:10px;left:12px;font-size:.74rem;font-weight:700;
  color:var(--c,var(--accent));letter-spacing:.02em}

/* 稼働バッジ（右上） */
.gallery-badge{position:absolute;top:9px;right:11px;font-size:.68rem;font-weight:700;
  padding:3px 10px;border-radius:999px;line-height:1.4}
.gallery-badge.on{background:#e3f4e8;color:#2f8a4d}
.gallery-badge.on::before{content:"";display:inline-block;width:7px;height:7px;border-radius:50%;
  background:#34a853;margin-right:5px;vertical-align:middle}
.gallery-badge.off{background:#f0eef5;color:var(--sub)}

/* アバター */
.gallery-ava-wrap{margin-bottom:12px}
.gallery-ava{width:185px;height:185px;border-radius:50%;object-fit:cover;
  border:3px solid var(--c,#ddd);box-shadow:0 3px 10px rgba(90,70,140,.14);display:block}
.gallery-ava-init{display:flex;align-items:center;justify-content:center;
  color:#fff;font-weight:700;font-size:3rem;border-color:rgba(255,255,255,.6)}

/* 名前・役割・メタ */
.gallery-name{font-weight:700;font-size:1.06rem;margin-bottom:4px;word-break:break-word}
.gallery-role{font-size:.82rem;color:var(--text);margin-bottom:10px;line-height:1.4;
  word-break:break-word}
.gallery-meta{display:flex;gap:6px;flex-wrap:wrap;justify-content:center;margin-top:auto}
.gallery-dept{font-size:.72rem;font-weight:700;color:var(--c,var(--accent));
  background:#efe9f8;padding:3px 10px;border-radius:999px}
.gallery-ka{font-size:.72rem;color:var(--sub);background:var(--bg);
  padding:3px 10px;border-radius:999px;border:1px solid var(--line)}

@media (max-width:480px){
  .gallery-grid{grid-template-columns:repeat(2,1fr);gap:10px}   /* スマホは横2列 */
  .gallery-card{padding:14px 7px 14px}                          /* 左右＆上余白を縮小 */
  .gallery-ava{width:100%;height:auto;aspect-ratio:1/1}         /* 画像はセル幅いっぱい */
  .gallery-sub{display:block;margin-top:3px}                    /* タイトルを「たち」の後で改行 */
}

/* ===== cards ===== */

/* ===== 社員詳細（agent.php）— What / Flow / Schedule プロフィールカード ===== */

/* プロフィールヘッダー（セミナーの登壇者カード風） */
.ag-hero{display:flex;align-items:center;gap:20px;flex-wrap:wrap;
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);border-top:5px solid var(--c,var(--accent));
  padding:22px 24px;margin-bottom:22px}
.ag-hero-av{width:150px;height:150px;border-radius:18px;object-fit:cover;flex:0 0 auto;
  background:var(--c,#ddd);box-shadow:0 0 0 4px #fff,0 0 0 6px var(--c,var(--line))}
.ag-hero-av.is-initial{display:flex;align-items:center;justify-content:center;
  color:#fff;font-weight:700;font-size:2rem}
.ag-hero-info{flex:1;min-width:200px}
.ag-hero-dept{font-size:.78rem;color:var(--sub);font-weight:600;letter-spacing:.02em}
.ag-hero-name{font-size:1.5rem;font-weight:700;margin:2px 0 4px;color:var(--text)}
.ag-hero-seikaku{font-size:.84rem;color:var(--sub);margin-bottom:10px}
.ag-hero-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.ag-status{font-size:.74rem;padding:3px 11px;border-radius:999px;background:#efe9f8;color:var(--accent);font-weight:600}
.ag-act{font-size:.82rem;font-weight:600;padding:5px 14px;border-radius:9px;
  background:var(--c,var(--accent));color:#fff}
.ag-act:hover{opacity:.88}
.ag-act.ghost{background:#fff;color:var(--c,var(--accent));border:1px solid var(--c,var(--accent))}

/* 3カードのグリッド */
.ag-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}
.ag-card{position:relative;background:var(--card);border:1px solid var(--line);
  border-radius:var(--radius);box-shadow:var(--shadow);
  border-top:4px solid var(--c,var(--accent));padding:20px 18px 18px}
.ag-card-tag{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.06em;
  text-transform:uppercase;color:#fff;background:var(--c,var(--accent));
  padding:3px 12px;border-radius:999px;margin-bottom:10px}
.ag-card-h{font-size:1.02rem;font-weight:700;margin:0 0 12px;color:var(--text)}
.ag-role{font-size:.88rem;color:var(--text);margin:0 0 12px;line-height:1.65}
.ag-sub{font-size:.74rem;font-weight:700;color:var(--sub);margin:14px 0 7px}
.ag-sub:first-of-type{margin-top:0}

/* 箇条書き（判断基準・連携） */
.ag-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.ag-list li{position:relative;font-size:.83rem;color:var(--text);line-height:1.55;
  padding-left:18px}
.ag-list li::before{content:"";position:absolute;left:2px;top:.55em;width:7px;height:7px;
  border-radius:2px;background:var(--c,var(--accent))}
.ag-list-flow li{color:var(--sub)}

/* スキルの矢印フロー */
.ag-flow{display:flex;flex-wrap:wrap;align-items:center;gap:7px;margin-bottom:4px}
.ag-node{font-size:.8rem;font-weight:600;color:var(--text);background:#f3eff8;
  border:1px solid var(--line);border-radius:9px;padding:5px 11px;line-height:1.3}
.ag-arrow{color:var(--c,var(--accent));font-weight:700;font-size:.9rem}

/* スケジュール */
.ag-jobs{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:9px}
.ag-job{display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  background:#faf8fd;border:1px solid var(--line);border-radius:11px;
  border-left:4px solid var(--c,var(--accent));padding:9px 13px}
.ag-job-name{font-size:.86rem;font-weight:700;color:var(--text)}
.ag-job-freq{font-size:.78rem;color:var(--accent);background:#efe9f8;
  padding:2px 9px;border-radius:999px;margin-left:auto}
.ag-job-off{font-size:.72rem;color:#b3261e;background:#fdecec;padding:2px 8px;border-radius:999px}
.ag-job.is-off{opacity:.6}
.ag-job.is-off .ag-job-freq{background:#f0eef5;color:var(--sub)}
.ag-sched-note{font-size:.78rem;margin:12px 0 0}
.ag-manual{font-size:.92rem;color:var(--text);display:flex;align-items:center;gap:8px;margin:4px 0}
.ag-manual-icon{font-size:1.2rem}

.ag-empty{font-size:.8rem;color:var(--sub);font-style:normal;margin:6px 0 0}

@media (max-width:640px){
  .ag-hero{gap:14px;padding:18px;flex-direction:column;align-items:stretch;text-align:center}
  .ag-hero-av{width:100%;height:auto;aspect-ratio:1/1;border-radius:16px}  /* スマホは横100% */
  .ag-hero-name{font-size:1.28rem}
}


/* ===== village ===== */
/* ============================================================
   village.php — AIの村マップ 専用スタイル（追加分のみ）
   既存の dashboard.css は変更せず、このブロックを末尾に追記する想定。
   ============================================================ */



/* ===== 承認待ち（approvals.php）===== */
.appr-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:16px 18px;margin-bottom:14px;border-left:4px solid var(--accent)}
.appr-head{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:8px}
.appr-head strong{font-size:1rem}
.appr-meta{font-size:.74rem;color:var(--sub);margin-left:auto}
.appr-body{background:var(--bg);border:1px solid var(--line);border-radius:10px;padding:12px 14px;
  font-size:.82rem;line-height:1.7;white-space:pre-wrap;word-break:break-word;margin:0 0 12px;
  font-family:ui-monospace,Menlo,"Hiragino Sans",monospace;max-height:280px;overflow:auto}
.appr-actions{display:flex;gap:10px}


/* ===== 組織図（index.php）社長→統括→2カラム横並び ===== */
.org-top{display:flex;flex-direction:column;align-items:center;gap:0;margin:6px 0 4px}
.org-leader{background:var(--card);border:1px solid var(--line);border-top:5px solid var(--c,#888);
  border-radius:var(--radius);box-shadow:var(--shadow);padding:14px 22px;text-align:center;min-width:240px}
.org-leader.prez{border-top-width:6px}
.org-leader-tag{font-size:.72rem;font-weight:700;color:var(--c,var(--accent));margin-bottom:8px}
.org-leader-ava{width:56px;height:56px;border-radius:50%;object-fit:cover;border:3px solid var(--c,#ddd);
  display:block;margin:0 auto 6px}
.org-leader-ava.init{display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1.3rem}
.org-leader-name{font-weight:700;font-size:1.05rem}
.org-leader-role{font-size:.74rem;color:var(--sub);margin-top:2px;max-width:300px}
.org-line{color:var(--line);font-size:1.2rem;line-height:1.1;padding:2px 0}
.org-note{text-align:center;font-size:.82rem;color:var(--sub);margin:14px 0 18px}
.org-note strong{color:var(--accent)}

.org-cols{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:start}
@media (max-width:760px){.org-cols{grid-template-columns:1fr}}
.org-group{background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);padding:14px}
.org-group.biz{background:#f3f8fb}
.org-group.common{background:#faf6f0}
.org-group-title{font-size:1rem;font-weight:800;margin:0 0 12px;color:var(--text)}
.org-group-title span{font-size:.72rem;font-weight:600;color:var(--sub);margin-left:6px}
.org-group .dept{margin-bottom:16px}
.org-group .dept:last-child{margin-bottom:0}
.org-group .dept-title{font-size:.92rem}
.org-group .agent-grid{grid-template-columns:1fr}


/* ===== 組織図v2：課ごとボックス／課長TOP→担当ぶら下げ ===== */
.dept-block{margin-bottom:18px}
.dept-h{font-size:.92rem;font-weight:800;color:var(--text);margin:0 0 8px;padding-left:8px;border-left:3px solid var(--sub)}
.ka-box{background:#fff;border:1.5px solid var(--c,#ccc);border-radius:12px;padding:10px 12px;margin-bottom:10px;
  box-shadow:var(--shadow);border-top:4px solid var(--c,#ccc)}
.ka-box-title{font-size:.82rem;font-weight:800;color:var(--c,var(--text));margin-bottom:8px}
.ka-box-title .badge{margin-left:6px}
/* リーダー（課長） */
.ka-lead{display:flex;align-items:center;gap:10px;padding:8px;border-radius:9px;background:var(--bg);
  color:inherit;margin-bottom:8px;border-left:4px solid var(--c,#888)}
.ka-lead:hover{background:#f1ecf8}
.ka-ava{width:38px;height:38px;border-radius:50%;object-fit:cover;flex-shrink:0;border:2px solid var(--c,#ddd)}
.ka-ava.init{display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1rem}
.ka-lead-body{display:flex;flex-direction:column;line-height:1.35}
.ka-lead-name{font-weight:700;font-size:.9rem}
.lead-tag{font-size:.62rem;font-weight:700;color:#fff;background:var(--c,var(--accent));padding:1px 7px;border-radius:999px;margin-left:4px;vertical-align:middle}
.ka-lead-role{font-size:.72rem;color:var(--sub)}
/* 担当（ぶら下げチップ） */
.ka-staff-label{font-size:.68rem;color:var(--sub);margin:2px 0 5px;font-weight:700}
.ka-staff{display:flex;flex-wrap:wrap;gap:6px}
.staff-chip{display:inline-flex;align-items:center;gap:6px;font-size:.74rem;color:var(--text);
  background:#fff;border:1px solid var(--line);border-left:3px solid var(--c,#aaa);border-radius:7px;padding:4px 9px}
.staff-chip:hover{background:var(--bg)}
.chip-ava{width:18px;height:18px;border-radius:50%;object-fit:cover}
.chip-dot{width:9px;height:9px;border-radius:50%;background:var(--c,#aaa);display:inline-block}


/* ===== projects ===== */
/* ============================================================
   projects.php — 接続プロジェクト一覧カード
   ============================================================ */
.proj-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}
.proj-card{display:flex;flex-direction:column}
.proj-card .name{font-size:1rem;margin-bottom:10px}

.proj-assign-title{font-size:.74rem;color:var(--sub);font-weight:700;margin:4px 0 6px}
.proj-assign{list-style:none;margin:0 0 12px;padding:0;display:flex;flex-direction:column;gap:6px}
.proj-assign li{display:flex;align-items:center;flex-wrap:wrap;gap:4px;font-size:.86rem}
.proj-assign-name{font-weight:600;color:var(--text)}
.proj-assign .badge{margin-left:0}
.proj-noassign{margin:4px 0 12px}

.proj-stats{display:flex;align-items:center;flex-wrap:wrap;gap:8px;
  margin-top:auto;padding-top:10px;border-top:1px dashed var(--line);font-size:.8rem}
.proj-pill{display:inline-block;padding:2px 10px;border-radius:999px;
  background:#efe9f8;color:var(--accent);font-weight:600;font-size:.76rem}
.proj-last{color:var(--sub)}
.proj-last time{color:var(--text)}
.proj-stat-muted{color:var(--sub);font-style:italic}

.proj-foot{margin-top:12px}
.proj-foot .btn{width:100%;text-align:center}

/* ===== activity ===== */
/* ============================================================
   activity.php — 行動ログ用スタイル
   ============================================================ */
.act-filter{display:flex;gap:14px;flex-wrap:wrap;align-items:flex-end;
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:14px 16px;margin-bottom:22px}
.act-filter label{display:flex;flex-direction:column;gap:4px;font-size:.78rem;color:var(--sub)}
.act-filter select{font:inherit;padding:7px 10px;border:1px solid var(--line);border-radius:10px;
  background:#fff;color:var(--text);min-width:160px}
.act-filter-btns{display:flex;gap:8px;align-items:center}
.act-btn{font:inherit;font-size:.85rem;padding:8px 16px;border:0;border-radius:999px;
  background:var(--accent);color:#fff;cursor:pointer;display:inline-block}
.act-btn:hover{filter:brightness(1.06)}
.act-btn-clear{background:#efe9f8;color:var(--accent)}
.act-table-wrap{overflow-x:auto}
.act-table{min-width:760px}
.act-table .act-time{white-space:nowrap;font-size:.78rem;color:var(--sub);width:1%}
.act-table .act-action{font-weight:600;min-width:300px;max-width:440px}
.act-table .act-reason{color:var(--sub);font-size:.84rem}
.act-dim{color:var(--line)}
@media(max-width:640px){
  .act-filter{flex-direction:column;align-items:stretch}
  .act-filter select{min-width:0;width:100%}
  .act-filter-btns{justify-content:flex-start}
}

/* ===== reflection ===== */
/* ===== reflection.php — 振り返り・学び ===== */
.reflection-cta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.reflection-cta a{color:#1f7a3d;font-weight:700;text-decoration:underline}

/* 横スクロール可（モバイル両対応：iOS Safari / Android Chrome） */
.reflection-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.reflection-table{min-width:760px}
.reflection-table td{vertical-align:top;font-size:.82rem}
.reflection-time{white-space:nowrap;color:var(--sub);font-size:.76rem;width:1%}
.reflection-summary{font-weight:600;max-width:420px;min-width:300px}
/* 日時2行（行動ログ・リフレクション共通） */
.r-date{display:block;font-weight:700;color:var(--text)}
.r-time{display:block;font-size:.7rem;opacity:.8}
.reflection-cond{color:var(--sub);max-width:200px}
.reflection-dash{color:var(--line)}

/* 効果バッジ（◎○△×を色分け） */
.reflection-effect-cell{text-align:center}
.reflection-effect{display:inline-block;font-weight:700;font-size:.9rem;line-height:1;
  padding:3px 8px;border-radius:999px;background:#efe9f8;color:var(--accent)}
.reflection-effect.effect-top{background:#e8f6ec;color:#1f7a3d}   /* ◎ */
.reflection-effect.effect-good{background:#eef3fb;color:#3a6bb5}  /* ○ */
.reflection-effect.effect-mid{background:#fdf6e3;color:#9a7d1a}   /* △ */
.reflection-effect.effect-bad{background:#fdecec;color:#b3261e}   /* × */

/* 状態バッジ */
.badge-joseki{background:#e8f6ec;color:#1f7a3d;font-weight:700}
.badge-kouho{background:#f1eef7;color:var(--sub)}

/* 定石の行は淡くハイライト */
.row-joseki{background:#f4fbf6}
.row-joseki .reflection-summary{color:#1f7a3d}

/* ===== プロジェクト 稼働ON/OFF ===== */
.proj-head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}
.proj-badge{font-size:.66rem;font-weight:700;padding:2px 8px;border-radius:999px;margin-left:6px;vertical-align:middle}
.proj-badge.on{background:#e3f4e8;color:#2f8a4d}
.proj-badge.on::before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:#34a853;margin-right:4px;vertical-align:middle}
.proj-badge.off{background:#e9e9ec;color:#8a8a93}
.proj-toggle{margin:0;flex-shrink:0}
.proj-toggle-btn{padding:4px 11px;font-size:.74rem}
.proj-assign-title{font-size:.74rem;color:var(--sub);font-weight:700;margin:8px 0 4px}
/* OFF＝薄いグレー（下に移動はPHPのソートで実施済み）*/
.proj-card.proj-off{opacity:.5;filter:grayscale(.85)}
.proj-card.proj-off .proj-badge.off{opacity:1}
.proj-card.proj-off:hover{opacity:.78}


/* ===== 社員カードの「担当：〇〇」枠 ===== */
.agent-card .tantou-box{display:inline-flex;align-items:center;gap:7px;margin:2px 0 8px;
  padding:4px 10px;border-radius:8px;background:color-mix(in srgb, var(--c,#888) 12%, #fff);
  border:1px solid color-mix(in srgb, var(--c,#888) 35%, #fff);align-self:flex-start}
.agent-card .tantou-label{font-size:.66rem;font-weight:700;color:#fff;background:var(--c,#888);
  padding:1px 7px;border-radius:999px}
.agent-card .tantou-val{font-size:.86rem;font-weight:700;color:var(--text)}

/* ===== AIの街マップ（背景画像＋キャラ配置）===== */
.city-intro{text-align:center;margin:4px 0 16px}
.city-title{font-size:1.6rem;font-weight:800;margin:0 0 6px;
  background:linear-gradient(90deg,#7aa7ff,#c08cff,#65d8e0);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:#8E6FC4}
.city-catch{font-size:.9rem;color:var(--sub);margin:0;line-height:1.7}
.city-summary{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-bottom:16px}
.city-chip{background:var(--card);border:1px solid var(--line);border-radius:999px;padding:6px 14px;font-size:.82rem;font-weight:700;color:var(--text);box-shadow:var(--shadow)}

/* マップ本体（背景画像 cover・キャラを絶対配置）*/
.mp-map{position:relative;width:100%;aspect-ratio:16/10;min-height:460px;border-radius:18px;overflow:hidden;
  background-size:cover;background-position:center;box-shadow:0 8px 28px rgba(20,20,60,.25);border:1px solid var(--line)}
/* 背景未設定時のフォールバック（夜空グラデ）*/
.mp-map.mp-nobg{background-image:radial-gradient(1200px 220px at 78% -50px,rgba(120,160,255,.28),transparent 60%),linear-gradient(180deg,#0b1338,#1d2e6e)}

/* キャラ（絵＋名前だけ）*/
.mp-spot{position:absolute;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:3px;
  text-decoration:none;cursor:pointer;z-index:2;transition:transform .15s ease,filter .15s ease}
.mp-spot:hover,.mp-spot:focus-visible{transform:translate(-50%,-56%) scale(1.1);z-index:9;outline:none;filter:drop-shadow(0 6px 10px rgba(0,0,0,.3))}
.mp-ava{width:50px;height:50px;border-radius:50%;overflow:hidden;border:3px solid #fff;background:var(--c,#ccc);
  display:flex;align-items:center;justify-content:center;box-shadow:0 2px 7px rgba(0,0,0,.35)}
.mp-ava img{width:100%;height:100%;object-fit:cover;display:block}
.mp-init{color:#fff;font-weight:800;font-size:1.25rem;line-height:1}
.mp-name{background:rgba(255,255,255,.94);border-radius:999px;padding:1px 9px;font-size:.72rem;font-weight:700;color:#2c2540;
  white-space:nowrap;box-shadow:0 1px 4px rgba(0,0,0,.25)}

@media (max-width:600px){
  .mp-map{min-height:360px}
  .mp-ava{width:40px;height:40px}
  .mp-init{font-size:1rem}
  .mp-name{font-size:.64rem;padding:1px 7px}
}

/* ===== メンバー系タブ（組織図/ギャラリー/社員一覧） ===== */
.view-tabs{display:flex;gap:6px;flex-wrap:wrap;margin:0 0 18px;border-bottom:2px solid var(--line);padding-bottom:0}
.view-tabs a{padding:8px 18px;font-size:.92rem;font-weight:700;color:var(--sub);
  border:2px solid transparent;border-bottom:none;border-radius:10px 10px 0 0;margin-bottom:-2px}
.view-tabs a:hover{color:var(--accent);background:#f3eefb}
.view-tabs a.active{color:var(--accent);background:var(--card);border-color:var(--line);border-bottom:2px solid var(--card)}

/* ===== 横断レポート ===== */
.reports-wrap{display:grid;grid-template-columns:170px 1fr;gap:16px;align-items:start}
.reports-list{display:flex;flex-direction:column;gap:4px;position:sticky;top:78px}
.reports-item{padding:9px 12px;border-radius:9px;font-size:.86rem;font-weight:700;color:var(--text);
  background:var(--card);border:1px solid var(--line)}
.reports-item:hover{border-color:var(--accent);color:var(--accent)}
.reports-item.active{background:#ffe3ee;color:#c44d77;border-color:#f3c2d4}
.reports-body{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px 20px;min-width:0}
.report-pre{white-space:pre-wrap;word-break:break-word;font-family:-apple-system,"Hiragino Sans",sans-serif;
  font-size:.9rem;line-height:1.8;color:var(--text);margin:0}
@media (max-width:640px){.reports-wrap{grid-template-columns:1fr}.reports-list{flex-direction:row;flex-wrap:wrap;position:static}}

/* ===== スマホ：サマリー(在籍/部署/スキル)を横3列に ===== */
@media (max-width:480px){
  .dash-summary{gap:8px;flex-wrap:nowrap}
  .dash-stat{flex:1 1 0;min-width:0;padding:11px 6px;text-align:center}
  .dash-stat b{font-size:1.35rem}
  .dash-stat span{font-size:.68rem}
}

/* ===== 編集ロック（名前/部署/課/担当/役割はLiSA経由のみ） ===== */
.locked-note{font-size:.78rem;color:#8a6d2f;background:#fdf6e3;border:1px solid #f0e2b8;
  border-radius:10px;padding:9px 12px;margin:0 0 14px;line-height:1.6}
.fld.locked>span{color:#b3a7c9}
.fld.locked input[readonly]{background:#f1eef6;color:#8b82a0;cursor:not-allowed;border-style:dashed}
.fld.locked input[readonly]:focus{outline:none;border-color:var(--line)}

/* ===== 社員一覧：画像クリックで編集へ ===== */
.avatar-link{display:inline-block;border-radius:50%;line-height:0;cursor:pointer;
  transition:box-shadow .15s ease,transform .15s ease}
.avatar-link:hover{box-shadow:0 0 0 3px var(--c,#888),0 4px 12px rgba(90,70,140,.22);transform:translateY(-1px)}

/* ===== ログイン画面 ===== */
.login-body{min-height:100vh;margin:0;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#f6f4fb 0%,#efe9f8 100%);padding:20px}
.login-card{background:var(--card);border:1px solid var(--line);border-radius:18px;
  box-shadow:0 8px 30px rgba(90,70,140,.14);padding:32px 28px;width:100%;max-width:380px;text-align:center}
.login-logo{font-weight:700;color:var(--text);font-size:1.05rem;margin-bottom:18px}
.login-title{font-size:1.3rem;margin:0 0 6px;color:var(--text)}
.login-note{font-size:.84rem;color:var(--sub);margin:0 0 14px}
.login-err{background:#fdecec;border:1px solid #f3c2c2;color:#b3261e;border-radius:10px;
  padding:9px 12px;font-size:.84rem;margin:0 0 14px}
.login-fld{display:block;text-align:left;margin-bottom:14px}
.login-fld>span{display:block;font-size:.8rem;color:var(--sub);margin-bottom:5px}
.login-fld input{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:10px;
  font-size:1rem;font-family:inherit;background:#fff;color:var(--text)}
.login-fld input:focus{outline:none;border-color:var(--accent)}
.login-btn{width:100%;padding:12px;border:0;border-radius:10px;background:var(--accent);color:#fff;
  font-size:1rem;font-weight:700;cursor:pointer;font-family:inherit;margin-top:4px}
.login-btn:hover{filter:brightness(1.06)}
.login-foot{font-size:.74rem;color:var(--sub);margin:16px 0 0}
/* ヘッダのログアウトボタン */
.nav-logout{display:inline}
.nav-logout button{font:inherit;font-size:.8rem;color:var(--sub);background:none;border:0;
  cursor:pointer;padding:5px 11px;border-radius:999px}
.nav-logout button:hover{color:#b3261e;background:#fdecec}
