	/* ═══════════════════════════
	 HERO
	═══════════════════════════ */
	.hero-wrap {
	background: var(--cream);
	padding-top: 68px;
	position: relative; overflow: hidden;
	}
	/* Subtle background texture */
	.hero-wrap::before {
	content: '';
	position: absolute; inset: 0;
	background:
	  radial-gradient(ellipse 60% 50% at 70% 40%, rgba(238,175,134,.13) 0%, transparent 70%),
	  radial-gradient(ellipse 40% 60% at 10% 80%, rgba(17,48,42,.04) 0%, transparent 70%);
	pointer-events: none;
	}

	.hero-inner {
	max-width: 1140px; margin: 0 auto;
	display: grid; grid-template-columns: 1fr 1fr;
	align-items: center; gap: 5rem;
	position: relative; z-index: 1;
	}
	.hero-wrap .hero-inner     { padding: 5rem 2rem 4rem; }
	.hero-wrap--dk .hero-inner { padding: 5rem 2rem 5rem; }

	.hero-badge {
	display: inline-flex; align-items: center; gap: .45rem;
	background: var(--peach-light); color: var(--forest);
	font-size: .72rem; font-weight: 600; letter-spacing: .04em;
	padding: .32rem .9rem; border-radius: 100px; margin-bottom: 1.5rem;
	animation: fadeUp .5s ease both;
	}
	.badge-dot { width: 5px; height: 5px; border-radius: 50%; background: var(--peach-dark); flex-shrink: 0; }

	.hero-inner h1 { margin-bottom: 1.1rem; animation: fadeUp .5s .08s ease both; }

	.hero-sub {
	max-width: 450px; margin-bottom: 1.6rem;
	animation: fadeUp .5s .16s ease both;
	}

	.hero-args {
	display: flex; flex-direction: column; gap: .5rem;
	margin-bottom: 2.2rem;
	animation: fadeUp .5s .22s ease both;
	}
	.hero-arg { display: flex; align-items: center; gap: .55rem; font-size: .845rem; font-weight: 500; }
	.hero-arg svg { font-size: .95rem; color: var(--forest-soft); }

	.hero-ctas { display: flex; gap: .9rem; align-items: center; flex-wrap: wrap; animation: fadeUp .5s .28s ease both; }

	/* Trust micro sous les CTAs */
	.hero-trust {
	display: flex; gap: 1.5rem; margin-top: 1.6rem; flex-wrap: wrap;
	animation: fadeUp .5s .34s ease both;
	}
	.hero-trust span {
	display: flex; align-items: center; gap: .35rem;
	font-size: .78rem; color: var(--muted);
	}
	.hero-trust span svg { font-size: .9rem; color: var(--forest-soft); }

	/* ── Phone mockup ── */
	.hero-visual { position: relative; display: flex; justify-content: center; animation: fadeUp .7s .1s ease both; }

	.phone-wrap { width: 255px; position: relative; z-index: 2; animation: float 5s ease-in-out infinite; }
	.phone-frame {
	background: white; border-radius: 42px; padding: 10px;
	box-shadow: var(--sh-lg), 0 0 0 1px rgba(17,48,42,.05);
	}
	.phone-screen {
	border-radius: 35px; overflow: hidden; aspect-ratio: 9/19.5;
	background: var(--peach-pale); display: flex; flex-direction: column;
	}
	.p-topbar {
	background: white; padding: .65rem 1rem .6rem;
	display: flex; align-items: center; justify-content: space-between;
	border-bottom: 1px solid rgba(17,48,42,.06);
	}
	.p-topbar-logo { font-size: .78rem; font-weight: 700; color: var(--forest); }
	.p-topbar-btn {
	width: 26px; height: 26px; border-radius: 8px;
	border: 1.5px solid rgba(220,80,50,.3); display: grid; place-items: center;
	}
	.p-topbar-btn svg { font-size: .75rem; color: #DC5032; }

	.p-body { flex: 1; display: flex; flex-direction: column; align-items: center; padding: .9rem .75rem; gap: .4rem; }
	.p-hello { font-size: .7rem; font-weight: 600; color: var(--forest); margin-bottom: .5rem; }

	.p-card {
	background: white; border-radius: 18px; padding: 1rem; width: 100%;
	box-shadow: 0 4px 14px rgba(17,48,42,.07);
	display: flex; flex-direction: column; align-items: center; gap: .55rem;
	}
	.p-card-label { font-size: .67rem; font-weight: 700; color: var(--peach-dark); align-self: flex-start; }
	.p-card-sub { font-size: .54rem; color: var(--muted); }
	.p-card-sub strong { color: var(--forest); font-weight: 600; }

	.p-qr {
	width: 96px; height: 96px; border-radius: 10px;
	background: var(--forest); display: grid; place-items: center;
	}
	.p-add-wallet {
	background: black; border-radius: 8px; padding: .32rem .65rem;
	display: flex; align-items: center; gap: .35rem;
	}
	.p-add-wallet span { font-size: .47rem; color: white; line-height: 1.3; }
	.p-add-wallet span b { display: block; font-size: .56rem; }
	.w-colors { display: flex; gap: 1px; }
	.w-colors s { width: 7px; height: 4px; border-radius: 1px; text-decoration: none; }
	.p-fidcode {
	background: var(--peach-light); border-radius: 10px;
	padding: .45rem 1.1rem; font-size: .95rem; font-weight: 700;
	color: var(--forest); letter-spacing: .06em;
	}

	.p-bottombar {
	background: var(--forest); padding: .65rem 1rem;
	display: flex; justify-content: space-around;
	}
	.p-tab { display: flex; flex-direction: column; align-items: center; gap: .12rem; }
	.p-tab svg { font-size: .88rem; }
	.p-tab span { font-size: .44rem; }

	/* Floating badges */
	.fb {
	position: absolute; background: white; border-radius: 14px;
	padding: .75rem 1rem; box-shadow: var(--sh-md); z-index: 3; white-space: nowrap;
	}
	.fb .row { display: flex; align-items: center; gap: .6rem; }
	.fb-icon {
	width: 32px; height: 32px; border-radius: 9px;
	display: grid; place-items: center; flex-shrink: 0;
	}
	.fb-icon.g { background: #E8F5E9; }
	.fb-icon.o { background: var(--peach-pale); }
	.fb strong { display: block; font-size: .83rem; color: var(--forest); font-weight: 600; }
	.fb small { font-size: .67rem; color: var(--muted); }
	.fb-1 { top: 12%; left: -88px; animation: fb1 5s ease-in-out infinite; }
	.fb-2 { bottom: 20%; right: -82px; animation: fb2 5s ease-in-out 2s infinite; }

	/* ── Platform (dark) ── */
	.hero-wrap--dk {
	background: var(--forest);
	}
	.hero-wrap--dk::before {
	content: '';
	position: absolute; inset: 0;
	background:
	  radial-gradient(ellipse 55% 70% at 85% 50%, rgba(238,175,134,.1) 0%, transparent 65%),
	  radial-gradient(ellipse 40% 50% at 5% 80%, rgba(238,175,134,.05) 0%, transparent 60%);
	pointer-events: none;
	}
	.hero-wrap--dk .hero-badge {
	background: rgba(238,175,134,.18);
	color: var(--peach-light);
	border: 1px solid rgba(238,175,134,.25);
	margin-bottom: 1.4rem;
	}
	.hero-wrap--dk .badge-dot { background: var(--peach); }
	.hero-wrap--dk h1 { color: var(--cream); }
	.hero-wrap--dk h1 em { color: var(--peach); }
	.hero-wrap--dk .lead { color: rgba(251,246,240,.52); max-width: 460px; }
	.hero-wrap--dk .hero-ctas { margin-top: 2rem; animation: none; }

	/* Quick nav anchors */
	.hero-anchors {
	display: flex; flex-wrap: wrap; gap: .5rem; margin-top: 2.5rem;
	}
	.anchor-pill {
	display: inline-flex; align-items: center; gap: .4rem;
	background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.12);
	border-radius: 100px; padding: .38rem .85rem;
	font-size: .75rem; font-weight: 500; color: rgba(251,246,240,.6);
	text-decoration: none; transition: all .2s;
	}
	.anchor-pill:hover { background: rgba(255,255,255,.13); color: var(--cream); }
	.anchor-pill svg { font-size: .85rem; }

	/* Hero right: feature card stack */
	.hero-feat-stack {
	display: flex; flex-direction: column; gap: .9rem;
	}
	.hfs-card {
	background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.1);
	border-radius: var(--r-md); padding: 1.2rem 1.4rem;
	display: flex; align-items: center; gap: 1rem;
	transition: background .2s;
	}
	.hfs-card:hover { background: rgba(255,255,255,.11); }
	.hfs-icon {
	width: 42px; height: 42px; border-radius: 11px;
	background: rgba(238,175,134,.15); display: grid; place-items: center; flex-shrink: 0;
	}
	.hfs-icon svg { font-size: 1.2rem; color: var(--peach); }
	.hfs-text strong { display: block; font-size: .875rem; color: var(--cream); font-weight: 600; margin-bottom: .15rem; }
	.hfs-text span { font-size: .78rem; color: rgba(251,246,240,.42); }
	.hfs-arrow { margin-left: auto; flex-shrink: 0; }
	.hfs-arrow svg { font-size: 1rem; color: rgba(255,255,255,.2); }

	/* ═══════════════════════════
	 PROBLÈME
	═══════════════════════════ */
	.section-problem { background: var(--forest); }

	.problem-header { text-align: center; margin-bottom: 3rem; }
	.problem-header .label { color: var(--peach); }
	.problem-header .h2 { color: var(--cream); }
	.problem-header em { color: var(--peach); }

	.problem-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.1rem; }
	.pb-card {
	background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.08);
	border-radius: var(--r-md); padding: 1.8rem;
	transition: background .2s, transform .2s;
	}
	.pb-card:hover { background: rgba(255,255,255,.08); transform: translateY(-3px); }
	.pb-card svg { font-size: 1.5rem; color: var(--peach); margin-bottom: .9rem; display: block; }
	.pb-card h3 { font-size: .95rem; color: var(--cream); margin-bottom: .4rem; }
	.pb-card p { font-size: .845rem; color: rgba(251,246,240,.48); line-height: 1.65; }

/* ═══════════════════════════
	 SOCIAL PROOF
═══════════════════════════ */
.section-proof { background: var(--bg); }

.proof-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.2rem; margin-top: 3rem; }
.proof-card {
	background: var(--cream); border: 1.5px solid var(--border);
	border-radius: var(--r-md); padding: 2rem; text-align: center;
	transition: transform .2s, box-shadow .2s;
}
.proof-card:hover { transform: translateY(-3px); box-shadow: var(--sh-md); }
.proof-icon {
	width: 54px; height: 54px; border-radius: 14px;
	background: var(--peach-pale); display: grid; place-items: center;
	margin: 0 auto .9rem;
}
.proof-icon svg { font-size: 1.5rem; color: var(--peach-dark); }
.proof-card h3 { margin-bottom: .4rem; }
.proof-card p { font-size: .85rem; color: var(--muted); line-height: 1.65; }

	/* ═══════════════════════════
	 BÉNÉFICES
	═══════════════════════════ */
	.section-benefits { background: var(--bg); }

	.benefits-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 1rem; margin-top: 3rem; }
	.bn-card {
	display: flex; gap: .9rem; align-items: flex-start;
	background: var(--cream); border: 1.5px solid var(--border);
	border-radius: var(--r-sm); padding: 1.5rem;
	transition: transform .2s, box-shadow .2s;
	}
	.bn-card:hover { transform: translateY(-2px); box-shadow: var(--sh-sm); }
	.bn-icon {
	width: 42px; height: 42px; border-radius: 11px;
	background: var(--peach-pale); display: grid; place-items: center; flex-shrink: 0;
	}
	.bn-icon svg { font-size: 1.1rem; color: var(--peach-dark); }
	.bn-card h3 { margin-bottom: .25rem; }
	.bn-card p { font-size: .835rem; color: var(--muted); line-height: 1.58; }

/* ═══════════════════════════
	 CIBLES COMMERCES
═══════════════════════════ */
.section-cibles { background: var(--cream); }

.cibles-intro { max-width: 560px; }
.cibles-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; margin-top: 3rem; }
.cibles-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: .8rem; }
.cible-card {
	background: var(--bg); border: 1.5px solid var(--border);
	border-radius: var(--r-sm); padding: 1.3rem 1rem;
	text-align: center; transition: all .2s; cursor: default;
}
.cible-card:hover { border-color: var(--peach); transform: translateY(-2px); box-shadow: var(--sh-sm); background: var(--peach-pale); }
.cible-card svg { font-size: 1.7rem; color: var(--forest-soft); display: block; margin: 0 auto .5rem; transition: color .2s; }
.cible-card:hover svg { color: var(--peach-dark); }
.cible-card span { font-size: .8rem; font-weight: 500; color: var(--forest); }

.cibles-text-block { display: flex; flex-direction: column; gap: 1.2rem; }
.cibles-text-item { display: flex; gap: .8rem; align-items: flex-start; }
.cibles-text-icon {
	width: 36px; height: 36px; border-radius: 9px;
	background: var(--peach-pale); display: grid; place-items: center; flex-shrink: 0;
}
.cibles-text-icon svg { font-size: 1rem; color: var(--peach-dark); }
.cibles-text-item strong { display: block; font-size: .875rem; font-weight: 600; margin-bottom: .15rem; }
.cibles-text-item p { font-size: .82rem; color: var(--muted); line-height: 1.55; }

	/* ═══════════════════════════
	 MODULES (3 piliers)
	═══════════════════════════ */
	.section-modules { background: var(--cream); }

	.modules-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.2rem; margin-top: 3rem; }
	.mod-card {
	background: var(--cream); border: 1.5px solid var(--border);
	border-radius: var(--r-lg); padding: 2.2rem;
	transition: transform .2s, box-shadow .2s, border-color .2s;
	position: relative; overflow: hidden;
	}
	.mod-card::after {
	content: ''; position: absolute; bottom: 0; left: 0; right: 0;
	height: 3px; background: var(--peach); opacity: 0; transition: opacity .25s;
	}
	.mod-card:hover { transform: translateY(-4px); box-shadow: var(--sh-md); border-color: var(--peach-light); }
	.mod-card:hover::after { opacity: 1; }
	.mod-num { font-size: .68rem; font-weight: 700; text-transform: uppercase; letter-spacing: .12em; color: var(--peach-dark); margin-bottom: .5rem; }
	.mod-icon {
	width: 50px; height: 50px; border-radius: 14px;
	background: var(--forest); display: grid; place-items: center; margin-bottom: 1.2rem;
	}
	.mod-icon svg { font-size: 1.4rem; color: var(--peach); }
	.mod-card h3 { font-size: 1.05rem; margin-bottom: .55rem; }
	.mod-card p { font-size: .845rem; color: var(--muted); line-height: 1.65; }
	.mod-tags { display: flex; flex-wrap: wrap; gap: .4rem; margin-top: 1.1rem; }
	.mod-tag {
	background: var(--peach-pale); color: var(--peach-dark);
	border-radius: 100px; padding: .22rem .65rem;
	font-size: .7rem; font-weight: 500;
	}

	/* ═══════════════════════════
	 TABS INTERACTIFS
═══════════════════════════ */
.section-tabs { background: var(--bg); }

.tabs-layout {
	display: grid; grid-template-columns: 260px 1fr; gap: 2.5rem;
	margin-top: 3rem; align-items: start;
}

/* Vertical tab nav */
.tabs-nav-v {
	display: flex; flex-direction: column; gap: .4rem;
	position: sticky; top: 88px;
}
.tab-btn-v {
	display: flex; align-items: center; gap: .75rem;
	padding: .85rem 1.1rem; border-radius: var(--r-sm); border: none;
	background: none; cursor: pointer; font-family: 'Inter', sans-serif;
	font-size: .875rem; font-weight: 500; color: var(--muted);
	text-align: left; transition: all .2s; width: 100%;
}
.tab-btn-v svg { font-size: 1.1rem; flex-shrink: 0; }
.tab-btn-v:hover { background: rgba(17,48,42,.05); color: var(--forest); }
.tab-btn-v.active {
	background: var(--forest); color: var(--cream);
	box-shadow: var(--sh-sm);
}
.tab-btn-v .tab-arrow { margin-left: auto; font-size: .85rem; opacity: 0; transition: opacity .2s; }
.tab-btn-v.active .tab-arrow { opacity: 1; }

/* Tab panels */
.tabs-content-v { min-height: 500px; }
.tab-panel-v { display: none; animation: fadeTab .3s ease; }
.tab-panel-v.active { display: block; }
@keyframes fadeTab { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }

/* Panel layout: top description + bottom visual */
.panel-header { margin-bottom: 2rem; }
.panel-header h2 { margin-bottom: .8rem; }
.panel-header .lead { max-width: 560px; }
.panel-points { display: flex; flex-direction: column; gap: .55rem; margin-top: 1.2rem; }
.panel-point { display: flex; gap: .55rem; align-items: flex-start; font-size: .865rem; }
.panel-point svg { color: var(--forest-soft); font-size: 1rem; flex-shrink: 0; margin-top: 1px; }

/* Visual panels */
.panel-visual {
	background: var(--cream); border: 1.5px solid var(--border);
	border-radius: var(--r-lg); padding: 2rem; margin-top: 2rem;
}
.parrainage-stats {
	display: grid; grid-template-columns: repeat(3, minmax(0, 1fr));
}
.parrainage-stat-icon {
	display: block; margin: 0 auto .3rem;
}
.parrainage-stat-label { font-size: .6rem; }
.panel-visual-label {
	font-size: .68rem; font-weight: 700; text-transform: uppercase;
	letter-spacing: .12em; color: var(--muted); margin-bottom: 1.2rem;
}

/* ── Carte panel visuals ── */
.fid-card-demo {
	background: linear-gradient(135deg, var(--peach) 0%, var(--peach-dark) 100%);
	border-radius: 18px; padding: 1.6rem;
	position: relative; overflow: hidden;
	box-shadow: 0 8px 28px rgba(212,132,90,.28);
	margin-bottom: 1.2rem;
}
.fid-card-demo::before {
	content: ''; position: absolute; top: -40px; right: -40px;
	width: 130px; height: 130px; border-radius: 50%; background: rgba(255,255,255,.1);
}
.fid-card-demo::after {
	content: ''; position: absolute; bottom: -20px; left: 60px;
	width: 80px; height: 80px; border-radius: 50%; background: rgba(255,255,255,.06);
}
.fcd-top { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 1.2rem; }
.fcd-logo { font-size: .82rem; font-weight: 700; color: rgba(17,48,42,.65); }
.fcd-type { font-size: .62rem; font-weight: 600; text-transform: uppercase; letter-spacing: .08em; background: rgba(17,48,42,.12); color: var(--forest); padding: .2rem .6rem; border-radius: 100px; }
.fcd-code { font-size: 1.8rem; font-weight: 700; color: var(--forest); letter-spacing: .08em; margin-bottom: .3rem; }
.fcd-name { font-size: .62rem; text-transform: uppercase; letter-spacing: .1em; color: rgba(17,48,42,.5); }
.fcd-progress { margin-top: 1rem; }
.fcd-progress-label { display: flex; justify-content: space-between; font-size: .65rem; color: rgba(17,48,42,.55); margin-bottom: .4rem; }
.fcd-progress-bar { background: rgba(17,48,42,.15); border-radius: 100px; height: 5px; }
.fcd-progress-fill { height: 100%; border-radius: 100px; background: var(--forest); }

.wallet-row { display: flex; gap: .7rem; margin-bottom: 1.2rem; }
.wallet-btn {
	flex: 1; border-radius: 10px; padding: .7rem 1rem;
	display: flex; align-items: center; gap: .55rem; font-size: .78rem; font-weight: 500;
}
.wallet-btn-apple { background: black; color: white; }
.wallet-btn-apple svg { font-size: .95rem; }
.wallet-btn-google { background: #4285F4; color: white; }
.wallet-btn-google svg { font-size: .95rem; }

.auth-methods { display: flex; flex-wrap: wrap; gap: .5rem; }
.auth-pill {
	display: inline-flex; align-items: center; gap: .4rem;
	background: var(--bg); border: 1.5px solid var(--border);
	border-radius: 100px; padding: .35rem .8rem;
	font-size: .75rem; font-weight: 500; color: var(--forest);
}
.auth-pill svg { font-size: .9rem; color: var(--forest-soft); }

/* ── Coupons panel visuals ── */
.coupon-list { display: flex; flex-direction: column; gap: .8rem; }
.coupon-row {
	background: white; border-radius: 14px; padding: 1rem 1.2rem;
	display: flex; align-items: center; gap: 1rem;
	border: 1.5px solid var(--border);
	transition: box-shadow .2s;
}
.coupon-row:hover { box-shadow: var(--sh-sm); }
.coupon-icon-wrap {
	width: 46px; height: 46px; border-radius: 12px;
	display: grid; place-items: center; flex-shrink: 0;
}
.coupon-icon-wrap.forest { background: var(--forest); }
.coupon-icon-wrap.peach { background: var(--peach-light); }
.coupon-icon-wrap.muted { background: var(--bg); }
.coupon-icon-wrap svg { font-size: 1.2rem; }
.coupon-icon-wrap.forest svg { color: var(--peach); }
.coupon-icon-wrap.peach svg { color: var(--peach-dark); }
.coupon-icon-wrap.muted svg { color: var(--muted); }
.coupon-body { flex: 1; }
.coupon-body strong { display: block; font-size: .875rem; color: var(--forest); font-weight: 600; margin-bottom: .1rem; }
.coupon-body small { font-size: .74rem; color: var(--muted); }
.coupon-chip {
	font-size: .7rem; font-weight: 600; padding: .24rem .65rem; border-radius: 100px;
}
.chip-avail { background: var(--peach-pale); color: var(--peach-dark); }
.chip-new { background: #E8F5E9; color: #2E7D32; }
.chip-used { background: var(--bg); color: var(--muted); }

/* ── Parrainage panel visuals ── */
.ref-tree { display: flex; flex-direction: column; gap: .7rem; }
.ref-row {
	background: white; border-radius: 12px; padding: .9rem 1.1rem;
	display: flex; align-items: center; gap: .8rem; border: 1.5px solid var(--border);
}
.ref-row.indent { margin-left: 2rem; border-left: 3px solid var(--peach-light); }
.ref-avatar {
	width: 36px; height: 36px; border-radius: 50%;
	display: grid; place-items: center; font-size: .74rem; font-weight: 700; flex-shrink: 0;
}
.ref-avatar.peach { background: var(--peach); color: var(--forest); }
.ref-avatar.forest { background: var(--forest); color: var(--cream); }
.ref-info strong { display: block; font-size: .83rem; color: var(--forest); font-weight: 600; }
.ref-info small { font-size: .73rem; color: var(--muted); }
.ref-badge-ok { display: flex; align-items: center; gap: .3rem; margin-left: auto; }
.ref-badge-ok svg { font-size: .9rem; color: #2E7D32; }
.ref-badge-ok span { font-size: .73rem; color: #2E7D32; font-weight: 500; }
.ref-badge-pending { display: flex; align-items: center; gap: .3rem; margin-left: auto; }
.ref-badge-pending svg { font-size: .9rem; color: var(--muted); }
.ref-badge-pending span { font-size: .73rem; color: var(--muted); }

.ref-stats-row { display: grid; grid-template-columns: repeat(3,1fr); gap: .7rem; margin-top: .7rem; }
.ref-stat {
	background: var(--forest); border-radius: 12px; padding: 1rem;
	text-align: center;
}
.ref-stat strong { display: block; font-size: 1.4rem; font-weight: 700; color: var(--cream); line-height: 1; margin-bottom: .2rem; }
.ref-stat span { font-size: .7rem; color: rgba(251,246,240,.45); }

/* ── Stats panel visuals ── */
.stats-grid { display: grid; grid-template-columns: 1fr 1fr; gap: .8rem; }
.stat-card {
	background: white; border-radius: 14px; padding: 1.2rem;
	border: 1.5px solid var(--border);
}
.stat-card-label { font-size: .7rem; font-weight: 600; text-transform: uppercase; letter-spacing: .1em; color: var(--muted); margin-bottom: .5rem; }
.stat-card-value { font-size: 1.8rem; font-weight: 700; color: var(--forest); line-height: 1; margin-bottom: .4rem; }
.stat-card-sub { font-size: .73rem; color: var(--muted); display: flex; align-items: center; gap: .3rem; }
.stat-card-sub svg { font-size: .85rem; }
.stat-card-sub.up { color: #2E7D32; }
.stat-card-sub.up svg { color: #2E7D32; }
.stat-bar-wrap { margin-top: .7rem; }
.stat-bar-bg { background: var(--bg); border-radius: 100px; height: 5px; }
.stat-bar-fill { height: 100%; border-radius: 100px; background: var(--peach); }

.stat-activity { background: white; border-radius: 14px; padding: 1.2rem; border: 1.5px solid var(--border); margin-top: .8rem; }
.stat-activity-label { font-size: .7rem; font-weight: 600; text-transform: uppercase; letter-spacing: .1em; color: var(--muted); margin-bottom: .8rem; }
.stat-bars { display: flex; align-items: flex-end; gap: .35rem; height: 60px; }
.stat-bar-col { flex: 1; border-radius: 4px 4px 0 0; background: var(--peach-light); transition: background .2s; min-width: 0; }
.stat-bar-col:hover { background: var(--peach); }
.stat-bars-labels { display: flex; gap: .35rem; margin-top: .3rem; }
.stat-bars-labels span { flex: 1; text-align: center; font-size: .6rem; color: var(--muted); min-width: 0; }

	/* ═══════════════════════════
	 COMMENT ÇA MARCHE
	═══════════════════════════ */
	.section-how { background: var(--bg); }

	.steps-wrap { position: relative; display: grid; grid-template-columns: repeat(4,1fr); gap: 1.5rem; margin-top: 3.5rem; }
	.steps-wrap::before {
	content: ''; position: absolute;
	top: 25px; left: calc(12.5% + 26px); right: calc(12.5% + 26px);
	height: 1px;
	background: linear-gradient(90deg, var(--peach-light), var(--peach), var(--peach-light));
	z-index: 0;
	}
	.step { text-align: center; position: relative; z-index: 1; }
	.step-num {
	width: 52px; height: 52px; border-radius: 50%;
	background: var(--forest); color: var(--cream);
	font-size: 1.05rem; font-weight: 700;
	display: grid; place-items: center;
	margin: 0 auto 1.1rem;
	box-shadow: 0 4px 16px rgba(17,48,42,.22);
	}
	.step h3 { font-size: .875rem; margin-bottom: .4rem; }
	.step p { font-size: .8rem; color: var(--muted); line-height: 1.55; }

/* ═══════════════════════════
	 EXTRAS (notifs, MEA)
═══════════════════════════ */
.section-extras { background: var(--cream); }

.extras-bento {
	display: grid;
	grid-template-columns: 1fr 1fr;
	grid-template-rows: auto auto;
	gap: 1.2rem;
	margin-top: 3rem;
}

/* Notifs card — full width */
.extra-card {
	background: var(--bg); border: 1.5px solid var(--border);
	border-radius: var(--r-lg); padding: 2.2rem; overflow: hidden;
	position: relative; transition: box-shadow .2s;
}
.extra-card:hover { box-shadow: var(--sh-md); }
.extra-card.full { grid-column: span 2; }
.extra-card.forest { background: var(--forest); border-color: var(--forest); }
.extra-card.peach-bg { background: var(--peach-pale); border-color: var(--peach-light); }

.extra-icon {
	width: 48px; height: 48px; border-radius: 13px;
	display: grid; place-items: center; margin-bottom: 1.2rem;
}
.extra-icon.light { background: var(--cream); }
.extra-icon.dark { background: rgba(255,255,255,.1); }
.extra-icon.peach { background: var(--peach-light); }
.extra-icon svg { font-size: 1.35rem; color: var(--forest); }
.extra-icon.dark svg { color: var(--peach); }
.extra-icon.peach svg { color: var(--peach-dark); }

.extra-card h3 { font-size: 1.05rem; margin-bottom: .55rem; }
.extra-card.forest h3 { color: var(--cream); }
.extra-card p { font-size: .855rem; color: var(--muted); line-height: 1.65; }
.extra-card.forest p { color: rgba(251,246,240,.5); }

/* Notifs email preview */
.email-preview {
	margin-top: 1.5rem;
	background: white; border-radius: 14px; border: 1.5px solid var(--border);
	overflow: hidden;
}
.email-preview-header {
	background: var(--forest); padding: .7rem 1rem;
	display: flex; align-items: center; gap: .6rem;
}
.email-preview-header svg { color: var(--peach); font-size: 1rem; }
.email-preview-header span { font-size: .75rem; color: rgba(251,246,240,.65); }
.email-preview-body { padding: 1rem; }
.email-row { display: flex; justify-content: space-between; padding: .35rem 0; border-bottom: 1px solid var(--bg); }
.email-row:last-child { border: none; }
.email-row span { font-size: .75rem; color: var(--muted); }
.email-row strong { font-size: .75rem; color: var(--forest); font-weight: 600; }
.email-cta-row { margin-top: .8rem; display: flex; gap: .5rem; flex-wrap: wrap; }
.email-tag {
	display: inline-flex; align-items: center; gap: .35rem;
	background: var(--peach-pale); border-radius: 100px; padding: .28rem .7rem;
	font-size: .72rem; color: var(--peach-dark); font-weight: 500;
}
.email-tag svg { font-size: .8rem; }

/* MEA (mise en avant) preview */
.mea-preview {
	margin-top: 1.5rem; display: flex; flex-direction: column; gap: .7rem;
}
.mea-item {
	background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.1);
	border-radius: 11px; padding: .8rem 1rem;
	display: flex; align-items: center; gap: .7rem;
}
.mea-item svg { font-size: 1.1rem; color: var(--peach); flex-shrink: 0; }
.mea-item strong { display: block; font-size: .8rem; color: var(--cream); font-weight: 600; margin-bottom: .1rem; }
.mea-item span { font-size: .73rem; color: rgba(251,246,240,.42); }
.mea-toggle {
	width: 32px; height: 18px; border-radius: 100px;
	background: var(--peach); flex-shrink: 0; margin-left: auto;
	position: relative;
}
.mea-toggle::after {
	content: ''; position: absolute; top: 3px; right: 3px;
	width: 12px; height: 12px; border-radius: 50%; background: white;
}

/* Auth methods */
.auth-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: .6rem; margin-top: 1.3rem; }
.auth-item {
	background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.1);
	border-radius: 10px; padding: .8rem; text-align: center;
}
.auth-item svg { font-size: 1.3rem; color: var(--peach); display: block; margin: 0 auto .35rem; }
.auth-item span { font-size: .72rem; color: rgba(251,246,240,.55); }

	/* ═══════════════════════════
	 TÉMOIGNAGES
	═══════════════════════════ */
	.section-testi { background: var(--cream); }

	.testi-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.2rem; margin-top: 3rem; }
	.testi-card {
	background: var(--cream); border: 1.5px solid var(--border);
	border-radius: var(--r-md); padding: 1.8rem; position: relative;
	transition: transform .2s, box-shadow .2s;
	}
	.testi-card:hover { transform: translateY(-3px); box-shadow: var(--sh-md); }
	.testi-q {
	position: absolute; top: 1rem; right: 1.4rem;
	font-size: 3.8rem; line-height: 1; color: var(--peach-light);
	font-family: Georgia, serif; pointer-events: none;
	}
	.testi-stars { display: flex; gap: .15rem; margin-bottom: .9rem; }
	.testi-stars svg { font-size: .82rem; color: var(--peach); }
	.testi-card blockquote { font-size: .875rem; line-height: 1.72; color: var(--forest); margin-bottom: 1.4rem; }
	.testi-author { display: flex; align-items: center; gap: .75rem; }
	.testi-av {
	width: 38px; height: 38px; border-radius: 50%; background: var(--peach);
	display: grid; place-items: center; font-size: .75rem; font-weight: 700;
	color: var(--forest); flex-shrink: 0;
	}
	.testi-name { font-size: .845rem; font-weight: 600; }
	.testi-role { font-size: .73rem; color: var(--muted); }

	/* ═══════════════════════════
	 WALLET SECTION
═══════════════════════════ */
.section-wallet { background: var(--bg); }

.wallet-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: center; }

.wallet-text .h2 { margin-bottom: 1rem; }
.wallet-args { margin-top: 1.8rem; display: flex; flex-direction: column; gap: 1rem; }
.wallet-arg { display: flex; gap: .85rem; align-items: flex-start; }
.w-arg-icon {
	width: 40px; height: 40px; border-radius: 10px;
	background: var(--forest); display: grid; place-items: center; flex-shrink: 0;
}
.w-arg-icon svg { font-size: 1.1rem; color: var(--peach); }
.w-arg-text strong { display: block; font-size: .875rem; font-weight: 600; margin-bottom: .18rem; }
.w-arg-text span { font-size: .82rem; color: var(--muted); line-height: 1.5; }

.wallet-pills { display: flex; gap: .6rem; margin-top: 2rem; flex-wrap: wrap; }
.wpill {
	display: inline-flex; align-items: center; gap: .45rem;
	padding: .5rem 1rem; border-radius: 100px;
	font-size: .78rem; font-weight: 500;
}
.wpill-apple { background: #000; color: var(--cream); }
.wpill-google { background: #4285F4; color: white; }

/* Wallet visual card */
.wallet-visual-wrap { display: flex; flex-direction: column; gap: 1rem; }
.wallet-card-demo {
	background: linear-gradient(135deg, var(--peach) 0%, var(--peach-dark) 100%);
	border-radius: 20px; padding: 1.6rem;
	box-shadow: 0 12px 40px rgba(212,132,90,.3);
	position: relative; overflow: hidden;
}
.wallet-card-demo::before {
	content: ''; position: absolute; top: -50px; right: -50px;
	width: 150px; height: 150px; border-radius: 50%; background: rgba(255,255,255,.1);
}
.wcd-top { display: flex; justify-content: space-between; align-items: center; margin-bottom: 1.2rem; }
.wcd-logo { font-size: .85rem; font-weight: 700; color: rgba(17,48,42,.65); }
.wcd-badge {
	background: rgba(17,48,42,.12); color: var(--forest);
	font-size: .6rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em;
	padding: .22rem .6rem; border-radius: 100px;
}
.wcd-code { font-size: 1.9rem; font-weight: 700; color: var(--forest); letter-spacing: .08em; margin-bottom: .3rem; }
.wcd-name { font-size: .62rem; text-transform: uppercase; letter-spacing: .1em; color: rgba(17,48,42,.5); }

.wallet-feature-list { display: flex; flex-direction: column; gap: .6rem; }
.wallet-feat-row {
	background: white; border-radius: 12px; padding: .85rem 1.1rem;
	display: flex; align-items: center; gap: .7rem;
	border: 1.5px solid var(--border);
}
.wallet-feat-row svg { font-size: 1rem; color: var(--forest-soft); flex-shrink: 0; }
.wallet-feat-row span { font-size: .835rem; color: var(--forest); }

	/* ═══════════════════════════
	 PRICING
	═══════════════════════════ */
	.section-pricing { background: var(--bg); }

	.pricing-header { text-align: center; margin-bottom: 2rem; }

	/* Toggle */
	.billing-toggle { display: flex; align-items: center; justify-content: center; gap: 1rem; margin-bottom: 2.5rem; }
	.bl-label { font-size: .855rem; font-weight: 500; color: var(--muted); cursor: pointer; transition: color .2s; }
	.bl-label.on { color: var(--forest); }
	.tgl-track {
	width: 48px; height: 26px; border-radius: 100px;
	background: var(--forest); border: none; cursor: pointer; position: relative;
	}
	.tgl-knob {
	position: absolute; top: 3px; left: 3px;
	width: 20px; height: 20px; border-radius: 50%;
	background: white; transition: transform .25s;
	}
	.tgl-knob.right { transform: translateX(22px); }
	.annual-chip { background: #E8F5E9; color: #2E7D32; font-size: .68rem; font-weight: 700; padding: .18rem .55rem; border-radius: 100px; }

	/* Cards */
	.pricing-grid { display: grid; grid-template-columns: 1fr 1.08fr; gap: 1.5rem; align-items: start; }

	/* Free */
	.plan-free {
	background: var(--cream); border: 1.5px solid var(--border);
	border-radius: var(--r-lg); padding: 2.2rem;
	}

	/* Plus */
	.plan-plus {
	background: var(--forest); border-radius: var(--r-lg); padding: 2.2rem;
	position: relative; overflow: hidden;
	}
	.plan-plus::before {
	content: ''; position: absolute; top: -100px; right: -100px;
	width: 280px; height: 280px; border-radius: 50%;
	background: radial-gradient(circle, rgba(238,175,134,.1) 0%, transparent 65%);
	}

	/* Offer block */
	.offer-block { margin-bottom: 1.8rem; border-radius: 16px; overflow: hidden; border: 1px solid rgba(238,175,134,.22); }

	.offer-trial {
	background: rgba(238,175,134,.1);
	padding: 1rem 1.2rem;
	display: flex; align-items: center; gap: 1rem;
	}
	.trial-badge {
	background: var(--peach); border-radius: 10px;
	padding: .5rem .75rem; text-align: center; flex-shrink: 0; min-width: 50px;
	}
	.trial-badge strong { display: block; font-size: 1.3rem; font-weight: 700; color: var(--forest); line-height: 1; }
	.trial-badge small { font-size: .5rem; text-transform: uppercase; letter-spacing: .08em; font-weight: 700; color: var(--forest); }
	.trial-meta { flex: 1; }
	.trial-meta p { font-size: .8rem; font-weight: 600; color: var(--cream); }
	.trial-meta small { font-size: .71rem; color: rgba(251,246,240,.42); }
	.trial-checks { display: flex; flex-direction: column; gap: .18rem; }
	.trial-checks span { font-size: .69rem; color: rgba(251,246,240,.5); display: flex; align-items: center; gap: .28rem; }
	.trial-checks span svg { font-size: .75rem; color: var(--peach); }

	.offer-launch {
	background: rgba(255,255,255,.04); border-top: 1px solid rgba(238,175,134,.15);
	padding: .75rem 1.2rem; display: flex; align-items: flex-start; gap: .6rem;
	}
	.offer-launch svg { font-size: .95rem; color: var(--peach); flex-shrink: 0; margin-top: .1rem; }
	.offer-launch p { font-size: .76rem; color: rgba(251,246,240,.55); line-height: 1.45; }
	.offer-launch strong { color: var(--peach); font-weight: 600; }

	/* Shared plan parts */
	.plan-label { font-size: .7rem; font-weight: 700; text-transform: uppercase; letter-spacing: .12em; color: var(--muted); margin-bottom: .35rem; }
	.plan-label.lt { color: rgba(251,246,240,.38); }
	.plan-desc { font-size: .845rem; color: var(--muted); margin-bottom: 1.6rem; }
	.plan-desc.lt { color: rgba(251,246,240,.42); }
	.price-block { margin-bottom: 1.8rem; }
	.price-old-row { display: flex; align-items: center; gap: .5rem; margin-bottom: .1rem; }
	.price-s { font-size: .92rem; color: rgba(255,90,90,.75); text-decoration: line-through; }
	.price-soon { font-size: .63rem; background: rgba(96,165,250,.18); color: rgba(147,210,255,.9); padding: .14rem .48rem; border-radius: 100px; font-weight: 600; }
	.feat-soon { font-size: .68rem; font-weight: 600; background: rgba(96,165,250,.15); color: rgba(147,210,255,.8); padding: .12rem .42rem; border-radius: 100px; margin-left: .25rem; }
	.price-row { display: flex; align-items: baseline; gap: .25rem; }
	.price-row strong { font-size: 2.6rem; font-weight: 700; line-height: 1; }
	.price-row.dk strong { color: var(--forest); }
	.price-row.lt strong { color: var(--cream); }
	.price-row small { font-size: .845rem; }
	.price-row.dk small { color: var(--muted); }
	.price-row.lt small { color: rgba(251,246,240,.4); }
	.price-caption { font-size: .76rem; margin-top: .3rem; }
	.price-caption.dk { color: var(--muted); }
	.price-caption.lt { color: rgba(251,246,240,.35); }
	.price-save { display: inline-block; background: #E8F5E9; color: #2E7D32; font-size: .68rem; font-weight: 700; padding: .16rem .5rem; border-radius: 100px; }
	.annual-extra { display: none; margin-top: .3rem; }
	.annual-extra.show { display: block; }

	.feat-list { list-style: none; display: flex; flex-direction: column; gap: .6rem; margin-bottom: 1.8rem; }
	.feat-list li { display: flex; gap: .5rem; align-items: flex-start; font-size: .845rem; }
	.feat-list li svg { font-size: 1rem; flex-shrink: 0; margin-top: 1px; }
	.feat-list.dk li { color: var(--forest); }
	.feat-list.dk li svg { color: var(--forest-soft); }
	.feat-list.lt li { color: rgba(251,246,240,.82); }
	.feat-list.lt li svg { color: var(--peach); }

	/* ═══════════════════════════
	 FAQ
	═══════════════════════════ */
	.section-faq { background: var(--cream); }

	.faq-list { max-width: 700px; margin: 3rem auto 0; display: flex; flex-direction: column; gap: .65rem; }
	.faq-item { border: 1.5px solid var(--border); border-radius: var(--r-sm); overflow: hidden; }
	.faq-q {
	width: 100%; background: none; border: none; cursor: pointer;
	padding: 1.15rem 1.4rem; text-align: left;
	font-family: 'Inter', sans-serif; font-size: .88rem; font-weight: 600; color: var(--forest);
	display: flex; justify-content: space-between; align-items: center; gap: 1rem;
	transition: background .2s;
	}
	.faq-q:hover { background: rgba(17,48,42,.03); }
	.faq-q.open { background: rgba(17,48,42,.04); }
	.faq-arr {
	width: 22px; height: 22px; border-radius: 50%; background: var(--peach-pale);
	display: grid; place-items: center; flex-shrink: 0; transition: transform .25s;
	}
	.faq-arr svg { font-size: .75rem; color: var(--peach-dark); }
	.faq-q.open .faq-arr { transform: rotate(180deg); }
	.faq-a { max-height: 0; overflow: hidden; transition: max-height .35s ease, padding .2s; padding: 0 1.4rem; }
	.faq-a.open { max-height: 280px; padding: .9rem 1.4rem 1.2rem; }
	.faq-a p { font-size: .865rem; color: var(--muted); line-height: 1.7; }

	/* ═══════════════════════════
	 CTA FINAL
	═══════════════════════════ */
	.section-cta {
	background: var(--forest); padding: 6rem 0;
	text-align: center; position: relative; overflow: hidden;
	}
	.section-cta::before {
	content: ''; position: absolute; bottom: -100px; right: -100px;
	width: 450px; height: 450px; border-radius: 50%;
	background: radial-gradient(circle, rgba(238,175,134,.08) 0%, transparent 65%);
	}
	.cta-inner { max-width: 560px; margin: 0 auto; padding: 0 2rem; position: relative; z-index: 1; }
	.cta-inner .h2 { color: var(--cream); margin-bottom: 1rem; }
	.cta-inner em { color: var(--peach); }
	.cta-inner .lead { color: rgba(251,246,240,.48); margin-bottom: 2.2rem; }
	/* ═══════════════════════════
	 ANIMATIONS
	═══════════════════════════ */
	@keyframes fadeUp { from { opacity: 0; transform: translateY(22px); } to { opacity: 1; transform: none; } }
	@keyframes float { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-10px); } }
	@keyframes fb1 { 0%,100% { transform: translateY(0) rotate(-1deg); } 50% { transform: translateY(-8px) rotate(0deg); } }
	@keyframes fb2 { 0%,100% { transform: translateY(0) rotate(1deg); } 50% { transform: translateY(-8px) rotate(0deg); } }

	.reveal { opacity: 0; transform: translateY(24px); transition: opacity .6s ease, transform .6s ease; }
	.reveal.in { opacity: 1; transform: none; }
	.d1 { transition-delay: .1s; } .d2 { transition-delay: .2s; } .d3 { transition-delay: .3s; }

	/* ═══════════════════════════
	 RESPONSIVE
	═══════════════════════════ */
	@media (max-width: 960px) {
	.hero-inner { grid-template-columns: 1fr; text-align: center; padding: 4rem 1.5rem 3rem !important; }
	.hero-sub, .hero-args { margin-left: auto; margin-right: auto; }
	.hero-ctas, .hero-trust { justify-content: center; }
	.hero-visual { display: none; }
	.problem-grid { grid-template-columns: 1fr; }
	.benefits-grid { grid-template-columns: 1fr; }
	.modules-grid { grid-template-columns: 1fr; }
	.section-modules .btn { white-space: normal; text-align: center; justify-content: center; max-width: 100%; }
	.h2 { text-wrap: balance; }
	.steps-wrap { grid-template-columns: repeat(2,1fr); }
	.steps-wrap::before { display: none; }
	.testi-grid { grid-template-columns: 1fr; }
	.pricing-grid { grid-template-columns: 1fr; }
	}
	@media (max-width: 560px) {
	.steps-wrap { grid-template-columns: 1fr; }
	}
	@media (max-width: 960px) {
	.hero-wrap--dk .hero-inner { grid-template-columns: 1fr; gap: 2rem; }
	.hero-wrap--dk .hero-inner > div:last-child { display: none; }
	.hero-wrap--dk h1, .hero-wrap--dk .lead { max-width: 100%; }
	.proof-grid { grid-template-columns: 1fr; }
	.cibles-layout { grid-template-columns: 1fr; }
	.cibles-grid { grid-template-columns: repeat(2, 1fr); }
	.tabs-layout { grid-template-columns: 1fr; }
	.tabs-content-v { min-width: 0; overflow: hidden; }
	.parrainage-stat-label { font-size: .46rem; letter-spacing: 0; }
	.tabs-nav-v { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); position: static; overflow: hidden; }
	.tab-btn-v { width: 100%; justify-content: center; align-items: center; height: 4rem; background: rgba(17,48,42,.05); border-radius: var(--r-sm); }
	.tab-btn-v.active { box-shadow: none; }
	.tab-btn-v .tab-arrow,
	.tab-btn-v.active .tab-arrow { display: none; }
	.extras-bento { grid-template-columns: 1fr; }
	.extra-card.full { grid-column: 1; }
	.extra-card--wide { grid-column: 1 !important; }
	.notifs-inner { grid-template-columns: 1fr !important; gap: 1.5rem !important; }
	.hebergement-inner { grid-template-columns: 1fr !important; }
	.hebergement-text { grid-column: 1 !important; }
	.wallet-layout { grid-template-columns: 1fr; }
	.stats-grid { grid-template-columns: 1fr; }
	.auth-grid { grid-template-columns: repeat(2,1fr); }
	}
	@media (max-width: 600px) {
	.wallet-row { flex-direction: column; }
	.ref-stats-row { grid-template-columns: repeat(3,1fr); }
	.hero-anchors { display: none; }
	}
