/**
 * 当番表ジェネレーター - 専用スタイル
 */

/* ============================
   当番の種類 - 動的リスト
   ============================ */
.duty-list {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.duty-item {
	display: flex;
	align-items: center;
	gap: 8px;
	animation: fadeSlideIn 0.2s ease;
}

.duty-input {
	flex: 1;
	padding: 8px 12px;
	font-size: 14px;
	color: var(--color-text);
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	font-family: var(--font-body);
}

.duty-input:focus {
	outline: none;
	border-color: var(--color-primary);
}

.duty-remove-btn {
	flex-shrink: 0;
	width: 32px;
	height: 32px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: none;
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	font-size: 18px;
	color: var(--color-text-muted);
	cursor: pointer;
	transition: all 0.15s ease;
}

.duty-remove-btn:hover {
	color: #e74c3c;
	border-color: #e74c3c;
	background: rgba(231, 76, 60, 0.05);
}

.duty-add-btn {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	margin-top: 8px;
	padding: 6px 12px;
	font-size: 13px;
	color: var(--color-accent);
	background: none;
	border: 1px dashed var(--color-border);
	border-radius: var(--radius);
	cursor: pointer;
	transition: all 0.15s ease;
}

.duty-add-btn:hover {
	border-color: var(--color-accent);
	background: rgba(224, 120, 80, 0.05);
}

.duty-limit-text {
	margin-top: 6px;
	font-size: 12px;
	color: var(--color-text-muted);
}

/* ============================
   期間設定
   ============================ */
.period-settings {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.period-row {
	display: flex;
	align-items: center;
	gap: 12px;
}

.period-label {
	flex-shrink: 0;
	width: 60px;
	font-size: 13px;
	color: var(--color-text-muted);
}

.period-date-input {
	padding: 8px 12px;
	font-size: 14px;
	color: var(--color-text);
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	font-family: var(--font-body);
}

.period-date-input:focus {
	outline: none;
	border-color: var(--color-primary);
}

.period-duration {
	display: flex;
	align-items: center;
	gap: 8px;
}

.period-number-input {
	width: 70px;
	padding: 8px 12px;
	font-size: 14px;
	color: var(--color-text);
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	font-family: var(--font-body);
	text-align: center;
}

.period-number-input:focus {
	outline: none;
	border-color: var(--color-primary);
}

.period-select {
	padding: 8px 12px;
	font-size: 14px;
	color: var(--color-text);
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	font-family: var(--font-body);
	cursor: pointer;
}

.period-select:focus {
	outline: none;
	border-color: var(--color-primary);
}

.period-select-small {
	padding: 6px 10px;
	font-size: 13px;
}

/* ============================
   詳細設定
   ============================ */
.option-group {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 12px;
}

.option-group-label {
	font-size: 13px;
	color: var(--color-text-muted);
	flex-shrink: 0;
}

.weekday-checkboxes {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}

.weekday-label {
	display: flex;
	align-items: center;
	gap: 4px;
	padding: 4px 10px;
	font-size: 13px;
	color: var(--color-text);
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: 4px;
	cursor: pointer;
	transition: all 0.15s ease;
	user-select: none;
}

.weekday-label:has(input:checked) {
	background: var(--color-primary);
	color: var(--color-white);
	border-color: var(--color-primary);
}

.weekday-label input {
	display: none;
}

.persons-per-day-group {
	display: flex;
	align-items: center;
	gap: 8px;
}

/* ============================
   結果エリア
   ============================ */
.result-area {
	background: var(--color-white);
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	margin-bottom: 32px;
}

.result-header {
	padding: 14px 20px;
	border-bottom: 1px solid var(--color-border);
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.result-actions {
	display: flex;
	gap: 12px;
}

.result-body {
	padding: 0;
}

/* ============================
   当番表テーブル
   ============================ */
.roster-table-wrapper {
	max-height: 500px;
	overflow-y: auto;
	border-bottom: 1px solid var(--color-border);
}

.roster-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 14px;
}

.roster-table th {
	background: var(--color-primary);
	color: var(--color-white);
	padding: 10px 12px;
	font-size: 13px;
	font-weight: 500;
	text-align: center;
	position: sticky;
	top: 0;
	z-index: 1;
}

.roster-table td {
	padding: 8px 12px;
	text-align: center;
	border-bottom: 1px solid var(--color-border);
	font-size: 13px;
}

.roster-table td:first-child {
	text-align: left;
	white-space: nowrap;
	font-size: 12px;
	color: var(--color-text-secondary);
}

.roster-table tr:nth-child(even) {
	background: var(--color-bg);
}

.roster-table tr.is-today {
	background: rgba(224, 120, 80, 0.08);
	font-weight: 500;
}

.roster-table tr.is-today td {
	color: var(--color-text);
}

.roster-table tr.week-start td {
	border-top: 2px solid var(--color-primary);
}

/* ============================
   割り当て回数
   ============================ */
.result-stats-section {
	padding: 16px 20px;
	border-bottom: 1px solid var(--color-border);
}

.result-stats-title {
	font-family: var(--font-display);
	font-size: 13px;
	font-weight: 700;
	color: var(--color-text);
	margin-bottom: 10px;
}

.assignment-stats-list {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.assignment-stat-row {
	display: flex;
	align-items: baseline;
	gap: 8px;
	font-size: 13px;
	line-height: 1.6;
}

.assignment-stat-name {
	flex-shrink: 0;
	min-width: 60px;
	font-weight: 500;
	color: var(--color-text);
}

.assignment-stat-detail {
	color: var(--color-text-secondary);
}

.assignment-stat-total {
	color: var(--color-text-muted);
	font-size: 12px;
}

/* ============================
   偏り警告
   ============================ */
.bias-warning {
	padding: 12px 20px;
	border-bottom: 1px solid var(--color-border);
	font-size: 13px;
	color: #b8860b;
	background: rgba(184, 134, 11, 0.06);
	line-height: 1.7;
}

/* ============================
   結果アクション
   ============================ */
.result-action-section {
	padding: 14px 20px;
	display: flex;
	justify-content: center;
	gap: 12px;
}

/* ============================
   画像保存不可メッセージ
   ============================ */
.image-save-notice {
	font-size: 12px;
	color: var(--color-text-muted);
	padding: 0;
}

/* ============================
   アニメーション
   ============================ */
@keyframes fadeSlideIn {
	from {
		opacity: 0;
		transform: translateY(6px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* ============================
   レスポンシブ
   ============================ */
@media (max-width: 600px) {
	.period-row {
		flex-direction: column;
		align-items: flex-start;
		gap: 6px;
	}

	.period-label {
		width: auto;
	}

	.option-group {
		flex-direction: column;
		align-items: flex-start;
		gap: 8px;
	}

	.persons-per-day-group {
		flex-direction: column;
		align-items: flex-start;
		gap: 4px;
	}

	.weekday-checkboxes {
		gap: 4px;
	}

	.weekday-label {
		padding: 4px 8px;
		font-size: 12px;
	}

	.result-header {
		flex-direction: column;
		align-items: flex-start;
		gap: 8px;
	}

	.result-actions {
		flex-wrap: wrap;
		gap: 8px;
	}

	.roster-table-wrapper {
		max-height: 400px;
	}

	.roster-table th,
	.roster-table td {
		padding: 6px 8px;
		font-size: 12px;
	}

	.roster-table td:first-child {
		font-size: 11px;
	}

	.assignment-stat-row {
		flex-direction: column;
		gap: 2px;
	}

	.assignment-stat-name {
		min-width: auto;
	}
}
