:root{
  --bg:#edf3f9;--panel:#fff;--line:#dbe5f0;--text:#172235;--muted:#617089;
  --nav:#101828;--nav2:#18243a;--primary:#2f6df6;--soft:#eef4ff;--soft2:#f7fbff;
  --ok:#0f766e;--okbg:#e7fbf8;--mid:#9a6700;--midbg:#fff6df;--high:#b42318;--highbg:#fff1f1;
  --shadow:0 16px 44px rgba(20,34,65,.12);
  --r1:24px;--r2:18px;--r3:14px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:linear-gradient(180deg,#f8fbff 0%,var(--bg) 100%);color:var(--text);font-family:"Segoe UI","Hiragino Sans","Yu Gothic UI",sans-serif}
.app{display:flex;min-height:100vh}
.sidebar{width:290px;background:linear-gradient(180deg,var(--nav),var(--nav2));color:#fff;padding:28px 22px;display:flex;flex-direction:column;gap:22px;position:sticky;top:0;height:100vh;overflow-y:auto;box-shadow:12px 0 34px rgba(0,0,0,.15)}
.brand{display:flex;gap:14px;align-items:center;padding-bottom:18px;border-bottom:1px solid rgba(255,255,255,.12)}
.logo{width:54px;height:54px;border-radius:16px;background:linear-gradient(135deg,#4a89ff,#82b5ff);display:grid;place-items:center;font-size:24px;font-weight:900;box-shadow:0 12px 24px rgba(74,137,255,.35);flex-shrink:0}
.eyebrow{font-size:12px;letter-spacing:.12em;text-transform:uppercase;font-weight:800;color:var(--primary);margin-bottom:8px}
.sidebar .eyebrow{color:rgba(255,255,255,.65)}
.brand h2{margin:0;font-size:22px}
.brand p{margin:6px 0 0;color:rgba(255,255,255,.72);font-size:13px;line-height:1.65}
.label{font-size:13px;font-weight:800;color:rgba(255,255,255,.7);margin-bottom:10px}
.stack{display:flex;flex-direction:column;gap:10px}
.nav-btn,.domain-btn{width:100%;text-align:left;background:rgba(255,255,255,.06);color:#fff;border:1px solid rgba(255,255,255,.13);border-radius:14px;padding:14px 14px;font-size:14px;font-weight:800;cursor:pointer;transition:.18s ease}
.nav-btn small,.domain-btn small{display:block;font-size:12px;font-weight:500;color:rgba(255,255,255,.68);margin-top:4px;line-height:1.5}
.nav-btn:hover,.domain-btn:hover{transform:translateY(-1px);background:rgba(255,255,255,.1)}
.nav-btn.active,.domain-btn.active{background:linear-gradient(135deg,rgba(74,137,255,.28),rgba(130,181,255,.18));border-color:rgba(119,169,255,.95)}
.sidebar-note{margin-top:auto;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:18px;padding:16px}
.sidebar-note h3{margin:0 0 10px;font-size:14px}
.sidebar-note ul{margin:0;padding-left:18px;font-size:13px;line-height:1.7;color:rgba(255,255,255,.82)}
.main{flex:1;padding:28px;min-width:0}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r1);box-shadow:var(--shadow)}
.hero{padding:28px 30px;display:flex;justify-content:space-between;gap:20px;align-items:flex-start;margin-bottom:22px;background:linear-gradient(135deg,#fff,#f7fbff)}
.hero h1{margin:0;font-size:30px;line-height:1.25}
.hero p{margin:10px 0 0;color:var(--muted);font-size:15px;line-height:1.8;max-width:760px}
.chips{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end;max-width:420px}
.chip{display:inline-flex;align-items:center;padding:10px 14px;border-radius:999px;background:var(--soft);border:1px solid #cfe0ff;color:var(--primary);font-size:13px;font-weight:800;white-space:nowrap}
.hidden{display:none!important}
.grid4{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-bottom:20px}
.kpi{padding:20px 22px;background:linear-gradient(180deg,#fff,#f7fbff)}
.kpi .k1{font-size:13px;font-weight:800;color:var(--muted);margin-bottom:10px}
.kpi .k2{font-size:34px;font-weight:900;line-height:1;margin-bottom:8px}
.kpi .k3{font-size:13px;color:var(--muted);line-height:1.6}
.grid2{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,1fr);gap:20px;margin-bottom:20px}
.grid2.eq{grid-template-columns:repeat(2,minmax(0,1fr))}
.panel{padding:22px}
.head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:18px}
.head h3{margin:0;font-size:20px;line-height:1.35}
.head p,.head span{margin:4px 0 0;color:var(--muted);font-size:13px;line-height:1.6}
.bars{display:flex;flex-direction:column;gap:14px}
.bar-row{display:grid;grid-template-columns:200px minmax(0,1fr) 72px;gap:14px;align-items:center}
.bar-meta strong{display:block;font-size:15px}
.bar-meta small{font-size:12px;color:var(--muted)}
.track{height:14px;border-radius:999px;background:linear-gradient(180deg,#edf2fa,#e3ebf8);border:1px solid #dae5f2;overflow:hidden}
.fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,#4f85ff,#7bb0ff)}
.bar-val{text-align:right;font-size:14px;font-weight:900;color:var(--primary)}
table{width:100%;border-collapse:collapse}
th,td{padding:12px 10px;border-bottom:1px solid #e7eef7;text-align:left;vertical-align:top;font-size:14px}
th{background:#f8fbff;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.04em;font-weight:900}
tbody tr:last-child td{border-bottom:none}
.badge{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:900;white-space:nowrap}
.badge.low{color:var(--ok);background:var(--okbg);border:1px solid #c8f2ec}
.badge.mid{color:var(--mid);background:var(--midbg);border:1px solid #ffe3a2}
.badge.high{color:var(--high);background:var(--highbg);border:1px solid #ffd3cf}
.tags,.pills{display:flex;flex-wrap:wrap;gap:10px}
.tag,.pill{display:inline-flex;align-items:center;gap:8px;padding:10px 12px;border-radius:999px;background:#f9fbff;border:1px solid var(--line);font-size:13px;font-weight:800}
.tag b,.pill b{color:var(--primary)}
.subcards{display:grid;gap:14px}
.subcard{background:var(--soft2);border:1px solid #e0e8f3;border-radius:16px;padding:16px}
.subcard h4{margin:0 0 8px;font-size:15px}
.subcard ul{margin:0;padding-left:18px;color:var(--muted);font-size:14px;line-height:1.75}
.filter{padding:18px 20px;display:flex;flex-direction:column;gap:14px;margin-bottom:20px}
.filter-row{display:flex;gap:14px;align-items:flex-end;flex-wrap:wrap}
.field{display:flex;flex-direction:column;gap:8px;flex:1;min-width:200px}
.field.narrow{min-width:160px;flex:0 0 180px}
.field.wide{flex:2;min-width:280px}
.field label{font-size:13px;font-weight:800;color:var(--muted)}
.search{width:100%;padding:12px 16px;border:1.5px solid #b7ceff;border-radius:14px;background:#fbfdff;font-size:14px;outline:none;box-shadow:0 0 0 3px rgba(47,109,246,.06)}
.search:focus{border-color:#7aaeff;box-shadow:0 0 0 4px rgba(47,109,246,.14)}
.quick{display:flex;gap:8px;flex-wrap:wrap}
.quick button{padding:8px 14px;border-radius:999px;border:1px solid #d7e3f4;background:#fff;font-size:13px;font-weight:800;color:var(--muted);cursor:pointer;transition:.15s ease;white-space:nowrap}
.quick button:hover{background:#f4f8ff;border-color:#b7ceff}
.quick button.active{background:var(--soft);color:var(--primary);border-color:#bcd2ff}
.reset-btn{width:100%;padding:12px 16px;border:1px solid var(--line);border-radius:14px;background:#fff;font-size:14px;font-weight:800;color:var(--muted);cursor:pointer}
.reset-btn:hover{background:var(--soft)}
.people{display:grid;grid-template-columns:320px minmax(0,1fr);gap:20px;align-items:start}
.list{padding:22px}
.members{display:flex;flex-direction:column;gap:12px;max-height:1100px;overflow:auto;padding-right:4px}
.member{border:1px solid #e0e9f5;border-radius:18px;padding:16px;background:linear-gradient(180deg,#fff,#f8fbff);cursor:pointer;transition:.18s ease}
.member:hover{transform:translateY(-1px);border-color:#c8daf6}
.member.active{border-color:#8cb3ff;background:linear-gradient(180deg,#fff,#eef5ff);box-shadow:inset 0 0 0 1px rgba(47,109,246,.12)}
.member h4{margin:0;font-size:16px}
.member .m1{margin-top:6px;font-size:13px;color:var(--muted);line-height:1.6}
.member .m2{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.member .m2 .pill{padding:7px 10px;font-size:12px}
.detail{display:grid;gap:20px}
.hero2{padding:22px;display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,.8fr);gap:20px}
.profile h3{margin:0;font-size:28px;line-height:1.2}
.profile .psub{margin-top:8px;color:var(--muted);font-size:14px;line-height:1.8}
.stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:14px}
.stat{border:1px solid #e1e9f5;border-radius:16px;padding:14px;background:#fbfdff}
.stat .s1{font-size:12px;font-weight:800;color:var(--muted);margin-bottom:8px}
.stat .s2{font-size:22px;font-weight:900;line-height:1}
.summary{border:1px solid #e1e9f5;border-radius:18px;padding:16px;background:linear-gradient(180deg,#fff,#f8fbff);display:grid;gap:12px}
.summary h4{margin:0;font-size:14px}
.summary p{margin:0;font-size:14px;color:var(--muted);line-height:1.75}
.dots{display:inline-flex;align-items:center;gap:5px}
.dot{width:10px;height:10px;border-radius:50%;background:#d9e3f1}
.dot.on{background:linear-gradient(180deg,#4f85ff,#7bb0ff);box-shadow:0 0 0 4px rgba(47,109,246,.08)}
.level{display:inline-flex;align-items:center;gap:10px}
.level span{font-size:13px;font-weight:900;color:var(--primary)}
.snote{margin-top:2px;font-size:12px;color:var(--muted);line-height:1.6}
.timeline{display:grid;gap:14px}
.titem{display:grid;grid-template-columns:160px minmax(0,1fr);gap:16px;padding:18px 0;border-bottom:1px solid #e7eef7}
.titem:last-child{border-bottom:none;padding-bottom:0}
.tperiod{padding-top:3px;font-size:13px;font-weight:900;color:var(--primary)}
.tcontent{display:grid;gap:10px}
.tcontent h4{margin:0;font-size:17px;line-height:1.4}
.tmeta{font-size:13px;color:var(--muted);line-height:1.6}
.tdesc{font-size:14px;color:var(--muted);line-height:1.8}
.notes{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px}
.empty{border:1px dashed #c8d7e8;border-radius:18px;padding:24px;text-align:center;background:#fbfdff;color:var(--muted);font-size:14px}
.placeholder{padding:40px;min-height:520px;display:grid;place-items:center}
.placeholder .box{max-width:760px;text-align:center;padding:40px 34px}
.placeholder h3{margin:0 0 12px;font-size:30px;line-height:1.25}
.placeholder p{margin:0;color:var(--muted);font-size:15px;line-height:1.85}
.loading{display:flex;align-items:center;justify-content:center;min-height:400px;font-size:15px;color:var(--muted)}
/* AI Insight */
.insight-wrap{display:grid;grid-template-columns:minmax(0,1.3fr) minmax(0,.7fr);gap:24px;align-items:start}
.insight-left{display:grid;gap:14px}
.insight-comment{background:var(--soft2);border:1px solid #dce8f8;border-radius:16px;padding:18px 20px;font-size:14px;line-height:1.85;color:var(--text)}
.insight-sec{border-left:3px solid var(--primary);padding:10px 16px;background:var(--soft2);border-radius:0 12px 12px 0}
.insight-sec strong{display:block;font-size:11px;font-weight:900;color:var(--muted);letter-spacing:.06em;text-transform:uppercase;margin-bottom:6px}
.insight-sec p{margin:0;font-size:13px;line-height:1.75;color:var(--text)}
.match-list{display:grid;gap:12px;margin-top:4px}
.match-row{display:grid;gap:5px}
.match-lbl{display:flex;justify-content:space-between;font-size:13px;font-weight:800}
.match-pct{color:var(--primary)}
.match-track{height:10px;border-radius:999px;background:#e4ecf8;overflow:hidden}
.match-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,#4f85ff,#7bb0ff)}
.match-note{font-size:11px;color:var(--muted);margin-top:10px;line-height:1.6}
.tag-chip{display:inline-flex;align-items:center;padding:7px 14px;border-radius:999px;background:var(--soft);border:1px solid #c5d9ff;color:var(--primary);font-size:12px;font-weight:800}
@media (max-width:980px){
  .insight-wrap{grid-template-columns:1fr}
}
@media (max-width:980px){
  .app{flex-direction:column}
  .sidebar{width:100%;height:auto;position:static}
  .main{padding:18px}
  .hero{padding:22px;flex-direction:column}
  .hero h1{font-size:24px}
  .chips{justify-content:flex-start}
  .bar-row{grid-template-columns:1fr;gap:8px}
  .stats{grid-template-columns:1fr}
  .titem{grid-template-columns:1fr;gap:8px}
  .grid4{grid-template-columns:1fr}
  .people{grid-template-columns:1fr}
  .grid2{grid-template-columns:1fr}
  .hero2{grid-template-columns:1fr}
  .notes{grid-template-columns:1fr}
}
/* ── スキル登録/更新 ── */
.nav-btn.edit-btn.active{background:linear-gradient(135deg,rgba(74,137,255,.28),rgba(130,181,255,.18));border-color:rgba(119,169,255,.95)}
.nav-btn .new-badge{display:inline-block;font-size:10px;font-weight:900;padding:2px 7px;background:#f59e0b;color:#fff;border-radius:999px;margin-left:6px;vertical-align:middle}
.edit-people{display:grid;grid-template-columns:300px minmax(0,1fr);gap:20px;align-items:start}
.edit-left{display:flex;flex-direction:column}
.edit-member-list{display:flex;flex-direction:column;gap:10px;max-height:1100px;overflow-y:auto;padding-right:4px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-full{grid-column:1/-1}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-label{font-size:13px;font-weight:800;color:var(--text)}
.form-label .req{color:#ef4444;margin-left:2px}
.form-input,.form-select,.form-textarea{padding:10px 14px;border:1.5px solid var(--line);border-radius:12px;font-size:14px;color:var(--text);font-family:inherit;outline:none;background:#fff;transition:border .2s}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#b7ceff;box-shadow:0 0 0 4px rgba(47,109,246,.1)}
.form-textarea{resize:vertical;min-height:80px}
.form-hint{font-size:11px;color:var(--muted)}
.select-tag-wrap{position:relative}
.select-tag-box{display:flex;flex-wrap:wrap;gap:6px;padding:8px 12px;border:1.5px solid var(--line);border-radius:12px;background:#fff;min-height:46px;align-items:center;cursor:pointer;transition:border .2s}
.select-tag-box:focus-within{border-color:#b7ceff;box-shadow:0 0 0 4px rgba(47,109,246,.1)}
.tag-item{background:var(--soft);color:var(--primary);font-size:12px;font-weight:700;padding:3px 8px;border-radius:999px;display:flex;align-items:center;gap:4px;white-space:nowrap}
.tag-item .del{cursor:pointer;opacity:.6;font-size:13px;line-height:1;border:none;background:none;color:inherit;padding:0}
.tag-item .del:hover{opacity:1}
.tag-ph{font-size:14px;color:var(--muted);user-select:none}
.sel-dropdown{display:none;position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1.5px solid #b7ceff;border-radius:14px;box-shadow:0 8px 28px rgba(30,58,95,.14);z-index:150;overflow:hidden;max-height:260px;flex-direction:column}
.sel-dropdown.open{display:flex}
.sel-search{padding:10px 14px;border:none;border-bottom:1px solid var(--line);font-size:14px;outline:none;font-family:inherit}
.sel-list{overflow-y:auto}
.sel-item{padding:10px 14px;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:space-between;transition:background .1s}
.sel-item:hover{background:var(--soft)}
.sel-item.selected{color:var(--primary);font-weight:700}
.sel-item .chk{color:var(--primary)}
.lang-select{width:100%;padding:8px 28px 8px 10px;border:1.5px solid var(--line);border-radius:10px;font-size:14px;color:var(--text);font-family:inherit;outline:none;appearance:none;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236B7280' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat right 10px center;cursor:pointer}
.lang-select:focus{border-color:#b7ceff;box-shadow:0 0 0 4px rgba(47,109,246,.1)}
.skill-table{width:100%;border-collapse:collapse}
.skill-table th{background:#f8fbff;color:var(--muted);padding:10px 12px;font-size:12px;font-weight:900;text-align:left;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--line)}
.skill-table td{padding:9px 10px;border-bottom:1px solid #e7eef7;vertical-align:middle}
.skill-table tr:last-child td{border-bottom:none}
.level-selector{display:flex;gap:5px}
.level-btn{width:34px;height:34px;border-radius:8px;border:1.5px solid var(--line);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:13px;font-weight:700;color:var(--muted);background:#fff;transition:all .15s;user-select:none}
.level-btn.sel{background:var(--primary);color:#fff;border-color:var(--primary)}
.level-btn:hover:not(.sel){border-color:var(--primary);color:var(--primary)}
.pj-card{border:1.5px solid var(--line);border-radius:16px;padding:16px;margin-bottom:12px;background:#fbfdff}
.pj-card:hover{border-color:#b7ceff}
.pj-card-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}
.pj-name{font-size:15px;font-weight:800;color:var(--text)}
.pj-period{font-size:12px;color:var(--muted)}
.icon-btn{width:28px;height:28px;border-radius:8px;border:1.5px solid var(--line);background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px;transition:all .15s}
.icon-btn:hover{border-color:var(--primary);background:var(--soft)}
.pj-tags{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:8px}
.pj-tag{background:var(--soft);color:var(--primary);font-size:11px;font-weight:700;padding:3px 10px;border-radius:999px}
.pj-tag:empty{display:none}
.phase-chip{background:#f0fdf4;color:#15803d;font-size:11px;font-weight:700;padding:3px 10px;border-radius:999px;border:1px solid #bbf7d0}
.phase-pick-area{display:flex;flex-wrap:wrap;gap:8px;padding:8px 0}
.phase-pick-chip{display:inline-flex;align-items:center;padding:5px 14px;border-radius:999px;font-size:12px;font-weight:700;cursor:pointer;border:1.5px solid var(--line);background:#f8fbff;color:var(--muted);transition:all .15s;user-select:none}
.phase-pick-chip.active{background:#f0fdf4;border-color:#86efac;color:#15803d}
.phase-pick-chip:hover:not(.active){border-color:#b7ceff;color:var(--primary);background:var(--soft)}
.phase-pick-other-btn:hover{border-color:#b7ceff;color:var(--primary);background:var(--soft)}
.phase-custom-del{font-size:10px;opacity:.6;margin-left:2px;cursor:pointer}
.phase-custom-del:hover{opacity:1}
.pj-edit-form{display:none;border-top:1.5px solid var(--line);margin-top:14px;padding-top:14px}
.pj-edit-form.open{display:block}
.btn-add-pj{width:100%;padding:12px;border:2px dashed var(--line);border-radius:14px;background:none;color:var(--muted);font-size:14px;cursor:pointer;transition:all .2s}
.btn-add-pj:hover{border-color:var(--primary);color:var(--primary);background:var(--soft)}
.save-bar{position:sticky;bottom:0;background:#fff;border-top:1px solid var(--line);padding:14px 28px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 -4px 18px rgba(20,34,65,.08);margin:0 -28px -28px}
.save-bar-info{font-size:13px;color:var(--muted)}
.btn-row{display:flex;gap:10px}
.btn{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;border-radius:12px;font-size:14px;font-weight:800;border:none;cursor:pointer;transition:all .2s}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:#1e5dd4}
.btn-ghost{background:transparent;color:var(--primary);border:1.5px solid var(--primary)}
.btn-ghost:hover{background:var(--soft)}
.btn-danger{background:transparent;color:#ef4444;border:1.5px solid #ef4444}
.btn-danger:hover{background:#fef2f2}
.lang-dup{border-color:#ef4444 !important;background:#fef2f2 !important;box-shadow:0 0 0 3px rgba(239,68,68,.15) !important}
.dup-warn{font-size:11px;color:#ef4444;font-weight:800;margin-top:3px;display:flex;align-items:center;gap:3px}
.note-banner{background:#fff9ec;border:1.5px solid #fde68a;border-radius:10px;padding:10px 16px;font-size:12px;color:#92400e;display:flex;align-items:center;gap:8px}
.info-banner{background:var(--soft2);border:1.5px solid #bfdbfe;border-radius:10px;padding:10px 16px;font-size:13px;color:var(--text);display:flex;align-items:center;gap:8px}
#toast{position:fixed;bottom:28px;right:28px;background:var(--nav);color:#fff;padding:14px 22px;border-radius:14px;font-size:14px;font-weight:700;box-shadow:0 6px 22px rgba(0,0,0,.22);opacity:0;transition:opacity .3s;pointer-events:none;z-index:999}
#confirm-modal-overlay{position:fixed;inset:0;background:rgba(15,30,60,.45);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:1200;opacity:0;pointer-events:none;transition:opacity .2s}
#confirm-modal-overlay.open{opacity:1;pointer-events:all}
#confirm-modal{background:#fff;border-radius:20px;padding:32px 28px 24px;width:min(420px,90vw);box-shadow:0 20px 60px rgba(0,0,0,.18);transform:translateY(10px);transition:transform .2s}
#confirm-modal-overlay.open #confirm-modal{transform:translateY(0)}
#confirm-modal .cm-icon{font-size:36px;text-align:center;margin-bottom:12px}
#confirm-modal .cm-title{font-size:15px;font-weight:800;color:var(--text);margin-bottom:8px;text-align:center}
#confirm-modal .cm-body{font-size:13px;color:var(--muted);text-align:center;line-height:1.7;margin-bottom:22px}
#confirm-modal .cm-value{display:inline-block;background:#f0f6ff;border:1.5px solid #c3d9ff;border-radius:8px;padding:4px 14px;font-weight:800;color:var(--primary);font-size:14px;margin:6px 0}
#confirm-modal .cm-btns{display:flex;gap:10px;justify-content:center}
#confirm-modal .cm-cancel{padding:10px 24px;border:1.5px solid var(--line);border-radius:10px;background:#fff;color:var(--muted);font-weight:700;font-size:14px;cursor:pointer;font-family:inherit;transition:.15s}
#confirm-modal .cm-cancel:hover{background:var(--soft)}
#confirm-modal .cm-ok{padding:10px 28px;border:none;border-radius:10px;background:var(--primary);color:#fff;font-weight:800;font-size:14px;cursor:pointer;font-family:inherit;transition:.15s;box-shadow:0 4px 12px rgba(74,137,255,.3)}
#confirm-modal .cm-ok:hover{filter:brightness(1.08)}
.tool-chip{background:#f0f9ff;color:#0369a1;font-size:11px;font-weight:700;padding:3px 10px;border-radius:999px;border:1px solid #bae6fd}
.tool-pick-chip{display:inline-flex;align-items:center;padding:5px 14px;border-radius:999px;font-size:12px;font-weight:700;cursor:pointer;border:1.5px solid var(--line);background:#f8fbff;color:var(--muted);transition:all .15s;user-select:none}
.tool-pick-chip.active{background:#f0f9ff;border-color:#7dd3fc;color:#0369a1}
.tool-pick-chip:hover:not(.active){border-color:#b7ceff;color:var(--primary);background:var(--soft)}

/* ── 新規メンバー登録モーダル ── */
#reg-modal-overlay{position:fixed;inset:0;z-index:9998;background:rgba(10,20,40,.55);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s}
#reg-modal-overlay.open{opacity:1;pointer-events:auto}
#reg-modal{background:#fff;border-radius:24px;padding:36px 32px;width:100%;max-width:440px;box-shadow:0 24px 60px rgba(0,0,0,.25);transform:translateY(12px);transition:transform .2s}
#reg-modal-overlay.open #reg-modal{transform:translateY(0)}
#reg-modal h3{margin:0 0 4px;font-size:20px;font-weight:900}
#reg-modal .reg-sub{font-size:13px;color:var(--muted);margin-bottom:24px}
#reg-modal .reg-field{margin-bottom:16px}
#reg-modal .reg-field label{display:block;font-size:13px;font-weight:800;color:var(--text);margin-bottom:6px}
#reg-modal .reg-field input{width:100%;padding:11px 14px;border:1.5px solid var(--line);border-radius:10px;font-size:14px;font-family:inherit;outline:none;transition:.15s;background:#fafbfd;color:var(--text)}
#reg-modal .reg-field input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(47,109,246,.1)}
#reg-modal .reg-field input[readonly]{background:#f0f4ff;color:var(--primary);font-weight:700;cursor:default}
.reg-pw-row{display:flex;gap:8px;align-items:center}
.reg-pw-row input{flex:1}
.reg-pw-regenerate,
.reg-pw-copy{padding:9px 12px;border:1.5px solid var(--line);border-radius:10px;background:#fff;color:var(--muted);font-size:13px;font-weight:700;cursor:pointer;font-family:inherit;white-space:nowrap;transition:.15s;flex-shrink:0}
.reg-pw-regenerate:hover,
.reg-pw-copy:hover{border-color:var(--primary);color:var(--primary)}
#reg-modal .reg-field .reg-role-row{display:flex;gap:10px}
#reg-modal .reg-field .reg-role-option{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:11px 14px;border:1.5px solid var(--line);border-radius:10px;background:#fafbfd;font-size:14px;font-weight:700;color:var(--text);cursor:pointer;transition:.15s;user-select:none}
#reg-modal .reg-field .reg-role-option:hover{background:var(--soft)}
#reg-modal .reg-field .reg-role-option input[type="radio"]{width:16px;height:16px;padding:0;margin:0;border:none;border-radius:0;background:transparent;accent-color:var(--primary);cursor:pointer;box-shadow:none}
#reg-modal .reg-field .reg-role-option:has(input[type="radio"]:checked){border-color:var(--primary);background:var(--soft);color:var(--primary);box-shadow:0 0 0 3px rgba(47,109,246,.1)}
#reg-modal .reg-error{background:#fff1f1;border:1.5px solid #fca5a5;border-radius:8px;padding:9px 12px;font-size:12px;font-weight:700;color:#b42318;margin-bottom:14px;display:none}
#reg-modal .reg-error.show{display:block}
#reg-modal .reg-btns{display:flex;gap:10px;justify-content:flex-end;margin-top:8px}
#reg-modal .reg-cancel{padding:9px 20px;border:1.5px solid var(--line);border-radius:10px;background:#fff;color:var(--muted);font-weight:700;font-size:14px;cursor:pointer;font-family:inherit;transition:.15s}
#reg-modal .reg-cancel:hover{background:var(--soft)}
#reg-modal .reg-next{padding:9px 24px;border:none;border-radius:10px;background:var(--primary);color:#fff;font-weight:800;font-size:14px;cursor:pointer;font-family:inherit;box-shadow:0 4px 12px rgba(47,109,246,.3);transition:.15s}
#reg-modal .reg-next:hover{filter:brightness(1.07)}
#reg-modal .reg-next:disabled{opacity:.6;cursor:not-allowed}
.reg-confirm-box{background:#f0f6ff;border:1.5px solid #c3d9ff;border-radius:14px;padding:18px 20px;margin-bottom:20px}
.reg-confirm-row{display:flex;gap:12px;align-items:baseline;padding:6px 0;border-bottom:1px solid #dae8ff}
.reg-confirm-row:last-child{border-bottom:none}
.reg-confirm-label{font-size:12px;font-weight:800;color:var(--muted);width:110px;flex-shrink:0}
.reg-confirm-val{font-size:14px;font-weight:700;color:var(--text);word-break:break-all}

/* ── パスワード変更モーダル ── */
#pw-modal-overlay{position:fixed;inset:0;z-index:9998;background:rgba(10,20,40,.55);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s}
#pw-modal-overlay.open{opacity:1;pointer-events:auto}
#pw-modal{background:#fff;border-radius:22px;padding:36px 32px;width:100%;max-width:400px;box-shadow:0 24px 60px rgba(0,0,0,.25);transform:translateY(12px);transition:transform .2s}
#pw-modal-overlay.open #pw-modal{transform:translateY(0)}
#pw-modal h3{margin:0 0 6px;font-size:20px;font-weight:900}
#pw-modal .pw-sub{font-size:13px;color:var(--muted);margin-bottom:24px}
#pw-modal .pw-field{margin-bottom:16px}
#pw-modal .pw-field label{display:block;font-size:13px;font-weight:800;color:var(--text);margin-bottom:6px}
#pw-modal .pw-field input{width:100%;padding:11px 14px;border:1.5px solid var(--line);border-radius:10px;font-size:14px;font-family:inherit;outline:none;transition:.15s;background:#fafbfd}
#pw-modal .pw-field input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(47,109,246,.1)}
#pw-modal .pw-error{background:#fff1f1;border:1.5px solid #fca5a5;border-radius:8px;padding:9px 12px;font-size:12px;font-weight:700;color:#b42318;margin-bottom:14px;display:none}
#pw-modal .pw-error.show{display:block}
#pw-modal .pw-btns{display:flex;gap:10px;justify-content:flex-end;margin-top:8px}
#pw-modal .pw-cancel{padding:9px 20px;border:1.5px solid var(--line);border-radius:10px;background:#fff;color:var(--muted);font-weight:700;font-size:14px;cursor:pointer;font-family:inherit}
#pw-modal .pw-cancel:hover{background:var(--soft)}
#pw-modal .pw-ok{padding:9px 24px;border:none;border-radius:10px;background:var(--primary);color:#fff;font-weight:800;font-size:14px;cursor:pointer;font-family:inherit;box-shadow:0 4px 12px rgba(47,109,246,.3)}
#pw-modal .pw-ok:hover{filter:brightness(1.07)}
#pw-modal .pw-ok:disabled{opacity:.6;cursor:not-allowed}

/* ── ログアウト確認モーダル ── */
#logout-modal-overlay{position:fixed;inset:0;z-index:9998;background:rgba(10,20,40,.55);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s}
#logout-modal-overlay.open{opacity:1;pointer-events:auto}
#logout-modal{background:#fff;border-radius:22px;padding:36px 32px;width:100%;max-width:360px;box-shadow:0 24px 60px rgba(0,0,0,.25);transform:translateY(12px);transition:transform .2s}
#logout-modal-overlay.open #logout-modal{transform:translateY(0)}
#logout-modal .lm-icon{font-size:34px;text-align:center;margin-bottom:12px}
#logout-modal .lm-title{font-size:17px;font-weight:900;text-align:center;margin-bottom:8px}
#logout-modal .lm-body{font-size:13px;color:var(--muted);text-align:center;line-height:1.7;margin-bottom:24px}
#logout-modal .lm-btns{display:flex;gap:10px;justify-content:center}
#logout-modal .lm-cancel{padding:10px 24px;border:1.5px solid var(--line);border-radius:10px;background:#fff;color:var(--muted);font-weight:700;font-size:14px;cursor:pointer;font-family:inherit;transition:.15s}
#logout-modal .lm-cancel:hover{background:var(--soft)}
#logout-modal .lm-ok{padding:10px 28px;border:none;border-radius:10px;background:#dc2626;color:#fff;font-weight:800;font-size:14px;cursor:pointer;font-family:inherit;transition:.15s;box-shadow:0 4px 12px rgba(220,38,38,.25)}
#logout-modal .lm-ok:hover{filter:brightness(1.08)}

/* ── ログイン画面 ── */
#login-overlay{position:fixed;inset:0;z-index:9999;background:linear-gradient(135deg,#0d1b2e 0%,#152440 50%,#0d1b2e 100%);display:flex;align-items:center;justify-content:center}
#login-overlay.hidden{display:none!important}
.login-box{background:#fff;border-radius:28px;padding:44px 40px;width:100%;max-width:420px;box-shadow:0 40px 80px rgba(0,0,0,.45)}
.login-logo{width:56px;height:56px;border-radius:16px;background:linear-gradient(135deg,#4a89ff,#82b5ff);display:grid;place-items:center;font-size:26px;font-weight:900;color:#fff;margin:0 auto 20px;box-shadow:0 8px 24px rgba(74,137,255,.35)}
.login-box h2{margin:0 0 6px;font-size:26px;font-weight:900;text-align:center;color:var(--text)}
.login-box .login-sub{text-align:center;color:var(--muted);font-size:14px;margin-bottom:32px}
.login-field{margin-bottom:18px}
.login-field label{display:block;font-size:13px;font-weight:800;color:var(--text);margin-bottom:7px}
.login-field input{width:100%;padding:13px 16px;border:1.5px solid var(--line);border-radius:12px;font-size:15px;font-family:inherit;outline:none;transition:.15s;background:#fafbfd;color:var(--text)}
.login-field input:focus{border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px rgba(47,109,246,.12)}
.login-btn{width:100%;padding:14px;border:none;border-radius:12px;background:linear-gradient(135deg,#2f6df6,#5a93ff);color:#fff;font-size:15px;font-weight:800;cursor:pointer;font-family:inherit;transition:.18s;box-shadow:0 6px 20px rgba(47,109,246,.35);margin-top:6px}
.login-btn:hover{filter:brightness(1.07);transform:translateY(-1px)}
.login-btn:active{transform:translateY(0)}
.login-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}
.login-error{background:#fff1f1;border:1.5px solid #fca5a5;border-radius:10px;padding:10px 14px;font-size:13px;font-weight:700;color:#b42318;margin-bottom:16px;display:none}
.login-error.show{display:block}

/* ── サイドバー ユーザー情報 ── */
.sidebar-user{margin-top:auto;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);border-radius:16px;padding:14px 16px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:.18s;position:relative;user-select:none}
.sidebar-user:hover{background:rgba(255,255,255,.13)}
.sidebar-user-avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,#4a89ff,#82b5ff);display:grid;place-items:center;font-size:15px;font-weight:900;color:#fff;flex-shrink:0}
.sidebar-user-info{flex:1;min-width:0}
.sidebar-user-email{font-size:12px;color:rgba(255,255,255,.9);font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sidebar-user-role{font-size:11px;color:rgba(255,255,255,.5);margin-top:2px}
.sidebar-user-chevron{color:rgba(255,255,255,.4);font-size:13px;flex-shrink:0;transition:.18s}
.sidebar-user.menu-open .sidebar-user-chevron{transform:rotate(180deg)}
.sidebar-user-menu{position:absolute;bottom:calc(100% + 8px);left:0;right:0;background:#1e2d47;border:1px solid rgba(255,255,255,.15);border-radius:14px;overflow:hidden;box-shadow:0 8px 28px rgba(0,0,0,.35);display:none;z-index:100}
.sidebar-user.menu-open .sidebar-user-menu{display:block}
.sidebar-user-menu button{display:flex;align-items:center;gap:10px;width:100%;padding:13px 16px;background:none;border:none;color:rgba(255,255,255,.85);font-size:13px;font-weight:700;cursor:pointer;font-family:inherit;transition:.15s;text-align:left}
.sidebar-user-menu button:hover{background:rgba(255,255,255,.08)}
.sidebar-user-menu button.menu-danger{color:#f87171}
.sidebar-user-menu button.menu-danger:hover{background:rgba(248,113,113,.12)}
.sidebar-user-menu .menu-divider{height:1px;background:rgba(255,255,255,.08);margin:2px 0}
