/**
 * スキル均等チーム編成ツール（ビジネス向け）
 * tt- プレフィックス（team-tools-common.css）をベースに拡張
 */

/* スキル列ヘッダー */
.sb-skill-defs {
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	gap: 6px;
	margin-bottom: 10px;
}

.sb-skill-def {
	display: flex;
	align-items: center;
	gap: 4px;
	padding: 6px 8px;
	background: #F4F8FF;
	border: 1px solid #E0E6F2;
	border-radius: 6px;
}

.sb-skill-def input[type="text"] {
	width: 100%;
	padding: 4px 6px;
	font-size: 12px;
	border: 1px solid #DDE3EE;
	border-radius: 4px;
	font-family: inherit;
	background: #FFFFFF;
}

@media (max-width: 720px) {
	.sb-skill-defs {
		grid-template-columns: repeat(2, 1fr);
	}
}

/* メンバー表 */
.sb-members-table {
	width: 100%;
	border-collapse: separate;
	border-spacing: 0;
	font-size: 13px;
	margin-top: 8px;
}

.sb-members-table thead th {
	background: #F4F8FF;
	color: #3D5AC8;
	font-weight: 700;
	padding: 8px 6px;
	border-bottom: 2px solid #C9D5F2;
	font-size: 12px;
	text-align: center;
}

.sb-members-table tbody td {
	padding: 6px 6px;
	border-bottom: 1px solid #EEF1F8;
	text-align: center;
}

.sb-members-table tbody td:first-child {
	text-align: left;
}

.sb-members-table input.sb-name {
	width: 100%;
	padding: 6px 8px;
	font-size: 13px;
	border: 1px solid var(--color-border);
	border-radius: 4px;
	font-family: inherit;
	background: #FFFFFF;
}

.sb-members-table select.sb-level {
	width: 54px;
	padding: 5px 4px;
	font-size: 12px;
	border: 1px solid var(--color-border);
	border-radius: 4px;
	background: #FFFFFF;
}

.sb-members-table .sb-row-remove {
	background: none;
	border: none;
	color: #C0392B;
	cursor: pointer;
	font-size: 16px;
	padding: 0 6px;
}

.sb-members-table .sb-row-remove:hover {
	color: #8B1F12;
}

/* テーブル全体をスクロール可能に */
.sb-members-wrap {
	overflow-x: auto;
	margin-top: 8px;
}

/* チーム合計スキルバー */
.sb-skill-summary {
	margin-top: 12px;
	padding-top: 10px;
	border-top: 1px dashed #E8ECF7;
}

.sb-skill-row {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 12px;
	margin-bottom: 6px;
}

.sb-skill-row-label {
	flex: 0 0 80px;
	color: var(--color-text-secondary);
	font-weight: 500;
}

.sb-skill-row-bar {
	flex: 1;
	height: 8px;
	background: #EEF2FB;
	border-radius: 4px;
	overflow: hidden;
}

.sb-skill-row-bar > div {
	height: 100%;
	background: linear-gradient(90deg, #5C7CFA, #3D5AC8);
	transition: width 0.4s ease;
}

.sb-skill-row-value {
	flex: 0 0 36px;
	text-align: right;
	font-weight: 700;
	color: #3D5AC8;
}

/* バランススコア */
.sb-balance-score {
	display: inline-block;
	padding: 4px 10px;
	border-radius: 999px;
	font-size: 12px;
	font-weight: 700;
	margin-left: 8px;
}

.sb-balance-score--great { background: #DFF5E5; color: #2C8A4F; }
.sb-balance-score--good  { background: #FFF8EC; color: #B58608; }
.sb-balance-score--warn  { background: #FCEFEC; color: #C0392B; }

/* モード切替 */
.sb-mode-row {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
}

.sb-mode-chip {
	padding: 8px 16px;
	background: #F4F4F2;
	border: 1.5px solid transparent;
	border-radius: 8px;
	font-size: 13px;
	font-weight: 500;
	cursor: pointer;
	transition: all 0.15s ease;
}

.sb-mode-chip.is-active {
	background: linear-gradient(135deg, #E1F1F5 0%, #C5E5EB 100%);
	border-color: #4DC2D5;
	color: #1F5D6B;
	font-weight: 700;
}

.sb-mode-chip:hover { background: #E9EFF5; }
.sb-mode-chip.is-active:hover { filter: brightness(0.96); }

/* 追加・削除ボタン */
.sb-row-actions {
	display: flex;
	gap: 8px;
	margin-top: 10px;
	flex-wrap: wrap;
}
