/* Blood Type Calculator — bt- prefix */

/* ── Form: 2-column grid ── */
.bt-form-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0 20px;
}
.bt-form-heading {
	font-size: 14px;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	color: var(--text-muted, #695A80);
	margin-bottom: 8px;
	padding-bottom: 8px;
	border-bottom: 1.5px solid rgba(139,123,184,0.12);
}

/* ── Results: blood type badges ── */
.bt-type-badges {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 10px;
	margin: 20px 0 16px;
}
.bt-type-badge {
	display: flex;
	flex-direction: column;
	align-items: center;
	background: rgba(139,123,184,0.08);
	border: 1.5px solid rgba(139,123,184,0.12);
	border-radius: 12px;
	padding: 12px 18px 10px;
	min-width: 72px;
}
.bt-type-name {
	font-size: 22px;
	font-weight: 900;
	color: var(--text, #3D2F50);
	line-height: 1.1;
}
.bt-type-prob {
	font-size: 13px;
	font-weight: 700;
	color: var(--text-muted, #695A80);
	margin-top: 4px;
}

/* ── Results table ── */
.bt-results-table td:first-child {
	font-size: 16px;
}

/* ── Warning boxes ── */
.bt-warning {
	max-width: 584px;
	margin: 16px auto;
	border-radius: 14px;
	overflow: hidden;
}
.bt-warning-header {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 14px 24px;
	font-size: 15px;
}
.bt-warning-icon {
	font-size: 18px;
	flex-shrink: 0;
}
.bt-warning-body {
	padding: 0 24px 20px;
}
.bt-warning-body p {
	font-size: 15px;
	color: var(--text-muted, #695A80);
	margin-bottom: 10px;
	line-height: 1.55;
}
.bt-warning-body p:last-child {
	margin-bottom: 0;
}

/* Rh warning — warm amber */
.bt-warning-rh {
	background: #FFF8F0;
	border: 1.5px solid rgba(210,140,60,0.20);
}
.bt-warning-rh .bt-warning-header {
	background: rgba(210,140,60,0.08);
	color: #8B5E20;
}

/* ABO warning — soft blue */
.bt-warning-abo {
	background: #F0F6FF;
	border: 1.5px solid rgba(80,130,200,0.20);
}
.bt-warning-abo .bt-warning-header {
	background: rgba(80,130,200,0.08);
	color: #2E5A8A;
}

/* ── Rarity table highlight ── */
.bt-rarity-table tr.bt-highlight {
	background: rgba(139,123,184,0.06);
}
.bt-rarity-table tr.bt-highlight td {
	font-weight: 700;
	color: var(--primary, #8B7BB8);
}

/* ── Reverse calculator form card ── */
.bt-reverse-card {
	margin-top: 0;
	border-top: 1.5px solid rgba(139,123,184,0.10);
}
.bt-reverse-heading {
	font-size: 17px;
	font-weight: 800;
	color: var(--text, #3D2F50);
	margin: 0 0 6px;
}
.bt-reverse-desc {
	font-size: 15px;
	color: var(--text-muted, #695A80);
	margin: 0 0 20px;
	line-height: 1.5;
}

/* ── Impossible combination message ── */
.bt-impossible-msg {
	margin: 20px 0 16px;
	padding: 16px 20px;
	background: rgba(210,140,60,0.06);
	border: 1.5px solid rgba(210,140,60,0.15);
	border-radius: 12px;
}
.bt-impossible-msg p {
	font-size: 15px;
	color: var(--text-muted, #695A80);
	line-height: 1.55;
	margin: 0;
}

/* ── Ruled out badges ── */
.bt-ruled-out {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 12px;
}
.bt-ruled-out-badge {
	display: inline-block;
	font-size: 15px;
	font-weight: 800;
	color: var(--text-muted, #695A80);
	background: rgba(139,123,184,0.06);
	border: 1.5px solid rgba(139,123,184,0.10);
	border-radius: 8px;
	padding: 6px 14px;
	text-decoration: line-through;
	opacity: 0.6;
}

/* ── Disclaimer ── */
.bt-disclaimer {
	max-width: 584px;
	margin: 16px auto;
	font-size: 13px;
	color: var(--text-muted, #695A80);
	text-align: center;
	line-height: 1.5;
	opacity: 0.7;
}

/* ── Mobile ── */
@media (max-width: 600px) {
	.bt-form-grid {
		grid-template-columns: 1fr;
		gap: 4px;
	}
	.bt-form-heading {
		margin-top: 12px;
	}
	.bt-form-grid .bt-form-col:first-child .bt-form-heading {
		margin-top: 0;
	}
	.bt-type-name {
		font-size: 20px;
	}
	.bt-type-badge {
		padding: 10px 14px 8px;
		min-width: 64px;
	}
}
