/* ============================================================
 * STOP FACTURE — blocks.css
 * Frontend styles for all custom block patterns inserted via
 * the editor (lead, callouts, stats, pullquote, comparison,
 * inline CTAs, FAQ, verdict).
 * ========================================================== */

/* ─── 1. LEAD ESSENTIAL ───────────────────────────────────── */
.sfe-lead-essential{
	border:1px solid var(--sfe-ink);
	border-left:4px solid var(--sfe-burgundy);
	background:var(--sfe-cream-light);
	padding:24px 28px;margin:0 0 40px;
	position:relative;
}
.sfe-lead-essential::before{
	content:'';position:absolute;top:-1px;right:-1px;
	width:0;height:0;
	border-style:solid;border-width:0 22px 22px 0;
	border-color:transparent var(--sfe-burgundy) transparent transparent;
}
.sfe-lead-label{
	font-family:var(--sfe-mono);font-size:10px;font-weight:600;
	letter-spacing:.2em;text-transform:uppercase;color:var(--sfe-burgundy);
	margin-bottom:10px;display:flex;align-items:center;gap:10px;
}
.sfe-lead-label::after{
	content:'';flex:1;height:1px;background:var(--sfe-border);max-width:80px;
}
.sfe-lead-text{
	font-family:var(--sfe-serif);font-size:17px;line-height:1.55;
	color:var(--sfe-ink);font-weight:500;
}

/* ─── 2. H2 NUMÉROTÉ (chiffre romain) ─────────────────────── */
/* La classe .sfe-h2-num est appliquée dans single.css aux H2 du corps. */
/* Ici on assure l'affichage aussi pour les pages statiques. */
.sfe-page-inner h2 .sfe-h2-num,
.sfe-content h2 .sfe-h2-num{
	font-family:var(--sfe-mono);font-size:12px;font-weight:600;
	letter-spacing:.2em;color:var(--sfe-burgundy);
	display:block;margin-bottom:12px;text-transform:uppercase;
}

/* ─── 3. STATS ROW ───────────────────────────────────────── */
.sfe-stats-row{
	display:grid;grid-template-columns:repeat(3,1fr);gap:0;
	margin:36px 0;border:1px solid var(--sfe-ink);
}
.sfe-stat-cell{
	padding:24px 22px;
	border-right:1px solid var(--sfe-ink);
	background:var(--sfe-cream-light);
}
.sfe-stat-cell:last-child{border-right:none}
.sfe-stat-num{
	font-family:var(--sfe-serif);font-size:42px;font-weight:800;
	line-height:1;color:var(--sfe-burgundy);letter-spacing:-.02em;
}
.sfe-stat-num .sfe-stat-unit{
	font-size:18px;color:var(--sfe-ink);margin-left:3px;
}
.sfe-stat-lab{
	font-family:var(--sfe-mono);font-size:10px;letter-spacing:.12em;
	text-transform:uppercase;color:var(--sfe-gray);
	margin-top:10px;line-height:1.5;
}

/* ─── 4-6. CALLOUTS ──────────────────────────────────────── */
.sfe-callout{
	margin:32px 0;padding:24px 26px 24px 30px;
	border-left:4px solid;background:var(--sfe-cream-light);position:relative;
}
.sfe-callout-attention{border-color:var(--sfe-burgundy);background:rgba(139,26,26,.04)}
.sfe-callout-saviez   {border-color:var(--sfe-yellow);  background:rgba(232,197,71,.1)}
.sfe-callout-retenir  {border-color:var(--sfe-ink);     background:var(--sfe-cream-warm)}

.sfe-callout-label{
	font-family:var(--sfe-mono);font-size:10px;font-weight:600;
	letter-spacing:.2em;text-transform:uppercase;
	margin-bottom:8px;display:flex;align-items:center;gap:8px;
}
.sfe-callout-attention .sfe-callout-label{color:var(--sfe-burgundy)}
.sfe-callout-saviez   .sfe-callout-label{color:var(--sfe-ink)}
.sfe-callout-retenir  .sfe-callout-label{color:var(--sfe-ink)}
.sfe-callout-label::before{
	font-family:var(--sfe-serif);font-style:italic;font-weight:700;font-size:14px;
	width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;
}
.sfe-callout-attention .sfe-callout-label::before{content:'!';color:var(--sfe-burgundy)}
.sfe-callout-saviez   .sfe-callout-label::before{content:'?'}
.sfe-callout-retenir  .sfe-callout-label::before{content:'§'}

.sfe-callout p{
	font-family:var(--sfe-serif);font-size:16px;line-height:1.6;
	color:var(--sfe-ink);margin:0;
}
.sfe-callout p + p{margin-top:12px}

/* ─── 7. PULL QUOTE ──────────────────────────────────────── */
.sfe-pullquote{
	margin:48px -20px;padding:32px 28px;text-align:left;
	border-top:2px solid var(--sfe-ink);
	border-bottom:2px solid var(--sfe-ink);
	position:relative;
}
.sfe-pullquote::before{
	content:'«';position:absolute;top:14px;left:14px;
	font-family:var(--sfe-serif);font-size:96px;line-height:.5;
	color:var(--sfe-burgundy);opacity:.18;
}
.sfe-pullquote q{
	font-family:var(--sfe-serif);font-size:28px;font-style:italic;
	line-height:1.3;color:var(--sfe-ink);font-weight:500;letter-spacing:-.01em;
	quotes:none;display:block;margin:0 0 14px;padding-left:36px;
}
.sfe-pullquote cite{
	font-family:var(--sfe-mono);font-style:normal;font-size:11px;
	letter-spacing:.12em;text-transform:uppercase;color:var(--sfe-gray);
	padding-left:36px;display:block;
}

/* ─── 8. COMPARISON TABLE ────────────────────────────────── */
.sfe-comparison{
	margin:36px 0;border:1px solid var(--sfe-ink);overflow:hidden;
}
.sfe-comparison-head{
	display:grid;grid-template-columns:1.5fr 1fr 1fr;
	background:var(--sfe-ink);color:var(--sfe-cream);
	font-family:var(--sfe-mono);font-size:11px;font-weight:600;
	letter-spacing:.1em;text-transform:uppercase;
}
.sfe-comparison-head > div{
	padding:14px 18px;border-right:1px solid rgba(244,239,230,.2);
}
.sfe-comparison-head > div:last-child{border-right:none}
.sfe-comparison-row{
	display:grid;grid-template-columns:1.5fr 1fr 1fr;
	border-top:1px solid var(--sfe-border);
}
.sfe-comparison-row:nth-child(even){background:var(--sfe-cream-light)}
.sfe-comparison-row > div{
	padding:14px 18px;font-family:var(--sfe-serif);font-size:15px;
	border-right:1px solid var(--sfe-border);line-height:1.4;
}
.sfe-comparison-row > div:last-child{border-right:none}
.sfe-cmp-label{font-weight:600;color:var(--sfe-ink)}
.sfe-cmp-bad{color:var(--sfe-burgundy);font-weight:600}
.sfe-cmp-good{color:var(--sfe-good);font-weight:600}

/* Two-column variant (for /restructuration/ etc.) */
.sfe-comparison-2col .sfe-comparison-head,
.sfe-comparison-2col .sfe-comparison-row{
	grid-template-columns:1.5fr 1fr;
}

/* ─── 9. INLINE CTA (noir + barre jaune) ─────────────────── */
.sfe-cta-inline{
	margin:36px 0;background:var(--sfe-ink);color:var(--sfe-cream);
	padding:24px 28px;border-left:4px solid var(--sfe-yellow);
	display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center;
}
.sfe-cta-text h4{
	font-family:var(--sfe-serif);font-size:20px;font-weight:700;
	line-height:1.25;margin:0 0 6px;letter-spacing:-.01em;
	color:var(--sfe-cream);
}
.sfe-cta-text p{
	font-family:var(--sfe-sans);font-size:13px;
	color:rgba(244,239,230,.7);line-height:1.5;margin:0;
}
.sfe-cta-btn{
	background:var(--sfe-yellow);color:var(--sfe-ink);
	padding:14px 22px;
	font-family:var(--sfe-mono);font-size:12px;font-weight:600;
	letter-spacing:.1em;text-transform:uppercase;text-decoration:none;
	border:2px solid var(--sfe-yellow);white-space:nowrap;transition:all .2s;
}
.sfe-cta-btn:hover{background:transparent;color:var(--sfe-yellow)}

/* ─── 10. CTA PARTNER INLINE ─────────────────────────────── */
.sfe-cta-partner-inline{
	margin:40px 0;
	border:2px solid var(--sfe-ink);background:var(--sfe-cream-light);
	display:grid;grid-template-columns:1.5fr 1fr;gap:0;
}
.sfe-ctap-left{padding:28px 28px;border-right:1px solid var(--sfe-border)}
.sfe-ctap-right{
	padding:28px 24px;background:var(--sfe-cream-warm);
	display:flex;flex-direction:column;justify-content:center;gap:14px;
}
.sfe-ctap-tag{
	display:inline-block;
	font-family:var(--sfe-mono);font-size:10px;font-weight:600;
	letter-spacing:.18em;text-transform:uppercase;color:var(--sfe-burgundy);
	padding:4px 10px;border:1px solid var(--sfe-burgundy);
	background:var(--sfe-burgundy-soft);margin-bottom:14px;
}
.sfe-ctap-left h4{
	font-family:var(--sfe-serif);font-size:22px;font-weight:700;
	line-height:1.2;margin:0 0 10px;letter-spacing:-.01em;color:var(--sfe-ink);
}
.sfe-ctap-left p{
	font-family:var(--sfe-serif);font-size:15px;line-height:1.55;
	color:var(--sfe-ink-soft);margin:0 0 14px;
}
.sfe-ctap-bullets{
	list-style:none;margin:0;padding:0;display:grid;gap:6px;
}
.sfe-ctap-bullets li{
	font-family:var(--sfe-sans);font-size:13px;color:var(--sfe-ink-soft);
	padding-left:18px;position:relative;
}
.sfe-ctap-bullets li::before{
	content:'→';position:absolute;left:0;top:0;
	color:var(--sfe-burgundy);font-weight:700;
}
.sfe-ctap-promo{
	background:var(--sfe-cream);border:1px dashed var(--sfe-burgundy);
	padding:12px 14px;text-align:center;
}
.sfe-ctap-promo-lab{
	font-family:var(--sfe-mono);font-size:9px;font-weight:600;
	letter-spacing:.18em;text-transform:uppercase;color:var(--sfe-burgundy);margin-bottom:4px;
}
.sfe-ctap-promo-code{
	font-family:var(--sfe-mono);font-size:18px;font-weight:700;
	letter-spacing:.08em;color:var(--sfe-ink);
}
.sfe-ctap-btn{
	display:block;text-align:center;
	background:var(--sfe-burgundy);color:var(--sfe-cream);
	padding:14px 18px;
	font-family:var(--sfe-mono);font-size:12px;font-weight:600;
	letter-spacing:.1em;text-transform:uppercase;text-decoration:none;
	border:2px solid var(--sfe-burgundy);transition:all .2s;
}
.sfe-ctap-btn:hover{background:var(--sfe-ink);border-color:var(--sfe-ink);color:var(--sfe-cream)}
.sfe-ctap-tiny{
	font-family:var(--sfe-mono);font-size:9px;letter-spacing:.08em;
	color:var(--sfe-gray);text-align:center;line-height:1.5;
}

/* ─── 11. FAQ ────────────────────────────────────────────── */
.sfe-faq{margin:48px 0 0}
.sfe-faq-item{
	border-bottom:1px solid var(--sfe-border);
	padding:0;margin:0;
}
.sfe-faq-item summary{
	font-family:var(--sfe-serif);font-size:19px;font-weight:600;
	line-height:1.35;letter-spacing:-.01em;color:var(--sfe-ink);
	padding:20px 36px 20px 0;cursor:pointer;
	position:relative;list-style:none;outline:none;
	transition:color .2s;
}
.sfe-faq-item summary::-webkit-details-marker{display:none}
.sfe-faq-item summary::after{
	content:'+';position:absolute;right:0;top:50%;transform:translateY(-50%);
	font-family:var(--sfe-serif);font-size:28px;font-weight:400;
	color:var(--sfe-burgundy);transition:transform .25s;line-height:1;
}
.sfe-faq-item[open] summary::after{transform:translateY(-50%) rotate(45deg)}
.sfe-faq-item summary:hover{color:var(--sfe-burgundy)}
.sfe-faq-answer{
	font-family:var(--sfe-serif);font-size:16px;line-height:1.7;
	color:var(--sfe-ink-soft);padding:0 0 22px;
}
.sfe-faq-answer p{margin:0 0 12px}
.sfe-faq-answer p:last-child{margin-bottom:0}

/* ─── 12. VERDICT ────────────────────────────────────────── */
.sfe-verdict{
	margin:48px 0;padding:0;
	border:2px solid var(--sfe-ink);
	background:var(--sfe-cream-light);
	display:grid;grid-template-columns:140px 1fr;gap:0;
	position:relative;overflow:hidden;
}
.sfe-verdict-stamp{
	background:var(--sfe-burgundy);color:var(--sfe-cream);
	font-family:var(--sfe-serif);font-size:28px;font-weight:900;
	font-style:italic;letter-spacing:-.01em;
	display:flex;align-items:center;justify-content:center;
	border-right:2px solid var(--sfe-ink);position:relative;
}
.sfe-verdict-stamp::after{
	content:'';position:absolute;inset:8px;
	border:1px solid rgba(244,239,230,.3);
}
.sfe-verdict-body{padding:28px 32px}
.sfe-verdict-body h3{
	font-family:var(--sfe-serif);font-size:24px;font-weight:700;
	font-style:italic;line-height:1.3;letter-spacing:-.01em;
	color:var(--sfe-ink);margin:0 0 12px;
}
.sfe-verdict-body p{
	font-family:var(--sfe-serif);font-size:16px;line-height:1.6;
	color:var(--sfe-ink-soft);margin:0 0 14px;
}
.sfe-verdict-sign{
	font-family:var(--sfe-mono);font-size:11px;font-weight:500;
	letter-spacing:.1em;text-transform:uppercase;color:var(--sfe-burgundy);
	padding-top:12px;border-top:1px dashed var(--sfe-border-strong);
}

/* ─── RESPONSIVE ─────────────────────────────────────────── */
@media (max-width:780px){
	.sfe-stats-row{grid-template-columns:1fr;border-right:1px solid var(--sfe-ink)}
	.sfe-stat-cell{border-right:none;border-bottom:1px solid var(--sfe-ink)}
	.sfe-stat-cell:last-child{border-bottom:none}

	.sfe-comparison-head,
	.sfe-comparison-row{grid-template-columns:1fr 1fr}
	.sfe-comparison-head > div:first-child,
	.sfe-comparison-row > div:first-child{
		grid-column:span 2;background:rgba(0,0,0,.04);font-weight:700;
	}

	.sfe-cta-inline{grid-template-columns:1fr;gap:18px}
	.sfe-cta-btn{justify-self:start}

	.sfe-cta-partner-inline{grid-template-columns:1fr}
	.sfe-ctap-left{border-right:none;border-bottom:1px solid var(--sfe-border)}

	.sfe-verdict{grid-template-columns:1fr}
	.sfe-verdict-stamp{
		padding:18px 0;border-right:none;border-bottom:2px solid var(--sfe-ink);
		font-size:22px;
	}

	.sfe-pullquote{margin:32px 0;padding:24px 18px}
	.sfe-pullquote q{font-size:22px;padding-left:24px}
	.sfe-pullquote cite{padding-left:24px}
}
