:root {
	--modal-active-color: #ffffff;
	--wheel-inner-size: 0px;
	--wheel-size: 0px
}

h1 {
	font-size: 24px;
}
h2 {
	font-size: 20px;
}
h3 {
	font-size: 1em;
	font-weight: normal;
}
.colors-title {
	font-size: 1em;
	font-weight: normal;
	margin: 4px 0;
}
.nav-pills .nav-link {
	padding: 4px 8px;
	margin: 4px 0;
}

.color-overview {
	/* font-size: 0.75rem; */
	/* padding: 0.25rem 0; */
	/* font-family: consolas, "Myrica M", "Noto Sans Mono", monospace; */
	height: 1.25rem;
}
/*
.modal-color-overview {
    width: 2.75rem;
    height: 2.75rem;
}
*/
#wheel-center {
	/* JSから渡される内接正方形のサイズを適用 */
	width: var(--wheel-inner-size);
	height: var(--wheel-inner-size);
	pointer-events: none; /* 下の色相環のクリックを邪魔しない場合 */
}
.contrast-overview {
	width: 100%;
	aspect-ratio: 1 / 1;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: var(--bs-border-radius);
	transition:
		background-color 0.2s ease-in-out,
		color 0.2s ease-in-out;
}
.contrast-text-brack {
	color: #000;
	background-color: var(--modal-active-color);
}
.contrast-text-white {
	color: #fff;
	background-color: var(--modal-active-color);
}
.contrast-bg-black {
	color: var(--modal-active-color);
	background-color: #000;
}
.contrast-bg-white {
	color: var(--modal-active-color);
	background-color: #fff;
}

#detailModalTable th {
	width: 4rem;
}
.main-contents {
	padding-top: 0.5rem;
	padding-bottom: 3.5rem;
}
/*
p {
    text-indent: 1em;
}
*/

.modal-description {
	min-height: 2rem;
}

/* 色相環のコンテナ */
.wheel-container {
	position: relative;
	width: var(--wheel-size);
	height: var(--wheel-size);

}

.color-sector {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	cursor: pointer;
	z-index: 1;
	transform-origin: center center;
	transition: transform 0.2s ease-in-out;

	--translate-x: 0px;
	--translate-y: 0px;
	--scale: 1;
	transform: translate(var(--translate-x), var(--translate-y)) scale(var(--scale));
}

.color-sector:hover {
	z-index: 10;
	--scale: 1.02;
}
.color-sector.active {
	z-index: 10;
	--scale: 1.04;
}

.contrast-progress-area {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	gap: 0.25rem;
}

/* コントラスト計全体のレイアウト */
.contrast-progress-wrapper {
	max-width: var(--wheel-size);
	display: flex;
	align-items: center;
	width: 100%;
	gap: 0.25rem
}

/* 比率数値ラベル（左側） */
.ratio-value-label {
	width: 2.25rem;
	font-size: 0.85rem;
	align-items: center; /* テキスト自体の垂直中央 */
	line-height: 1;
	text-align: right;
}

/* プログレスバーとマーカーの親コンテナ */
.contrast-progress-container {
	position: relative;
	flex-grow: 1;
	height: 1.5rem;
	display: flex;
	align-items: center;
}

/* Bootstrap progress 本体のオーバーライド */
.contrast-progress-container .progress {
	width: 100%;
	height: 0.375rem;
	overflow: visible;
	background-color: #e9ecef;
	border-radius: 0 50rem 50rem 0;
}

/* 進捗バー部分 */
.contrast-progress-container .progress-bar {
	background-color: var(--modal-active-color);
	border-radius: 0 50rem 50rem 0;
	transition:
		width 0.4s ease-in-out,
		background-color 0.4s ease-in-out;
}

/* マーカー共通：中心を基準に絶対配置 */
/* 共通：マーカーの基本スタイル */
.contrast-marker-circle {
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	font-size: 0.5rem;
	z-index: 2;
	transition:
		background-color 0.4s ease-in-out,
		color 0.4s ease-in-out,
		transform 0.4s ease-in-out;
}

/* 未到達（灰色） */
.marker-inactive {
	background-color: #dee2e6; /* 薄い灰色 */
	color: #adb5bd; /* 文字も少し薄く */
}

/* 達成時（活性色） */
.marker-a {
	background-color: #adb5bd; /* Aは標準的な灰色 */
	color: #fff;
}
.marker-aa {
	background-color: #a3cf62; /* AAは黄緑 */
	color: #fff;
}
.marker-aaa {
	background-color: #28a745; /* AAAは濃い緑 */
	color: #fff;
}

/* 達成度別の色（マーカー背景） */
.marker-a {
	background-color: #6c757d;
	width: 1rem;
	height: 1rem;
}
.marker-aa {
	background-color: #a3cf62;
	width: 1.25rem;
	height: 1.25rem;
}
.marker-aaa {
	background-color: #28a745;
	width: 1.5rem;
	height: 1.5rem;
}
.size-a {
	width: 1rem;
	height: 1rem;
}
.size-aa {
	width: 1.25rem;
	height: 1.25rem;
}
.size-aaa {
	width: 1.5rem;
	height: 1.5rem;
}
