/* ============================================================
   jp-bridge 本番運用コンソール プロトタイプ 共通デザイン
   indigo/rose 系（マモリタイハブの teal と区別・demo の jpb-shared とも別物）
   ============================================================ */
:root{
  --indigo:#4f46e5; --indigo-2:#6366f1; --indigo-soft:#e0e7ff;
  --rose:#e11d48; --rose-soft:#ffe4e6;
  --navy:#1e1b4b;
  --bg:#f5f6fb; --card:#fff; --text:#1e1b2e; --muted:#6b7280;
  --border:#e5e7eb; --border-soft:#f1f2f6;
  --green:#16a34a; --green-soft:#dcfce7;
  --amber:#d97706; --amber-soft:#fef3c7;
  --red:#dc2626; --red-soft:#fee2e2;
  --radius:12px; --shadow:0 8px 24px rgba(30,27,75,.07);
}
*{margin:0;padding:0;box-sizing:border-box;}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","Hiragino Sans","Yu Gothic","Malgun Gothic",sans-serif;background:var(--bg);color:var(--text);line-height:1.6;font-size:14px;}
a{color:inherit;text-decoration:none;}
.muted{color:var(--muted);} .small{font-size:12px;} .center{text-align:center;} .mono{font-family:Consolas,monospace;}

.mocknote{background:linear-gradient(90deg,var(--indigo-soft),#fff);border-bottom:1px solid #c7d2fe;color:#3730a3;font-size:12px;font-weight:700;padding:7px 16px;text-align:center;}

.topbar{background:var(--navy);color:#fff;padding:11px 20px;display:flex;align-items:center;gap:12px;}
.topbar .logo{font-weight:800;font-size:16px;display:flex;align-items:center;gap:8px;}
.topbar .logo .mark{background:linear-gradient(135deg,var(--indigo),var(--rose));width:28px;height:28px;border-radius:8px;display:grid;place-items:center;font-size:13px;}
.topbar .env{font-size:10px;font-weight:800;background:var(--rose);padding:2px 8px;border-radius:20px;}
.topbar .who{margin-left:auto;font-size:13px;color:#c7d2fe;display:flex;align-items:center;gap:10px;}
.topbar .who .role{background:rgba(255,255,255,.13);padding:3px 10px;border-radius:20px;font-weight:700;font-size:11px;}

.app{display:grid;grid-template-columns:220px 1fr;min-height:calc(100vh - 50px);}
.sidebar{background:#fff;border-right:1px solid var(--border);padding:14px 10px;}
.sidebar .grp{font-size:10px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin:14px 8px 6px;}
.navit{display:flex;align-items:center;gap:9px;padding:9px 12px;border-radius:9px;color:#374151;font-weight:600;font-size:13px;cursor:pointer;margin-bottom:2px;}
.navit:hover{background:var(--border-soft);}
.navit.on{background:var(--indigo-soft);color:#3730a3;font-weight:800;}
.main{padding:22px 26px;overflow:auto;}
.page{display:none;} .page.on{display:block;animation:f .2s ease;}
@keyframes f{from{opacity:0;transform:translateY(4px);}to{opacity:1;transform:none;}}
h1.pt{font-size:20px;font-weight:800;margin-bottom:4px;}
.sub{color:var(--muted);font-size:13px;margin-bottom:18px;}

.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:18px;}
.kpi{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;}
.kpi .n{font-size:25px;font-weight:800;color:var(--indigo);line-height:1.1;}
.kpi .n.red{color:var(--red);} .kpi .n.amber{color:var(--amber);} .kpi .n.green{color:var(--green);}
.kpi .l{font-size:11.5px;color:var(--muted);font-weight:700;margin-top:3px;}

.panel{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;margin-bottom:16px;box-shadow:var(--shadow);}
.panel h3{font-size:14px;font-weight:800;margin-bottom:12px;display:flex;align-items:center;gap:8px;}
.panel h3 .badge{margin-left:auto;}
.card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:14px;}
.card.indigo{background:#eef2ff;border-color:var(--indigo-soft);}
.card.amber{background:#fffbeb;border-color:#fde68a;}
.card.red{background:#fef2f2;border-color:#fca5a5;}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;}
@media(max-width:760px){.grid2,.grid3,.app{grid-template-columns:1fr;}}

table.data{width:100%;border-collapse:collapse;font-size:13px;}
table.data th,table.data td{text-align:left;padding:9px 11px;border-bottom:1px solid var(--border-soft);vertical-align:middle;}
table.data th{background:#fafbff;font-size:11px;color:var(--muted);font-weight:800;text-transform:uppercase;letter-spacing:.03em;}
table.data tr:hover td{background:#fafaff;}

.pill,.badge{display:inline-block;padding:2px 10px;border-radius:20px;font-size:11px;font-weight:800;}
.pill.g{background:var(--green-soft);color:var(--green);} .pill.a{background:var(--amber-soft);color:var(--amber);}
.pill.r{background:var(--red-soft);color:var(--red);} .pill.i{background:var(--indigo-soft);color:#3730a3;}
.pill.gray{background:var(--border-soft);color:var(--muted);}

.btn{display:inline-flex;align-items:center;gap:7px;border:none;cursor:pointer;font-weight:800;font-size:13px;padding:10px 16px;border-radius:10px;background:var(--border-soft);color:#374151;}
.btn:hover{filter:brightness(.98);}
.btn.primary{background:linear-gradient(135deg,var(--indigo),var(--indigo-2));color:#fff;}
.btn.danger{background:linear-gradient(135deg,var(--rose),#be123c);color:#fff;}
.btn.ghost{background:#fff;border:1px solid var(--border);}
.btn.sm{padding:6px 11px;font-size:12px;}
.btn.block{display:flex;width:100%;justify-content:center;}

.dot{width:9px;height:9px;border-radius:50%;display:inline-block;}
.dot.g{background:var(--green);} .dot.a{background:var(--amber);} .dot.r{background:var(--red);}

.filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px;align-items:center;}
.sel,.inp{border:1px solid var(--border);border-radius:9px;padding:8px 11px;font-size:13px;background:#fff;}
.field{margin-bottom:12px;}
.field label{display:block;font-size:11.5px;color:var(--muted);font-weight:800;margin-bottom:4px;}
.field .inp{width:100%;background:#f8fafc;}

.tline{font-size:12.5px;border-left:2px solid var(--indigo-soft);padding:2px 0 12px 14px;position:relative;margin-left:6px;}
.tline::before{content:"";position:absolute;left:-6px;top:4px;width:9px;height:9px;border-radius:50%;background:var(--indigo);}
.bar{height:8px;border-radius:6px;background:var(--border);overflow:hidden;}
.bar>i{display:block;height:100%;background:var(--indigo);}

.overlay{position:fixed;inset:0;background:rgba(30,27,75,.5);display:none;place-items:center;z-index:50;padding:20px;}
.overlay.on{display:grid;}
.modal{background:#fff;border-radius:16px;max-width:560px;width:100%;padding:22px;box-shadow:0 24px 60px rgba(0,0,0,.3);max-height:88vh;overflow:auto;}
.modal h3{font-size:17px;font-weight:800;margin-bottom:10px;}
