/* Outil F — Calculateur épargne Omra */

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

.smc-eo-calc { max-width: 760px; margin: 32px auto; padding: 0 16px; }
.smc-eo-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-eo-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-eo-calc__card > * { position: relative; z-index: 1; }
.smc-eo-calc__title { font-family: 'Cormorant Garamond', serif; font-size: 26px; color: #F7F1E3 !important; margin: 0 0 6px; text-align: center; }
.smc-eo-calc__title em { color: #D4B27E !important; font-style: italic; }
.smc-eo-calc__intro { text-align: center; font-size: 14px; color: rgba(247,241,227,.8); margin: 0 0 22px; }

.smc-eo-form { display: grid; grid-template-columns: 1fr; gap: 14px; }
@media (min-width: 600px) { .smc-eo-form { grid-template-columns: 1fr 1fr; } .smc-eo-form__field--full { grid-column: 1 / -1; } }
.smc-eo-form__field { display: block; }
.smc-eo-form__label {
	display: block; font-size: 12px; letter-spacing: 1px; text-transform: uppercase;
	color: #D4B27E; font-weight: 700; margin-bottom: 6px;
}
select.smc-eo-form__select, input.smc-eo-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-eo-form__select:focus, input.smc-eo-form__input:focus { outline: none !important; border-color: #D4B27E !important; }
select.smc-eo-form__select option { background: #14223A; color: #F7F1E3; }

button.smc-eo-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;
}
button.smc-eo-form__submit:hover { transform: translateY(-2px); }

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

/* Résultat */
.smc-eo-result { max-width: 760px; margin: 24px auto 32px; padding: 0 16px; }
.smc-eo-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-eo-fade .35s ease;
}
@keyframes smc-eo-fade { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } }

.smc-eo-result-card__header {
	display: grid; grid-template-columns: 1fr; gap: 18px;
	padding-bottom: 22px; margin-bottom: 18px;
	border-bottom: 1px solid rgba(184,147,92,.15);
}
@media (min-width: 600px) { .smc-eo-result-card__header { grid-template-columns: 1fr 1fr; gap: 22px; } }

.smc-eo-stat { text-align: center; padding: 18px 14px; border-radius: 14px; }
.smc-eo-stat--total { background: linear-gradient(135deg, #14223A 0%, #2E4166 100%); color: #F7F1E3; }
.smc-eo-stat--effort { background: linear-gradient(135deg, #D4B27E 0%, #B8935C 100%); color: #14223A; }
.smc-eo-stat__label { font-size: 11px; letter-spacing: 2px; text-transform: uppercase; font-weight: 700; opacity: .8; margin-bottom: 6px; }
.smc-eo-stat__value { font-family: 'Cormorant Garamond', serif; font-size: 38px; font-weight: 600; line-height: 1; }
.smc-eo-stat__unit { font-size: 16px; font-weight: 500; margin-left: 4px; }
.smc-eo-stat__sub { font-size: 12px; margin-top: 8px; opacity: .8; }

/* Verdict */
.smc-eo-verdict { padding: 18px 20px; border-radius: 12px; margin-bottom: 22px; }
.smc-eo-verdict--optimal { background: rgba(107,127,63,.08); border-left: 4px solid #6B7F3F; }
.smc-eo-verdict--confortable { background: rgba(184,147,92,.08); border-left: 4px solid #B8935C; }
.smc-eo-verdict--tendu { background: rgba(160,82,45,.08); border-left: 4px solid #A0522D; }
.smc-eo-verdict--inconnu { background: rgba(92,101,120,.08); border-left: 4px solid #5C6578; }
.smc-eo-verdict__title { font-family: 'Poppins', sans-serif; font-size: 15px; font-weight: 700; color: #14223A; margin-bottom: 6px; }
.smc-eo-verdict__message { font-size: 14px; line-height: 1.55; color: #2E4166; margin: 0; }
.smc-eo-verdict__suggestions { margin-top: 12px; font-size: 13.5px; color: #2E4166; }
.smc-eo-verdict__suggestions strong { display: block; color: #14223A; margin-bottom: 6px; font-weight: 700; }
.smc-eo-verdict__suggestions ul { padding-left: 22px; margin: 6px 0 0; }
.smc-eo-verdict__suggestions li { margin-bottom: 4px; line-height: 1.5; }

/* Postes */
.smc-eo-postes { margin-bottom: 22px; }
.smc-eo-postes__title {
	font-family: 'Poppins', sans-serif; font-size: 14px; font-weight: 700;
	color: #14223A; letter-spacing: .3px; text-transform: uppercase;
	margin: 0 0 12px;
}
.smc-eo-poste { display: grid; grid-template-columns: 8px 1fr; gap: 14px; padding: 10px 0; border-bottom: 1px dashed rgba(184,147,92,.15); align-items: center; }
.smc-eo-poste:last-child { border-bottom: none; }
.smc-eo-poste__color { width: 8px; height: 32px; border-radius: 4px; }
.smc-eo-poste__main { display: flex; justify-content: space-between; align-items: baseline; flex-wrap: wrap; gap: 6px; }
.smc-eo-poste__label { font-family: 'Poppins', sans-serif; font-size: 14px; font-weight: 600; color: #14223A; }
.smc-eo-poste__pct { color: #5C6578; font-weight: 400; font-size: 12px; }
.smc-eo-poste__amount { font-family: 'Poppins', sans-serif; font-size: 15px; font-weight: 700; color: #B8935C; }

/* CTAs Omra */
.smc-eo-ctas {
	margin-top: 22px;
	padding: 22px 22px 24px;
	background: linear-gradient(135deg, #14223A 0%, #2E4166 100%);
	border-radius: 14px;
	color: #F7F1E3;
}
.smc-eo-ctas h3 { font-family: 'Cormorant Garamond', serif; font-size: 22px; color: #F7F1E3; margin: 0 0 6px; }
.smc-eo-ctas__intro { font-size: 13.5px; color: rgba(247,241,227,.85); margin: 0 0 14px; line-height: 1.55; }
.smc-eo-ctas__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
@media (min-width: 600px) { .smc-eo-ctas__grid { grid-template-columns: repeat(3, 1fr); } }
.smc-eo-cta-btn {
	display: inline-flex; align-items: center; justify-content: center;
	padding: 11px 14px; border-radius: 10px;
	background: rgba(247,241,227,.08); border: 1px solid rgba(212,178,126,.35);
	color: #F7F1E3 !important; text-decoration: none !important;
	font-family: 'Poppins', sans-serif; font-size: 12.5px; font-weight: 600;
	transition: all .2s ease; text-align: center;
}
.smc-eo-cta-btn:hover { background: rgba(247,241,227,.15); border-color: #D4B27E; transform: translateY(-2px); }
.smc-eo-cta-btn--primary {
	background: linear-gradient(135deg, #D4B27E 0%, #B8935C 100%) !important;
	color: #14223A !important; border-color: #B8935C !important; font-weight: 700;
}

/* Internal links */
.smc-eo-internal { margin-top: 18px; padding: 16px 18px; background: #FBF5E6; border-radius: 12px; border-left: 3px solid #B8935C; }
.smc-eo-internal h4 { font-family: 'Poppins', sans-serif; font-size: 13px; font-weight: 700; color: #14223A; margin: 0 0 10px; letter-spacing: .3px; text-transform: uppercase; }
.smc-eo-internal__links { display: flex; flex-wrap: wrap; gap: 8px; }
.smc-eo-internal__link {
	display: inline-flex; align-items: center;
	background: #FFFFFF; border: 1px solid rgba(184,147,92,.25); border-radius: 8px;
	padding: 8px 14px; font-size: 13px; font-weight: 600;
	color: #14223A !important; text-decoration: none !important;
	transition: all .2s ease;
}
.smc-eo-internal__link:hover { transform: translateY(-2px); border-color: #B8935C; }
