/* PJ Calculettes — feuille de style commune
 * Charte alignée sur le thème Divi de pierrejovercourtage.fr
 * Toutes les classes sont préfixées pj-calc- pour éviter les conflits.
 */

/* Grille pour [pj_calc_toutes] : deux calcs côte à côte sur desktop,
 * empilées en colonne sur mobile / petit écran. */
.pj-calc-grid {
	display: flex;
	flex-wrap: wrap;
	gap: 1.25rem;
	justify-content: center;
	align-items: flex-start;
	max-width: 1140px;
	margin: 0 auto 2rem;
}
.pj-calc-grid > .pj-calc {
	flex: 1 1 320px;
	max-width: 540px;
	margin: 0;
	padding: 0;
}

.pj-calc {
	--pj-bleu:        #3550a0;
	--pj-bleu-hover:  #4159a0;
	--pj-cyan:        #0b8ad7;
	--pj-orange:      #ff6c00;
	--pj-rouge:       #C70307;
	--pj-vert:        #1B7A4A;
	--pj-vert-bg:     #E8F5EC;
	--pj-orange-warn: #C67A1A;
	--pj-orange-bg:   #FFF3E0;
	--pj-rouge-bg:    #FDEAEA;
	--pj-gris-input:  #50646E;
	--pj-gris-bord:   #D4E8EE;
	--pj-gris-fond:   #FAFCFD;
	--pj-fond:        #ffffff;
	--pj-texte:       #2c3e50;
	--pj-mute:        #6b7c85;

	font-family: 'Lato', Helvetica, Arial, sans-serif;
	color: var(--pj-texte);
	max-width: 540px;
	margin: 0 auto 2.5rem;
	padding: 0 8px;
	line-height: 1.5;
	box-sizing: border-box;
}
.pj-calc *, .pj-calc *::before, .pj-calc *::after { box-sizing: border-box; }

/* L'attribut HTML [hidden] doit forcer display:none même si une autre règle
 * définit un display (grid, flex, table…). Règle générique dans le scope. */
.pj-calc [hidden] { display: none !important; }

/* ===== Titres ===== */

.pj-calc h2.pj-calc-titre {
	font-family: 'Playfair Display', Georgia, serif;
	color: var(--pj-orange);
	font-size: 1.85rem;
	font-weight: 700;
	margin: 0 0 1rem;
	text-align: center;
	line-height: 1.2;
}
.pj-calc h3.pj-calc-soustitre {
	color: var(--pj-cyan);
	font-size: 1.05rem;
	font-weight: 700;
	margin: 0 0 1.25rem;
	text-align: center;
	letter-spacing: 0.02em;
}
.pj-calc h3.pj-calc-section {
	font-family: 'Playfair Display', Georgia, serif;
	color: var(--pj-orange);
	font-size: 1.45rem;
	font-weight: 700;
	margin: 0 0 1rem;
	text-align: center;
}

/* ===== Carte / formulaire ===== */

.pj-calc-card {
	background: var(--pj-fond);
	border: 1px solid var(--pj-gris-bord);
	border-radius: 12px;
	box-shadow: 0 2px 16px rgba(53, 80, 160, 0.06);
	padding: 1.25rem;
	margin-bottom: 1.5rem;
}

.pj-calc-row {
	display: grid;
	grid-template-columns: 1fr;
	gap: 0.35rem;
	margin-bottom: 0.9rem;
}
@media (min-width: 480px) {
	.pj-calc-row {
		grid-template-columns: 1fr 1.2fr;
		gap: 0.75rem;
		align-items: center;
	}
	.pj-calc-row > label { text-align: right; }
}

.pj-calc-row > label {
	font-size: 0.95rem;
	color: var(--pj-texte);
	font-weight: 400;
}

.pj-calc-input,
.pj-calc-select {
	width: 100%;
	font-family: inherit;
	font-size: 1rem;
	padding: 0.55rem 0.75rem;
	border: 1px solid var(--pj-gris-input);
	border-radius: 6px;
	background: var(--pj-gris-fond);
	color: var(--pj-texte);
	transition: border-color 0.15s, box-shadow 0.15s;
	-webkit-appearance: none;
	appearance: none;
}
.pj-calc-input:focus,
.pj-calc-select:focus {
	outline: none;
	border-color: var(--pj-bleu);
	box-shadow: 0 0 0 3px rgba(53, 80, 160, 0.15);
}
.pj-calc-input.pj-calc-disabled,
.pj-calc-input:disabled {
	background: #eef1f4;
	color: var(--pj-mute);
}

/* Champ avec suffixe (€, %, € / mois) */
.pj-calc-suffix {
	display: flex;
	align-items: stretch;
}
.pj-calc-suffix .pj-calc-input {
	border-top-right-radius: 0;
	border-bottom-right-radius: 0;
	text-align: right;
	border-right: none;
}
.pj-calc-suffix .pj-calc-suffix-tag {
	background: #e9eef3;
	border: 1px solid var(--pj-gris-input);
	border-left: none;
	border-top-right-radius: 6px;
	border-bottom-right-radius: 6px;
	padding: 0 0.75rem;
	display: flex;
	align-items: center;
	font-size: 0.95rem;
	color: var(--pj-texte);
	min-width: 3rem;
	justify-content: center;
}

/* Durée années + mois côte à côte */
.pj-calc-duree {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	gap: 0.4rem;
	align-items: center;
}
.pj-calc-duree .pj-calc-amp {
	color: var(--pj-mute);
	font-weight: 700;
	text-align: center;
}

/* Radios seul/couple, neuf/ancien */
.pj-calc-radios {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	padding: 0.25rem 0;
}
.pj-calc-radios label {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	cursor: pointer;
	font-size: 0.95rem;
}
.pj-calc-radios input[type="radio"] {
	accent-color: var(--pj-bleu);
	width: 1.05rem;
	height: 1.05rem;
}

/* ===== Boutons ===== */

.pj-calc-actions {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 0.5rem;
	margin-top: 1.25rem;
}

.pj-calc-btn {
	display: inline-block;
	font-family: 'Lato', Helvetica, Arial, sans-serif;
	font-weight: 900;
	font-size: 16px;
	line-height: 1;
	padding: 0.85em 1.6em;
	border-radius: 100px;
	border: none;
	cursor: pointer;
	text-decoration: none;
	text-align: center;
	transition: background-color 200ms ease, transform 100ms ease;
}
.pj-calc-btn-primary {
	background: var(--pj-bleu);
	color: #ffffff;
}
.pj-calc-btn-primary:hover,
.pj-calc-btn-primary:focus {
	background: var(--pj-bleu-hover);
	color: #ffffff;
	text-decoration: none;
}
.pj-calc-btn-secondary {
	background: #ffffff;
	color: var(--pj-bleu);
	box-shadow: inset 0 0 0 2px var(--pj-bleu);
}
.pj-calc-btn-secondary:hover,
.pj-calc-btn-secondary:focus {
	background: var(--pj-bleu);
	color: #ffffff;
	text-decoration: none;
}
.pj-calc-btn-ghost {
	background: transparent;
	color: var(--pj-bleu);
	box-shadow: inset 0 0 0 1.5px var(--pj-bleu);
	font-size: 14px;
	padding: 0.6em 1.2em;
}
.pj-calc-btn-ghost:hover,
.pj-calc-btn-ghost:focus {
	background: var(--pj-bleu);
	color: #ffffff;
}

/* ===== Encart résultat ===== */

.pj-calc-resultat {
	background: var(--pj-vert-bg);
	border: 1px solid #b9d9c4;
	border-radius: 12px;
	padding: 1.25rem 1.25rem 1.4rem;
	margin: 1rem 0 1.25rem;
}
.pj-calc-resultat[hidden] { display: none; }

.pj-calc-resultat-titre {
	font-family: 'Playfair Display', Georgia, serif;
	color: var(--pj-orange);
	font-size: 1.4rem;
	font-weight: 700;
	margin: 0 0 0.9rem;
	text-align: center;
}

.pj-calc-resultat-line {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	gap: 0.5rem;
	padding: 0.25rem 0;
	font-size: 0.95rem;
}
.pj-calc-resultat-line .label { color: var(--pj-texte); }
.pj-calc-resultat-line .value {
	color: var(--pj-vert);
	font-weight: 700;
	white-space: nowrap;
}

/* Mensualité ou prix max — en gros */
.pj-calc-resultat-hero {
	margin: 0.6rem -0.5rem 0.9rem;
	padding: 0.9rem 0.5rem;
	border-top: 1px dashed #9fc7af;
	border-bottom: 1px dashed #9fc7af;
	text-align: center;
}
.pj-calc-resultat-hero .label {
	display: block;
	font-size: 0.95rem;
	color: var(--pj-texte);
	margin-bottom: 0.15rem;
}
.pj-calc-resultat-hero .value {
	font-family: 'Playfair Display', Georgia, serif;
	font-size: 2.2rem;
	font-weight: 700;
	color: var(--pj-bleu);
	line-height: 1.1;
}

/* ===== Tableau d'amortissement ===== */

.pj-calc-amort-toggle {
	display: flex;
	justify-content: center;
	margin: 0.5rem 0 0.75rem;
}

.pj-calc-amort-wrap {
	margin: 0 -1.25rem 1rem;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}
.pj-calc-amort-wrap[hidden] { display: none; }

.pj-calc-amort {
	width: 100%;
	border-collapse: collapse;
	font-size: 0.9rem;
	min-width: 480px;
}
.pj-calc-amort thead th {
	background: var(--pj-bleu);
	color: #ffffff;
	font-weight: 700;
	padding: 0.55rem 0.6rem;
	text-align: right;
	font-size: 0.85rem;
	letter-spacing: 0.02em;
}
.pj-calc-amort thead th:first-child { text-align: left; }
.pj-calc-amort tbody td {
	padding: 0.45rem 0.6rem;
	text-align: right;
	border-bottom: 1px solid #eef1f4;
	font-variant-numeric: tabular-nums;
}
.pj-calc-amort tbody td:first-child {
	text-align: left;
	color: var(--pj-mute);
}
.pj-calc-amort tbody tr:nth-child(even) td {
	background: var(--pj-gris-fond);
}

/* ===== Indicateur d'endettement ===== */

.pj-calc-endet {
	display: flex;
	align-items: center;
	gap: 0.6rem;
	margin-top: 0.75rem;
	padding: 0.6rem 0.85rem;
	border-radius: 8px;
	font-size: 0.95rem;
	font-weight: 700;
}
.pj-calc-endet .pj-calc-endet-dot {
	width: 0.7rem;
	height: 0.7rem;
	border-radius: 50%;
	flex: none;
}
.pj-calc-endet[data-niveau="ok"]      { background: var(--pj-vert-bg);    color: var(--pj-vert); }
.pj-calc-endet[data-niveau="ok"]      .pj-calc-endet-dot { background: var(--pj-vert); }
.pj-calc-endet[data-niveau="warn"]    { background: var(--pj-orange-bg);  color: var(--pj-orange-warn); }
.pj-calc-endet[data-niveau="warn"]    .pj-calc-endet-dot { background: var(--pj-orange-warn); }
.pj-calc-endet[data-niveau="depasse"] { background: var(--pj-rouge-bg);   color: var(--pj-rouge); }
.pj-calc-endet[data-niveau="depasse"] .pj-calc-endet-dot { background: var(--pj-rouge); }

/* ===== Alerte HCSF ===== */

.pj-calc-alerte {
	background: var(--pj-orange-bg);
	border-left: 4px solid var(--pj-orange-warn);
	color: var(--pj-orange-warn);
	padding: 0.75rem 1rem;
	border-radius: 8px;
	margin: 0.75rem 0;
	font-size: 0.95rem;
}
.pj-calc-alerte[hidden] { display: none; }

/* ===== Résultat lead capture (enveloppe XL) ===== */

.pj-calc-resultat-lead {
	background: linear-gradient(180deg, #f6f9ff 0%, #ffffff 100%);
	border: 1px solid var(--pj-gris-bord);
	box-shadow: 0 4px 28px rgba(53, 80, 160, 0.10);
	text-align: center;
	padding: 1.6rem 1.25rem 1.5rem;
}
.pj-calc-enveloppe-label {
	font-family: 'Lato', Helvetica, Arial, sans-serif;
	font-size: 0.95rem;
	font-weight: 700;
	color: var(--pj-cyan);
	letter-spacing: 0.04em;
	text-transform: uppercase;
	margin: 0 0 0.4rem;
}
.pj-calc-enveloppe-value {
	font-family: 'Playfair Display', Georgia, serif;
	font-size: 2.8rem;
	font-weight: 700;
	color: var(--pj-orange);
	line-height: 1.05;
	margin: 0 0 0.6rem;
}
@media (min-width: 480px) {
	.pj-calc-enveloppe-value { font-size: 3.4rem; }
}
.pj-calc-enveloppe-mention {
	font-size: 0.82rem;
	color: var(--pj-mute);
	line-height: 1.5;
	margin: 0 auto 1.1rem;
	max-width: 28em;
}
.pj-calc-actions-lead {
	margin-top: 0.5rem;
}

.pj-calc-btn-xl {
	font-size: 17px;
	padding: 1em 1.8em;
	box-shadow: 0 4px 14px rgba(53, 80, 160, 0.25);
}
.pj-calc-btn-xl:hover {
	transform: translateY(-1px);
	box-shadow: 0 6px 20px rgba(53, 80, 160, 0.32);
}

/* ===== Modale lead capture ===== */

.pj-calc-lead-modal {
	/* La modale est rendue hors du scope .pj-calc, donc on doit redéfinir
	 * ici les variables de couleur utilisées par .pj-calc-btn-primary etc. */
	--pj-bleu:        #3550a0;
	--pj-bleu-hover:  #4159a0;
	--pj-cyan:        #0b8ad7;
	--pj-orange:      #ff6c00;
	--pj-rouge:       #C70307;
	--pj-vert:        #1B7A4A;
	--pj-vert-bg:     #E8F5EC;
	--pj-rouge-bg:    #FDEAEA;
	--pj-gris-input:  #50646E;
	--pj-gris-fond:   #FAFCFD;
	--pj-mute:        #6b7c85;
	--pj-texte:       #2c3e50;

	position: fixed;
	inset: 0;
	z-index: 99999;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 1rem;
	font-family: 'Lato', Helvetica, Arial, sans-serif;
	color: var(--pj-texte);
	box-sizing: border-box;
}
.pj-calc-lead-modal[hidden] { display: none; }
.pj-calc-lead-modal *, .pj-calc-lead-modal *::before, .pj-calc-lead-modal *::after { box-sizing: border-box; }

.pj-calc-lead-overlay {
	position: absolute;
	inset: 0;
	background: rgba(15, 25, 50, 0.55);
	backdrop-filter: blur(2px);
	-webkit-backdrop-filter: blur(2px);
	animation: pjCalcFade 180ms ease;
}
.pj-calc-lead-dialog {
	position: relative;
	background: #ffffff;
	border-radius: 14px;
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.25);
	width: 100%;
	max-width: 520px;
	max-height: 90vh;
	overflow-y: auto;
	padding: 1.6rem 1.5rem 1.4rem;
	animation: pjCalcSlide 220ms ease;
}
@keyframes pjCalcFade { from { opacity: 0; } to { opacity: 1; } }
@keyframes pjCalcSlide {
	from { opacity: 0; transform: translateY(12px); }
	to   { opacity: 1; transform: translateY(0); }
}

.pj-calc-lead-close {
	position: absolute;
	top: 0.5rem;
	right: 0.7rem;
	background: transparent;
	border: none;
	font-size: 1.8rem;
	line-height: 1;
	color: var(--pj-mute, #6b7c85);
	cursor: pointer;
	padding: 0.25rem 0.5rem;
}
.pj-calc-lead-close:hover { color: var(--pj-bleu, #3550a0); }

.pj-calc-lead-titre {
	font-family: 'Playfair Display', Georgia, serif;
	color: var(--pj-bleu, #3550a0);
	font-size: 1.45rem;
	font-weight: 700;
	margin: 0 0 0.3rem;
	padding-right: 1.5rem;
}
.pj-calc-lead-intro {
	font-size: 0.95rem;
	color: var(--pj-texte, #2c3e50);
	margin: 0 0 1rem;
}

.pj-calc-lead-summary {
	background: #f6f9ff;
	border-left: 3px solid var(--pj-orange, #ff6c00);
	border-radius: 6px;
	padding: 0.7rem 0.9rem;
	margin: 0 0 1.1rem;
	font-size: 0.9rem;
}
.pj-calc-lead-summary[hidden] { display: none; }
.pj-calc-lead-summary-titre {
	font-weight: 700;
	margin: 0 0 0.4rem;
	color: var(--pj-bleu, #3550a0);
	font-size: 0.85rem;
	text-transform: uppercase;
	letter-spacing: 0.04em;
}
.pj-calc-lead-summary ul {
	margin: 0;
	padding: 0 0 0 1.1rem;
	list-style: disc;
}
.pj-calc-lead-summary li { margin-bottom: 0.2rem; line-height: 1.45; }
.pj-calc-lead-summary li strong { color: var(--pj-orange, #ff6c00); }

.pj-calc-lead-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 0.7rem 0.8rem;
	margin-bottom: 0.9rem;
}
@media (min-width: 460px) {
	.pj-calc-lead-grid { grid-template-columns: 1fr 1fr; }
}
.pj-calc-lead-field {
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
}
.pj-calc-lead-field > span {
	font-size: 0.85rem;
	font-weight: 700;
	color: var(--pj-texte, #2c3e50);
}
.pj-calc-lead-field input,
.pj-calc-lead-field textarea {
	font-family: inherit;
	font-size: 1rem;
	padding: 0.55rem 0.75rem;
	border: 1px solid var(--pj-gris-input, #50646E);
	border-radius: 6px;
	background: var(--pj-gris-fond, #FAFCFD);
	color: var(--pj-texte, #2c3e50);
	width: 100%;
}
.pj-calc-lead-field textarea {
	resize: vertical;
	min-height: 70px;
	font-family: inherit;
	line-height: 1.4;
}
.pj-calc-lead-field input:focus,
.pj-calc-lead-field textarea:focus {
	outline: none;
	border-color: var(--pj-bleu, #3550a0);
	box-shadow: 0 0 0 3px rgba(53, 80, 160, 0.15);
}
.pj-calc-lead-field-full {
	grid-column: 1 / -1;
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
	margin-bottom: 0.9rem;
}
.pj-calc-lead-field-full > span {
	font-size: 0.85rem;
	font-weight: 700;
	color: var(--pj-texte, #2c3e50);
}

/* Honeypot — invisible mais accessible aux bots */
.pj-calc-lead-honeypot {
	position: absolute;
	left: -9999px;
	top: -9999px;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

.pj-calc-lead-rgpd {
	display: flex;
	gap: 0.6rem;
	align-items: flex-start;
	font-size: 0.88rem;
	margin: 0.5rem 0 0.9rem;
	line-height: 1.45;
}
.pj-calc-lead-rgpd input[type="checkbox"] {
	margin-top: 0.2rem;
	accent-color: var(--pj-bleu, #3550a0);
	width: 1.1rem;
	height: 1.1rem;
	flex: none;
}

.pj-calc-lead-msg {
	padding: 0.6rem 0.85rem;
	border-radius: 6px;
	font-size: 0.9rem;
	margin: 0 0 0.8rem;
}
.pj-calc-lead-msg[data-niveau="erreur"] {
	background: var(--pj-rouge-bg, #FDEAEA);
	color: var(--pj-rouge, #C70307);
	border: 1px solid #f4c4c4;
}

.pj-calc-lead-actions {
	display: flex;
	justify-content: center;
	margin: 0.4rem 0 0.7rem;
}
.pj-calc-lead-actions .pj-calc-btn { width: 100%; }
@media (min-width: 460px) {
	.pj-calc-lead-actions .pj-calc-btn { width: auto; min-width: 240px; }
}

.pj-calc-lead-mentions {
	font-size: 0.74rem;
	color: var(--pj-mute, #6b7c85);
	line-height: 1.5;
	margin: 0;
	text-align: center;
}
.pj-calc-lead-mentions a {
	color: var(--pj-bleu, #3550a0);
	text-decoration: underline;
}

/* Écran de confirmation après envoi */
.pj-calc-lead-success {
	text-align: center;
	padding: 1rem 0.5rem;
}
.pj-calc-lead-success[hidden] { display: none; }
.pj-calc-lead-success-icon {
	width: 64px;
	height: 64px;
	border-radius: 50%;
	background: #E8F5EC;
	color: var(--pj-vert, #1B7A4A);
	font-size: 2.2rem;
	font-weight: 900;
	line-height: 64px;
	margin: 0 auto 0.9rem;
}
.pj-calc-lead-success p {
	margin: 0 0 0.6rem;
	font-size: 0.95rem;
}
.pj-calc-lead-success-tel a {
	color: var(--pj-bleu, #3550a0);
	font-weight: 900;
	text-decoration: none;
}
.pj-calc-lead-success-tel a:hover { text-decoration: underline; }

/* ===== Encart CTA ===== */

.pj-calc-cta {
	background: var(--pj-bleu);
	color: #ffffff;
	border-radius: 12px;
	padding: 1.25rem;
	margin: 1.25rem 0;
	text-align: center;
}
.pj-calc-cta-titre {
	font-family: 'Playfair Display', Georgia, serif;
	font-size: 1.2rem;
	font-weight: 700;
	margin: 0 0 0.4rem;
	color: #ffffff;
}
.pj-calc-cta-texte {
	margin: 0 0 1rem;
	color: rgba(255, 255, 255, 0.92);
	font-size: 0.95rem;
}
.pj-calc-cta-boutons {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	justify-content: center;
}
.pj-calc-cta .pj-calc-btn-primary {
	background: #ffffff;
	color: var(--pj-bleu);
}
.pj-calc-cta .pj-calc-btn-primary:hover {
	background: rgba(255, 255, 255, 0.9);
	color: var(--pj-bleu);
}
.pj-calc-cta .pj-calc-btn-secondary {
	background: transparent;
	color: #ffffff;
	box-shadow: inset 0 0 0 2px #ffffff;
}
.pj-calc-cta .pj-calc-btn-secondary:hover {
	background: #ffffff;
	color: var(--pj-bleu);
}

/* ===== Mentions ===== */

.pj-calc-mentions {
	font-size: 0.78rem;
	color: var(--pj-mute);
	text-align: center;
	margin: 0.75rem 0 0;
	line-height: 1.45;
}
.pj-calc-mentions a {
	color: var(--pj-bleu);
	text-decoration: underline;
}

/* ===== Erreur de saisie ===== */

.pj-calc-erreur {
	background: var(--pj-rouge-bg);
	color: var(--pj-rouge);
	border: 1px solid #f4c4c4;
	border-radius: 8px;
	padding: 0.6rem 0.85rem;
	margin: 0.75rem 0;
	font-size: 0.95rem;
}
.pj-calc-erreur[hidden] { display: none; }

/* ===== Impression ===== */

@media print {
	.pj-calc-actions,
	.pj-calc-cta,
	.pj-calc-amort-toggle,
	.pj-calc-card form,
	.pj-calc-mentions a { display: none !important; }
	.pj-calc { max-width: 100%; }
	.pj-calc-amort-wrap { overflow: visible; }
	.pj-calc-amort { min-width: 0; font-size: 10pt; }
	.pj-calc-resultat { background: #ffffff; border: 1px solid #ccc; }
}
