/* Outil E — Calculateur budget voyage musulman */

.smc-budget-voyage { background: linear-gradient(180deg, var(--cream-soft, #FBF5E6) 0%, transparent 100%); }

.smc-bv-calc { max-width: 760px; margin: 32px auto; padding: 0 16px; }
.smc-bv-calc__card {
	background: linear-gradient(135deg, #14223A 0%, #1C2E4A 50%, #2E4166 100%);
	border-radius: 22px;
	padding: 32px 28px;
	color: #F7F1E3;
	position: relative;
	overflow: hidden;
}
.smc-bv-calc__card::before {
	content:""; position:absolute; top:-100px; right:-80px; width:280px; height:280px;
	background: radial-gradient(circle, rgba(212,178,126,.22) 0%, transparent 70%);
	pointer-events: none;
}
.smc-bv-calc__card > * { position: relative; z-index: 1; }
.smc-bv-calc__title { font-family: 'Cormorant Garamond', serif; font-size: 26px; color: #F7F1E3 !important; margin: 0 0 6px; text-align: center; }
.smc-bv-calc__title em { color: #D4B27E !important; font-style: italic; }
.smc-bv-calc__intro { text-align: center; font-size: 14px; color: rgba(247,241,227,.8); margin: 0 0 22px; }

.smc-bv-form { display: grid; grid-template-columns: 1fr; gap: 14px; }
@media (min-width: 600px) { .smc-bv-form { grid-template-columns: 1fr 1fr; } .smc-bv-form__field--full { grid-column: 1 / -1; } }

.smc-bv-form__field { display: block; }
.smc-bv-form__label {
	display: block; font-size: 12px; letter-spacing: 1px; text-transform: uppercase;
	color: #D4B27E; font-weight: 700; margin-bottom: 6px;
}
select.smc-bv-form__select,
input.smc-bv-form__input {
	width: 100% !important; padding: 12px 14px !important;
	border: 1.5px solid rgba(212,178,126,.35) !important;
	border-radius: 10px !important;
	background: rgba(247,241,227,.08) !important;
	color: #F7F1E3 !important;
	font-family: 'Poppins', sans-serif !important;
	font-size: 14.5px !important;
	-webkit-appearance: none; appearance: none; box-sizing: border-box;
}
select.smc-bv-form__select:focus, input.smc-bv-form__input:focus {
	outline: none !important; border-color: #D4B27E !important;
}
select.smc-bv-form__select option { background: #14223A; color: #F7F1E3; }

button.smc-bv-form__submit {
	display: inline-flex !important; align-items: center !important; justify-content: center !important;
	gap: 8px; padding: 14px 28px !important; border-radius: 12px !important;
	background: linear-gradient(135deg, #D4B27E 0%, #B8935C 50%, #8F6F3C 100%) !important;
	color: #14223A !important; border: none !important;
	font-family: 'Poppins', sans-serif !important;
	font-size: 14px !important; font-weight: 700 !important;
	letter-spacing: .8px !important; text-transform: uppercase !important;
	cursor: pointer !important;
	box-shadow: 0 8px 22px rgba(184,147,92,.4) !important;
	-webkit-appearance: none; appearance: none;
	margin-top: 6px;
}
button.smc-bv-form__submit:hover { transform: translateY(-2px); }

.smc-bv-status { margin: 14px 0 0; font-size: 13.5px; text-align: center; color: rgba(247,241,227,.75); }
.smc-bv-status.is-error { color: #FFB87A; }
.smc-bv-status.is-loading { color: #D4B27E; }

/* Résultat */
.smc-bv-result { max-width: 760px; margin: 24px auto 32px; padding: 0 16px; }
.smc-bv-result-card {
	background: #FFFFFF;
	border: 1px solid var(--line, #D9CFB8);
	border-radius: 18px;
	padding: 28px 26px;
	box-shadow: 0 14px 30px rgba(20,34,58,.08);
	animation: smc-bv-fade .35s ease;
}
@keyframes smc-bv-fade { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } }

.smc-bv-result-card__header {
	display: flex; flex-direction: column; align-items: center; gap: 18px;
	padding-bottom: 22px; margin-bottom: 18px;
	border-bottom: 1px solid rgba(184,147,92,.15);
}
@media (min-width: 600px) { .smc-bv-result-card__header { flex-direction: row; justify-content: space-between; } }

.smc-bv-result-card__total { text-align: center; }
@media (min-width: 600px) { .smc-bv-result-card__total { text-align: left; } }
.smc-bv-result-card__total-label {
	font-size: 11px; letter-spacing: 2px; text-transform: uppercase;
	color: #5C6578; font-weight: 700; margin-bottom: 4px;
}
.smc-bv-result-card__total-value {
	font-family: 'Cormorant Garamond', serif;
	font-size: 42px; font-weight: 600;
	color: #14223A; line-height: 1;
}
.smc-bv-result-card__per-person { font-size: 13px; color: #5C6578; margin-top: 6px; }

/* Camembert CSS pur */
.smc-bv-pie {
	width: 160px; height: 160px;
	border-radius: 50%;
	position: relative;
	flex-shrink: 0;
	box-shadow: 0 8px 22px rgba(20,34,58,.15);
}
.smc-bv-pie__hole {
	position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
	width: 90px; height: 90px;
	background: #FFFFFF; border-radius: 50%;
	display: flex; align-items: center; justify-content: center;
	font-size: 36px;
	box-shadow: inset 0 4px 12px rgba(20,34,58,.06);
}

/* Liste postes */
.smc-bv-postes { display: flex; flex-direction: column; gap: 10px; }
.smc-bv-poste {
	display: grid; grid-template-columns: 8px 1fr; gap: 14px;
	padding: 12px 0;
	border-bottom: 1px dashed rgba(184,147,92,.15);
	align-items: center;
}
.smc-bv-poste:last-child { border-bottom: none; }
@media (min-width: 600px) {
	.smc-bv-poste { grid-template-columns: 8px 1fr auto; }
}
.smc-bv-poste__color { width: 8px; height: 36px; border-radius: 4px; }
.smc-bv-poste__main { display: flex; justify-content: space-between; align-items: baseline; flex-wrap: wrap; gap: 6px; }
.smc-bv-poste__label { font-family: 'Poppins', sans-serif; font-size: 14.5px; font-weight: 600; color: #14223A; }
.smc-bv-poste__pct { color: #5C6578; font-weight: 400; font-size: 12px; }
.smc-bv-poste__amount { font-family: 'Poppins', sans-serif; font-size: 16px; font-weight: 700; color: #B8935C; }
.smc-bv-poste__cta {
	display: inline-flex; align-items: center;
	background: #FBF5E6; border: 1px solid rgba(184,147,92,.25);
	border-radius: 8px; padding: 6px 12px;
	font-size: 12.5px; font-weight: 600;
	color: #14223A !important; text-decoration: none !important;
	transition: all .2s ease;
}
.smc-bv-poste__cta:hover {
	background: linear-gradient(135deg, #FBF5E6 0%, rgba(184,147,92,.15) 100%);
	border-color: #B8935C;
}

/* Bridge */
.smc-bv-bridge {
	margin-top: 22px;
	padding: 18px 20px;
	background: linear-gradient(135deg, #FBF5E6 0%, rgba(184,147,92,.08) 100%);
	border-left: 3px solid #B8935C;
	border-radius: 12px;
}
.smc-bv-bridge h4 {
	font-family: 'Poppins', sans-serif;
	font-size: 14px; font-weight: 700; color: #14223A;
	margin: 0 0 10px;
}
.smc-bv-bridge__links { display: flex; flex-wrap: wrap; gap: 8px; }
.smc-bv-bridge__link {
	display: inline-flex; align-items: center;
	background: #FFFFFF; border: 1px solid rgba(184,147,92,.25);
	border-radius: 8px; padding: 9px 14px;
	color: #14223A !important; text-decoration: none !important;
	font-size: 13px; font-weight: 600;
	transition: all .2s ease;
}
.smc-bv-bridge__link:hover { transform: translateY(-2px); border-color: #B8935C; }
.smc-bv-bridge__link--primary {
	background: linear-gradient(135deg, #14223A 0%, #2E4166 100%);
	color: #F7F1E3 !important;
	border-color: #14223A;
}

/* Actions */
.smc-bv-actions { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; margin-top: 22px; }
button.smc-bv-btn-secondary {
	background: transparent !important;
	border: 2px solid #B8935C !important;
	color: #B8935C !important;
	padding: 11px 22px !important; border-radius: 10px !important;
	font-size: 13px !important; font-weight: 600 !important;
	cursor: pointer !important;
}
button.smc-bv-btn-secondary:hover { background: #B8935C !important; color: #14223A !important; }
