/* ======================================================================
   You Energie — Styles des 5 nouvelles landing pages (inspirées de
   Selectra, comparateur-energie.be, comparerfacile, moncomparateurdenergie).
   Tout est scopé sous body.yel-landing pour la spécificité vs thème parent.
   Palette : primary #0F7A3A · primary-dark #093D1D · accent #3FD071 ·
             accent-soft #C9F0D8 · surface #F5FBF7 · muted #5C6B61.
   ====================================================================== */

body.yel-landing .yel-lpx,
body.yel-landing .yel-lpx * { box-sizing: border-box; }
body.yel-landing .yel-lpx [hidden] { display: none !important; }

:root {
	--yel-primary: #0F7A3A;
	--yel-primary-dark: #093D1D;
	--yel-accent: #3FD071;
	--yel-accent-soft: #C9F0D8;
	--yel-surface: #F5FBF7;
	--yel-muted: #5C6B61;
	--yel-contrast: #0A1F12;
	--yel-radius: 16px;
	--yel-shadow: 0 18px 48px rgba(9, 61, 29, 0.12);
	--yel-shadow-sm: 0 6px 20px rgba(9, 61, 29, 0.08);
}

/* Generic helpers -------------------------------------------------------- */
body.yel-landing .yel-wrap { max-width: 1180px; margin: 0 auto; padding: 0 24px; }
body.yel-landing .yel-eyebrow {
	display: inline-block; padding: 6px 14px; border-radius: 999px;
	background: rgba(63, 208, 113, 0.16); color: var(--yel-primary);
	border: 1px solid rgba(63, 208, 113, 0.35);
	font-size: 13px; font-weight: 700; letter-spacing: .01em; margin: 0 0 16px;
}
body.yel-landing .yel-accent-text { color: var(--yel-primary); }
body.yel-landing .yel-cta {
	display: inline-flex; align-items: center; justify-content: center; gap: 8px;
	background: var(--yel-primary); color: #fff; font-weight: 700; font-size: 16px;
	padding: 15px 28px; border-radius: 999px; border: 0; cursor: pointer;
	text-decoration: none; transition: transform .15s ease, background .15s ease, box-shadow .15s ease;
	box-shadow: 0 10px 24px rgba(15, 122, 58, 0.28);
}
body.yel-landing .yel-cta:hover { background: #0c662f; transform: translateY(-1px); }
body.yel-landing .yel-cta--ghost {
	background: #fff; color: var(--yel-primary-dark); border: 1.5px solid var(--yel-accent-soft);
	box-shadow: none;
}
body.yel-landing .yel-cta--block { width: 100%; }

/* ======================================================================
   LP1 — COMPARATEUR DE PRIX (Selectra-like)
   ====================================================================== */
body.yel-landing .yel-cmp-hero {
	background: linear-gradient(150deg, var(--yel-primary-dark) 0%, #0c5a2d 100%);
	color: #fff; padding: clamp(48px, 7vw, 88px) 0;
}
body.yel-landing .yel-cmp-hero__eyebrow {
	color: var(--yel-accent); background: rgba(63,208,113,.14); border-color: rgba(63,208,113,.4);
}
body.yel-landing .yel-cmp-hero h1 {
	font-size: clamp(30px, 4.4vw, 52px); line-height: 1.08; font-weight: 800;
	letter-spacing: -0.025em; margin: 0 0 16px; color: #fff;
}
body.yel-landing .yel-cmp-hero__lead { font-size: 18px; color: #cfe9d8; max-width: 640px; margin: 0 0 28px; }
body.yel-landing .yel-cmp-stats {
	display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; margin-top: 40px;
}
body.yel-landing .yel-cmp-stat {
	background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.12);
	border-radius: var(--yel-radius); padding: 20px;
}
body.yel-landing .yel-cmp-stat strong { display: block; font-size: 30px; font-weight: 800; color: var(--yel-accent); }
body.yel-landing .yel-cmp-stat span { font-size: 13px; color: #bcd9c6; line-height: 1.35; }

/* Logos défilants */
body.yel-landing .yel-logos { background: #fff; padding: 28px 0; border-bottom: 1px solid #eef4f0; overflow: hidden; }
body.yel-landing .yel-logos__title { text-align: center; font-size: 13px; color: var(--yel-muted); text-transform: uppercase; letter-spacing: .08em; margin: 0 0 18px; }
body.yel-landing .yel-logos__track { display: flex; gap: 48px; align-items: center; justify-content: center; flex-wrap: wrap; }
body.yel-landing .yel-logos__track span { font-weight: 700; color: #9bb0a3; font-size: 17px; }

/* Tableau comparateur */
body.yel-landing .yel-cmp-table-section { padding: clamp(48px, 7vw, 88px) 0; background: var(--yel-surface); }
body.yel-landing .yel-cmp-table-section h2 {
	font-size: clamp(26px, 3.6vw, 40px); font-weight: 800; color: var(--yel-primary-dark);
	letter-spacing: -0.02em; margin: 0 0 12px; text-align: center;
}
body.yel-landing .yel-cmp-table-section__lead { text-align: center; color: var(--yel-muted); max-width: 720px; margin: 0 auto 28px; font-size: 16px; }
body.yel-landing .yel-cmp-controls {
	display: flex; flex-wrap: wrap; gap: 16px; align-items: center; justify-content: center;
	background: #fff; border: 1px solid #e6efe9; border-radius: var(--yel-radius);
	padding: 18px; margin-bottom: 18px; box-shadow: var(--yel-shadow-sm);
}
body.yel-landing .yel-cmp-tabs { display: inline-flex; background: var(--yel-surface); border-radius: 999px; padding: 4px; }
body.yel-landing .yel-cmp-tab {
	border: 0; background: transparent; padding: 8px 18px; border-radius: 999px; cursor: pointer;
	font-weight: 700; color: var(--yel-muted); font-size: 14px;
}
body.yel-landing .yel-cmp-tab.is-active { background: var(--yel-primary); color: #fff; }
body.yel-landing .yel-cmp-field { display: flex; flex-direction: column; gap: 4px; font-size: 13px; color: var(--yel-muted); font-weight: 600; }
body.yel-landing .yel-cmp-field select,
body.yel-landing .yel-cmp-field input {
	border: 1.5px solid #d8e6dd; border-radius: 10px; padding: 9px 12px; font-size: 14px; color: var(--yel-contrast);
	background: #fff; min-width: 180px;
}
body.yel-landing .yel-cmp-tablewrap { background: #fff; border: 1px solid #e6efe9; border-radius: var(--yel-radius); overflow: hidden; box-shadow: var(--yel-shadow-sm); }
body.yel-landing table.yel-cmp-table { width: 100%; border-collapse: collapse; font-size: 14.5px; }
body.yel-landing .yel-cmp-table thead th {
	background: var(--yel-primary-dark); color: #fff; text-align: left; padding: 14px 16px; font-weight: 700; font-size: 13px;
	cursor: pointer; white-space: nowrap; user-select: none;
}
body.yel-landing .yel-cmp-table thead th[data-sortable]::after { content: " ⇅"; opacity: .5; font-size: 11px; }
body.yel-landing .yel-cmp-table thead th.is-asc::after { content: " ↑"; opacity: 1; }
body.yel-landing .yel-cmp-table thead th.is-desc::after { content: " ↓"; opacity: 1; }
body.yel-landing .yel-cmp-table tbody td { padding: 14px 16px; border-top: 1px solid #eef4f0; vertical-align: middle; }
body.yel-landing .yel-cmp-table tbody tr:nth-child(even) { background: #fafdfb; }
body.yel-landing .yel-cmp-table tbody tr.is-best { background: rgba(63,208,113,.10); }
body.yel-landing .yel-cmp-supplier { display: flex; align-items: center; gap: 12px; }
body.yel-landing .yel-cmp-supplier__logo {
	width: 40px; height: 40px; border-radius: 9px; background: var(--yel-surface);
	display: inline-flex; align-items: center; justify-content: center; font-weight: 800; color: var(--yel-primary); border: 1px solid #e6efe9; flex: none;
}
body.yel-landing .yel-cmp-supplier__name { font-weight: 700; color: var(--yel-contrast); }
body.yel-landing .yel-cmp-supplier__offer { font-size: 12.5px; color: var(--yel-muted); }
body.yel-landing .yel-cmp-badge { display: inline-block; font-size: 11px; font-weight: 700; padding: 3px 8px; border-radius: 6px; margin-right: 4px; }
body.yel-landing .yel-cmp-badge--green { background: var(--yel-accent-soft); color: #0c662f; }
body.yel-landing .yel-cmp-badge--fixe { background: #e7f0ff; color: #1d4ed8; }
body.yel-landing .yel-cmp-badge--indexe { background: #fff1e0; color: #b45309; }
body.yel-landing .yel-cmp-best { display: inline-block; font-size: 10.5px; font-weight: 800; padding: 2px 7px; border-radius: 999px; background: var(--yel-primary); color: #fff; margin-left: 6px; vertical-align: middle; }
body.yel-landing .yel-cmp-score { font-weight: 800; color: var(--yel-primary); }
body.yel-landing .yel-cmp-eco--pos { color: var(--yel-primary); font-weight: 800; }
body.yel-landing .yel-cmp-eco--neg { color: #b91c1c; font-weight: 700; }
body.yel-landing .yel-cmp-table .yel-cta { padding: 9px 16px; font-size: 13.5px; box-shadow: none; }
body.yel-landing .yel-cmp-source { text-align: center; font-size: 12.5px; color: var(--yel-muted); margin-top: 16px; font-style: italic; }

/* ======================================================================
   FUNNEL GÉNÉRIQUE — utilisé par LP2 (wizard), LP3 (form expert), LP5 (cartes)
   ====================================================================== */
body.yel-landing .yel-funnel { background: #fff; border-radius: var(--yel-radius); box-shadow: var(--yel-shadow); border: 1px solid #eef4f0; overflow: hidden; }
body.yel-landing .yel-funnel__progress { height: 6px; background: #eef4f0; }
body.yel-landing .yel-funnel__progress-bar { height: 100%; background: linear-gradient(90deg, var(--yel-primary), var(--yel-accent)); width: 0; transition: width .4s ease; }
body.yel-landing .yel-funnel__steps-nav { display: flex; gap: 8px; padding: 18px 24px 0; }
body.yel-landing .yel-funnel__steps-nav span {
	flex: 1; display: flex; flex-direction: column; align-items: center; gap: 6px;
	font-size: 12px; color: #b3c4ba; font-weight: 600; position: relative;
}
body.yel-landing .yel-funnel__steps-nav span::before {
	content: attr(data-n); width: 26px; height: 26px; border-radius: 50%; background: #eef4f0; color: #9bb0a3;
	display: flex; align-items: center; justify-content: center; font-weight: 800; font-size: 13px;
}
body.yel-landing .yel-funnel__steps-nav span.is-active { color: var(--yel-primary-dark); }
body.yel-landing .yel-funnel__steps-nav span.is-active::before { background: var(--yel-primary); color: #fff; }
body.yel-landing .yel-funnel__steps-nav span.is-done::before { content: "✓"; background: var(--yel-accent); color: #07331a; }
body.yel-landing .yel-funnel__body { padding: clamp(24px, 4vw, 40px); }
body.yel-landing .yel-fstep { display: none; }
body.yel-landing .yel-fstep.is-active { display: block; animation: yelFade .35s ease; }
@keyframes yelFade { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
body.yel-landing .yel-fstep__kicker { font-size: 13px; font-weight: 700; color: var(--yel-primary); margin: 0 0 6px; }
body.yel-landing .yel-fstep__title { font-size: clamp(20px, 2.6vw, 28px); font-weight: 800; color: var(--yel-primary-dark); margin: 0 0 6px; line-height: 1.2; }
body.yel-landing .yel-fstep__hint { font-size: 14.5px; color: var(--yel-muted); margin: 0 0 20px; }

/* Tiles / cards de réponse */
body.yel-landing .yel-tiles { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 12px; }
body.yel-landing .yel-tiles.is-2col { grid-template-columns: repeat(2, 1fr); }
body.yel-landing .yel-tile { position: relative; cursor: pointer; }
body.yel-landing .yel-tile input { position: absolute; opacity: 0; inset: 0; cursor: pointer; }
body.yel-landing .yel-tile__inner {
	display: flex; flex-direction: column; align-items: center; text-align: center; gap: 8px;
	border: 1.5px solid #e1ece5; border-radius: 14px; padding: 20px 14px; background: #fff; height: 100%;
	transition: border-color .15s ease, box-shadow .15s ease, transform .15s ease;
}
body.yel-landing .yel-tile:hover .yel-tile__inner { border-color: var(--yel-accent); transform: translateY(-2px); box-shadow: var(--yel-shadow-sm); }
body.yel-landing .yel-tile input:checked + .yel-tile__inner { border-color: var(--yel-primary); box-shadow: 0 0 0 3px var(--yel-accent-soft); background: var(--yel-surface); }
body.yel-landing .yel-tile__emoji { font-size: 28px; }
body.yel-landing .yel-tile__label { font-weight: 700; color: var(--yel-contrast); font-size: 15px; }
body.yel-landing .yel-tile__label small { display: block; font-weight: 500; color: var(--yel-muted); font-size: 12.5px; margin-top: 3px; }

/* Champs texte */
body.yel-landing .yel-frow { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 16px; }
body.yel-landing .yel-frow.is-1col { grid-template-columns: 1fr; }
body.yel-landing .yel-field { display: flex; flex-direction: column; gap: 6px; }
body.yel-landing .yel-field > span { font-size: 13.5px; font-weight: 700; color: var(--yel-contrast); }
body.yel-landing .yel-field input,
body.yel-landing .yel-field select,
body.yel-landing .yel-field textarea {
	border: 1.5px solid #d8e6dd; border-radius: 11px; padding: 12px 14px; font-size: 15px; color: var(--yel-contrast);
	background: #fff; width: 100%; transition: border-color .15s ease, box-shadow .15s ease;
}
body.yel-landing .yel-field input:focus,
body.yel-landing .yel-field select:focus,
body.yel-landing .yel-field textarea:focus { outline: none; border-color: var(--yel-primary); box-shadow: 0 0 0 3px var(--yel-accent-soft); }
body.yel-landing .yel-consent { display: flex; gap: 10px; align-items: flex-start; font-size: 13px; color: var(--yel-muted); margin-top: 8px; }
body.yel-landing .yel-consent input { margin-top: 3px; }

/* Nav boutons */
body.yel-landing .yel-funnel__nav { display: flex; justify-content: space-between; gap: 12px; margin-top: 28px; }
body.yel-landing .yel-funnel__nav .yel-cta--ghost { box-shadow: none; }
body.yel-landing .yel-funnel__nav button[data-yel-next],
body.yel-landing .yel-funnel__nav button[data-yel-submit] { margin-left: auto; }
body.yel-landing .yel-cta.is-loading { opacity: .7; pointer-events: none; }

/* Résultat / merci */
body.yel-landing .yel-funnel__result { text-align: center; padding: 12px 8px; }
body.yel-landing .yel-funnel__result h3 { font-size: 26px; color: var(--yel-primary-dark); font-weight: 800; margin: 0 0 8px; }
body.yel-landing .yel-funnel__result p { color: var(--yel-muted); }
body.yel-landing .yel-funnel__result .yel-savings { font-size: 40px; font-weight: 800; color: var(--yel-primary); margin: 12px 0; }
body.yel-landing .yel-funnel__error { background: #fef2f2; color: #b91c1c; border: 1px solid #fecaca; border-radius: 10px; padding: 12px 14px; font-size: 14px; margin-top: 12px; }

/* ======================================================================
   LP2 — WIZARD avec rail de réassurance (comparateur-energie.be)
   ====================================================================== */
body.yel-landing .yel-wizard-section { padding: clamp(40px, 6vw, 80px) 0; background: linear-gradient(180deg, var(--yel-surface), #fff); }
body.yel-landing .yel-wizard-grid { display: grid; grid-template-columns: 1.6fr 1fr; gap: 40px; align-items: start; }
body.yel-landing .yel-wizard-aside h2 { font-size: clamp(24px, 3vw, 34px); font-weight: 800; color: var(--yel-primary-dark); margin: 0 0 20px; line-height: 1.15; }
body.yel-landing .yel-checklist { list-style: none; padding: 0; margin: 0 0 28px; display: grid; gap: 14px; }
body.yel-landing .yel-checklist li { display: flex; gap: 12px; align-items: flex-start; font-size: 15.5px; color: var(--yel-contrast); font-weight: 600; }
body.yel-landing .yel-checklist li::before { content: "✓"; flex: none; width: 24px; height: 24px; border-radius: 50%; background: var(--yel-accent-soft); color: #0c662f; display: flex; align-items: center; justify-content: center; font-weight: 800; font-size: 13px; }
body.yel-landing .yel-partners-box { background: #fff; border: 1px solid #e6efe9; border-radius: var(--yel-radius); padding: 22px; box-shadow: var(--yel-shadow-sm); }
body.yel-landing .yel-partners-box p { font-weight: 700; color: var(--yel-primary-dark); margin: 0 0 14px; font-size: 15px; }
body.yel-landing .yel-partners-box__logos { display: flex; flex-wrap: wrap; gap: 10px; }
body.yel-landing .yel-partners-box__logos span { background: var(--yel-surface); border: 1px solid #e6efe9; border-radius: 8px; padding: 8px 12px; font-weight: 700; color: var(--yel-muted); font-size: 13px; }

/* ======================================================================
   LP3 — FORM EXPERT « un conseiller vous rappelle » (comparerfacile 962)
   ====================================================================== */
body.yel-landing .yel-exp-hero { background: linear-gradient(135deg, var(--yel-primary-dark), #0c5a2d); color: #fff; padding: clamp(40px, 6vw, 76px) 0; }
body.yel-landing .yel-exp-hero__grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: 44px; align-items: center; }
body.yel-landing .yel-exp-hero h1 { font-size: clamp(28px, 4vw, 46px); font-weight: 800; line-height: 1.1; letter-spacing: -0.02em; margin: 0 0 14px; color: #fff; }
body.yel-landing .yel-exp-hero__lead { font-size: 17px; color: #cfe9d8; margin: 0 0 22px; }
body.yel-landing .yel-exp-hero__chips { display: flex; flex-wrap: wrap; gap: 10px; }
body.yel-landing .yel-exp-hero__chips span { background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.18); border-radius: 999px; padding: 7px 14px; font-size: 13.5px; font-weight: 600; }
body.yel-landing .yel-exp-rating { display: inline-flex; align-items: center; gap: 8px; margin-top: 18px; font-size: 14px; color: #eafff1; }
body.yel-landing .yel-exp-rating strong { color: #fff; }
body.yel-landing .yel-live-badge { display: inline-flex; align-items: center; gap: 8px; font-size: 13px; color: var(--yel-muted); margin-top: 14px; justify-content: center; width: 100%; }
body.yel-landing .yel-live-badge .yel-dot { width: 9px; height: 9px; border-radius: 50%; background: var(--yel-accent); box-shadow: 0 0 0 0 rgba(63,208,113,.6); animation: yelPulse 1.8s infinite; }
@keyframes yelPulse { 0% { box-shadow: 0 0 0 0 rgba(63,208,113,.5);} 70% { box-shadow: 0 0 0 9px rgba(63,208,113,0);} 100% { box-shadow: 0 0 0 0 rgba(63,208,113,0);} }
body.yel-landing .yel-section { padding: clamp(48px, 7vw, 88px) 0; }
body.yel-landing .yel-section--surface { background: var(--yel-surface); }
body.yel-landing .yel-section__head { text-align: center; max-width: 720px; margin: 0 auto 40px; }
body.yel-landing .yel-section__eyebrow { font-size: 13px; font-weight: 700; color: var(--yel-primary); text-transform: uppercase; letter-spacing: .08em; }
body.yel-landing .yel-section h2 { font-size: clamp(26px, 3.4vw, 38px); font-weight: 800; color: var(--yel-primary-dark); margin: 8px 0 12px; letter-spacing: -0.02em; }
body.yel-landing .yel-section__head p { color: var(--yel-muted); font-size: 16px; }
body.yel-landing .yel-cards3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
body.yel-landing .yel-ecard { background: #fff; border: 1px solid #e6efe9; border-radius: var(--yel-radius); padding: 26px; box-shadow: var(--yel-shadow-sm); }
body.yel-landing .yel-ecard__icon { font-size: 30px; }
body.yel-landing .yel-ecard h3 { font-size: 20px; color: var(--yel-primary-dark); margin: 12px 0 8px; font-weight: 800; }
body.yel-landing .yel-ecard p { color: var(--yel-muted); font-size: 14.5px; margin: 0 0 14px; }
body.yel-landing .yel-ecard__save { display: inline-block; font-weight: 800; color: var(--yel-primary); background: var(--yel-accent-soft); padding: 5px 12px; border-radius: 999px; font-size: 13px; }
body.yel-landing .yel-statsrow { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; text-align: center; }
body.yel-landing .yel-statsrow div strong { display: block; font-size: 34px; font-weight: 800; color: var(--yel-primary); }
body.yel-landing .yel-statsrow div span { color: var(--yel-muted); font-size: 14px; }
body.yel-landing .yel-steps3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; counter-reset: yel; }
body.yel-landing .yel-step3 { position: relative; padding-top: 8px; }
body.yel-landing .yel-step3__n { width: 44px; height: 44px; border-radius: 50%; background: var(--yel-primary); color: #fff; display: flex; align-items: center; justify-content: center; font-weight: 800; font-size: 19px; margin-bottom: 14px; }
body.yel-landing .yel-step3 h3 { font-size: 18px; color: var(--yel-primary-dark); margin: 0 0 8px; font-weight: 800; }
body.yel-landing .yel-step3 p { color: var(--yel-muted); font-size: 14.5px; margin: 0; }
body.yel-landing .yel-reviews { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
body.yel-landing .yel-review { background: #fff; border: 1px solid #e6efe9; border-radius: var(--yel-radius); padding: 24px; box-shadow: var(--yel-shadow-sm); }
body.yel-landing .yel-review__tag { font-size: 12px; font-weight: 700; color: var(--yel-primary); background: var(--yel-accent-soft); border-radius: 6px; padding: 3px 9px; }
body.yel-landing .yel-review__q { font-style: italic; color: var(--yel-contrast); margin: 14px 0; font-size: 15px; line-height: 1.5; }
body.yel-landing .yel-review__who { display: flex; align-items: center; gap: 10px; }
body.yel-landing .yel-review__avatar { width: 38px; height: 38px; border-radius: 50%; background: var(--yel-primary); color: #fff; display: flex; align-items: center; justify-content: center; font-weight: 800; font-size: 13px; }
body.yel-landing .yel-review__name { font-weight: 700; color: var(--yel-contrast); font-size: 14px; }
body.yel-landing .yel-review__loc { color: var(--yel-muted); font-size: 12.5px; }
body.yel-landing .yel-review__save { margin-left: auto; font-weight: 800; color: var(--yel-primary); font-size: 14px; }
body.yel-landing .yel-market { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
body.yel-landing .yel-market__card { background: #fff; border: 1px solid #e6efe9; border-radius: var(--yel-radius); padding: 24px; box-shadow: var(--yel-shadow-sm); }
body.yel-landing .yel-market__card h3 { font-size: 19px; color: var(--yel-primary-dark); margin: 0 0 14px; font-weight: 800; }
body.yel-landing .yel-market__row { display: flex; justify-content: space-between; padding: 9px 0; border-top: 1px solid #eef4f0; font-size: 14px; }
body.yel-landing .yel-market__row span:first-child { color: var(--yel-muted); }
body.yel-landing .yel-market__row span:last-child { font-weight: 700; color: var(--yel-contrast); }

/* FAQ accordéon réutilisable */
body.yel-landing .yel-faq { max-width: 820px; margin: 0 auto; }
body.yel-landing .yel-faq details { background: #fff; border: 1px solid #e6efe9; border-radius: 12px; margin-bottom: 12px; box-shadow: var(--yel-shadow-sm); }
body.yel-landing .yel-faq summary { cursor: pointer; padding: 18px 22px; font-weight: 700; color: var(--yel-primary-dark); list-style: none; display: flex; justify-content: space-between; align-items: center; gap: 16px; font-size: 16px; }
body.yel-landing .yel-faq summary::-webkit-details-marker { display: none; }
body.yel-landing .yel-faq summary::after { content: "+"; font-size: 22px; color: var(--yel-primary); flex: none; }
body.yel-landing .yel-faq details[open] summary::after { content: "–"; }
body.yel-landing .yel-faq details > div { padding: 0 22px 20px; color: var(--yel-muted); font-size: 15px; line-height: 1.6; }

/* ======================================================================
   LP4 — CHAT CONVERSATIONNEL avec un conseiller (comparerfacile 810)
   ====================================================================== */
body.yel-landing .yel-chat-page { min-height: 100vh; background: linear-gradient(160deg, var(--yel-primary-dark) 0%, #0c4322 100%); }
body.yel-landing .yel-chat-header { padding: 14px 24px; border-bottom: 1px solid rgba(255,255,255,.08); display: flex; align-items: center; gap: 12px; }
body.yel-landing .yel-chat-header__id { display: flex; flex-direction: column; gap: 2px; }
body.yel-landing .yel-chat-header__title { color: #fff; font-weight: 800; font-size: 17px; }
body.yel-landing .yel-chat-header__status { display: inline-flex; align-items: center; gap: 7px; color: #bfe9cd; font-size: 12.5px; }
body.yel-landing .yel-chat-header__status .yel-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--yel-accent); box-shadow: 0 0 0 0 rgba(63,208,113,.6); animation: yelPulse 1.8s infinite; }
body.yel-landing .yel-chat-wrap { max-width: 620px; margin: 0 auto; padding: 28px 16px 120px; }
body.yel-landing .yel-chat-row { display: flex; gap: 12px; align-items: flex-end; margin-bottom: 14px; }
body.yel-landing .yel-chat-row.is-user { flex-direction: row-reverse; }
body.yel-landing .yel-chat-avatar { width: 46px; height: 46px; border-radius: 50%; flex: none; background: var(--yel-accent); color: #07331a; display: flex; align-items: center; justify-content: center; font-weight: 800; box-shadow: 0 4px 12px rgba(0,0,0,.2); overflow: hidden; }
body.yel-landing .yel-chat-bubble { background: #fff; border-radius: 18px; padding: 14px 18px; max-width: 78%; color: var(--yel-contrast); font-size: 15px; line-height: 1.5; box-shadow: 0 6px 18px rgba(0,0,0,.12); animation: yelFade .3s ease; }
body.yel-landing .yel-chat-bubble strong { color: var(--yel-primary-dark); }
body.yel-landing .yel-chat-row.is-user .yel-chat-bubble { background: var(--yel-primary); color: #fff; border-bottom-right-radius: 4px; }
body.yel-landing .yel-chat-bubble.is-meta { background: rgba(255,255,255,.14); color: #eafff1; font-size: 13.5px; font-style: italic; box-shadow: none; }
body.yel-landing .yel-chat-typing { display: inline-flex; gap: 4px; padding: 16px 18px; }
body.yel-landing .yel-chat-typing i { width: 8px; height: 8px; border-radius: 50%; background: #b3c4ba; animation: yelBlink 1.2s infinite both; }
body.yel-landing .yel-chat-typing i:nth-child(2) { animation-delay: .2s; }
body.yel-landing .yel-chat-typing i:nth-child(3) { animation-delay: .4s; }
@keyframes yelBlink { 0%, 80%, 100% { opacity: .3; } 40% { opacity: 1; } }
body.yel-landing .yel-chat-replies { display: flex; flex-wrap: wrap; gap: 10px; justify-content: flex-end; margin: 4px 0 18px; }
body.yel-landing .yel-chat-reply { background: #fff; border: 1.5px solid var(--yel-accent); color: var(--yel-primary-dark); border-radius: 999px; padding: 10px 18px; font-weight: 700; font-size: 14px; cursor: pointer; transition: background .15s ease, transform .15s ease; }
body.yel-landing .yel-chat-reply:hover { background: var(--yel-accent-soft); transform: translateY(-1px); }
body.yel-landing .yel-chat-inputrow { display: flex; gap: 10px; max-width: 620px; margin: 0 auto; }
body.yel-landing .yel-chat-inputbar { position: fixed; bottom: 0; left: 0; right: 0; background: rgba(7,40,20,.85); backdrop-filter: blur(8px); padding: 14px 16px; border-top: 1px solid rgba(255,255,255,.08); }
body.yel-landing .yel-chat-inputrow input { flex: 1; border: 0; border-radius: 999px; padding: 13px 18px; font-size: 15px; background: #fff; color: var(--yel-contrast); }
body.yel-landing .yel-chat-inputrow button { border: 0; border-radius: 999px; padding: 0 22px; background: var(--yel-accent); color: #07331a; font-weight: 800; cursor: pointer; }

/* ======================================================================
   LP5 — FUNNEL CARTES « conseillère » (moncomparateurdenergie bp2)
   ====================================================================== */
body.yel-landing .yel-bp-page { min-height: 100vh; background: var(--yel-surface); }
body.yel-landing .yel-bp-topbar { background: #fff; border-bottom: 1px solid #eef4f0; padding: 14px 0; }
body.yel-landing .yel-bp-topbar__inner { display: flex; align-items: center; justify-content: space-between; gap: 20px; }
body.yel-landing .yel-bp-stepper { display: flex; gap: 22px; }
body.yel-landing .yel-bp-stepper span { display: flex; align-items: center; gap: 8px; color: #b3c4ba; font-weight: 700; font-size: 14px; }
body.yel-landing .yel-bp-stepper span::before { content: attr(data-n); width: 26px; height: 26px; border-radius: 50%; background: #eef4f0; color: #9bb0a3; display: flex; align-items: center; justify-content: center; font-size: 13px; font-weight: 800; }
body.yel-landing .yel-bp-stepper span.is-active { color: var(--yel-primary-dark); }
body.yel-landing .yel-bp-stepper span.is-active::before { background: var(--yel-primary-dark); color: #fff; }
body.yel-landing .yel-bp-stepper span.is-done::before { content: "✓"; background: var(--yel-accent); color: #07331a; }
body.yel-landing .yel-bp-stage { max-width: 760px; margin: 0 auto; padding: clamp(28px, 5vw, 56px) 20px 80px; text-align: center; }
body.yel-landing .yel-bp-advisor { display: flex; align-items: center; gap: 16px; justify-content: center; margin-bottom: 26px; text-align: left; }
body.yel-landing .yel-bp-advisor__avatar { width: 72px; height: 72px; border-radius: 50%; border: 3px solid var(--yel-accent); background: var(--yel-surface); color: var(--yel-primary); display: flex; align-items: center; justify-content: center; font-weight: 800; font-size: 24px; flex: none; }
body.yel-landing .yel-bp-advisor__txt strong { display: block; color: var(--yel-primary-dark); font-size: 18px; }
body.yel-landing .yel-bp-advisor__txt span { color: var(--yel-muted); font-size: 14px; }
body.yel-landing .yel-bp-stage h2 { font-size: clamp(22px, 3.2vw, 32px); font-weight: 800; color: var(--yel-primary-dark); margin: 0 auto 28px; max-width: 560px; line-height: 1.2; }
body.yel-landing .yel-bp-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 16px; max-width: 640px; margin: 0 auto; }
body.yel-landing .yel-bp-card { position: relative; cursor: pointer; }
body.yel-landing .yel-bp-card input { position: absolute; opacity: 0; inset: 0; }
body.yel-landing .yel-bp-card__inner { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 4px; background: #fff; border: 2px solid #e1ece5; border-radius: var(--yel-radius); padding: 28px 18px; transition: all .15s ease; height: 100%; }
body.yel-landing .yel-bp-card:hover .yel-bp-card__inner { border-color: var(--yel-accent); transform: translateY(-3px); box-shadow: var(--yel-shadow-sm); }
body.yel-landing .yel-bp-card input:checked + .yel-bp-card__inner { border-color: var(--yel-primary); background: var(--yel-surface); box-shadow: 0 0 0 3px var(--yel-accent-soft); }
body.yel-landing .yel-bp-card__icon { display: block; font-size: 34px; }
body.yel-landing .yel-bp-card__title { display: block; font-weight: 800; color: var(--yel-primary-dark); font-size: 18px; margin: 8px 0 4px; }
body.yel-landing .yel-bp-card__desc { display: block; color: var(--yel-muted); font-size: 13.5px; }
body.yel-landing .yel-bp-nav { display: flex; justify-content: center; gap: 14px; margin-top: 34px; }
body.yel-landing .yel-bp-fields { max-width: 460px; margin: 0 auto; text-align: left; }

/* ======================================================================
   RESPONSIVE
   ====================================================================== */
@media (max-width: 980px) {
	body.yel-landing .yel-cmp-stats { grid-template-columns: repeat(2, 1fr); }
	body.yel-landing .yel-wizard-grid { grid-template-columns: 1fr; }
	body.yel-landing .yel-exp-hero__grid { grid-template-columns: 1fr; }
	body.yel-landing .yel-cards3,
	body.yel-landing .yel-steps3,
	body.yel-landing .yel-reviews { grid-template-columns: 1fr; }
	body.yel-landing .yel-statsrow { grid-template-columns: repeat(2, 1fr); }
	body.yel-landing .yel-market { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
	body.yel-landing .yel-cmp-stats { grid-template-columns: 1fr; }
	body.yel-landing .yel-frow { grid-template-columns: 1fr; }
	body.yel-landing .yel-tiles.is-2col { grid-template-columns: 1fr; }
	body.yel-landing .yel-cmp-tablewrap { overflow-x: auto; }
	body.yel-landing table.yel-cmp-table { min-width: 720px; }
	body.yel-landing .yel-bp-stepper span span { display: none; }
}
