:root {
	--accent: #00d38c;
	--bg: #ffffff;
	--card: #faedef;
	--danger: #ff5c7a;
	--imc-border: var(--border,#e5e7eb);
	--imc-card-bg: var(--card,#ffffff);
	--imc-muted: var(--muted,#64748b);
	--imc-primary-weak: rgba(43,182,115,.18);
	--imc-primary: var(--accent,#2bb673);
	--imc-text: var(--text,#0f172a);
	--muted: #4b5563;
	--primary-2: #50045d;
	--primary: #e11a63;
	--radius: 18px;
	--shadow: 0 10px 30px rgba(0,0,0,.25);
	--text: #0b0f15;
}

* {
	box-sizing: border-box;
}

body {
	-webkit-font-smoothing: antialiased;
	background-attachment: fixed, fixed, fixed;
	background-color: var(--bg);
	background-repeat: no-repeat;
	color: var(--text);
	font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial;
	line-height: 1.45;
	margin: 0;
}

body, html {
	height: 100%;
}

button.opt {
	appearance: none;
	background: var(--primary);
	border-radius: 14px;
	border: 3px solid var(--primary);
	color: #ffffff;
	cursor: pointer;
	flex: 0 0 auto;
	font-size: 14px;
	font-weight: 600;
	padding: 12px 14px;
	text-align: center;
	transition: transform .06s ease, border-color .2s ease, background .2s ease;
	width: auto;
}

button.opt.selected {
	filter: brightness(1.50);
}

button.opt:hover {
	filter: brightness(1.50);
	transform: translateY(-1px);
}

footer {
	color: var(--primary-2);
	font-size: 12px;
	margin-top: 14px;
	text-align: center;
	text-align: center !important;
}

h3 {
	color: var(--primary);
	font-size: 20px;
	margin: 0 0 10px;
}

header {
	color: var(--primary);
	margin-bottom: 18px;
	text-align: center;
}

header h1 {
	font-size: clamp(22px,4.2vw,34px);
	font-weight: 700;
	margin: 10px 0 6px;
}

header p {
	color: #000000;
	margin: 0;
}

#card-engagement {
	overflow: hidden;
	position: relative;
}

.promo-badge {
	background: linear-gradient(135deg,#ff4fa3,#ff8cc6);
	border-radius: 8px;
	box-shadow: 0 2px 6px rgba(0,0,0,0.15);
	color: #fff;
	font-size: 14px;
	font-weight: bold;
	padding: 6px 12px;
	position: absolute;
	right: 10px;
	top: 10px;
	z-index: 10;
}

#stripe-form {
	align-items: center;
	background: repeating-linear-gradient(45deg,#fafafa,#fafafa 10px,#ffffff 10px,#ffffff 20px);
	border-radius: 12px;
	border: 2px dashed rgba(0,0,0,.15);
	display: flex;
	justify-content: center;
	min-height: 120px;
	padding: 18px;
}

#submitPaymentButtonDiv {
	margin-top: -110px;
	margin-top: -70px;
}

.badges {
	display: grid;
	gap: 6px;
	list-style: none;
	margin: 6px 0 0;
	padding: 0;
}

.badges li {
	background: linear-gradient(90deg, rgba(225,26,99,.12), rgba(80,4,93,.10));
	border-radius: 12px;
	border: 1px solid rgba(225,26,99,.22);
	color: #1f2937;
	font-weight: 600;
	padding: 8px 10px;
	text-align: left;
}

.btns {
	display: grid !important;
	flex-wrap: wrap;
	gap: 10px !important;
	grid-template-columns: repeat(2, minmax(0,1fr));
	max-width: 100% !important;
	width: 100% !important;
}

.btns.error {
	border-radius: 10px;
	padding: 8px;
}

.btns.error, .field.error input, .field.error textarea {
	border: 1px solid #e74c3c !important;
	box-shadow: 0 0 0 2px rgba(231,76,60,.08);
}

.card {
	background: var(--card);
	border-radius: var(--radius);
	border: 1px solid rgba(0,0,0,.06);
	box-shadow: var(--shadow);
	color: var(--text);
	padding: 18px;
}

.checkout {
	display: grid;
	gap: 22px;
}

.checkout .legal {
	color: #4b5563;
	font-size: 12px;
	line-height: 1.5;
	text-align: center;
}

.checkout .legal a {
	color: var(--primary-2);
	text-decoration: underline;
	text-underline-offset: 2px;
}

.checkout-hero {
	display: grid;
	gap: 16px;
	text-align: center;
}

.checkout-hero .degrade {
	-webkit-background-clip: text;
	background-clip: text;
	background: linear-gradient(90deg, var(--primary), var(--primary-2));
	color: transparent;
}

.checkout-hero .pill {
	background: rgba(225,26,99,.08);
	border-radius: 999px;
	border: 1px solid rgba(225,26,99,.25);
	color: var(--primary-2);
	display: inline-block;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: .2px;
	padding: 6px 12px;
}

.checkout-hero .sub {
	color: #374151;
	margin: 0 auto;
	max-width: 740px;
}

.checkout-hero h2 {
	font-size: clamp(22px,3.6vw,32px);
	font-weight: 800;
	line-height: 1.15;
	margin: 4px 0;
}

.click-hint {
	color: #888;
	font-size: 14px;
	margin-bottom: 12px;
	text-align: center;
}

.concurrence {
	background: linear-gradient(135deg,#ffe6f0 0%,#f3e6ff 100%);
	border-radius: 25px;
	box-shadow: 0 6px 18px rgba(0,0,0,0.05);
	box-sizing: border-box;
	margin: 60px auto;
	max-width: 1200px;
	padding: 60px 40px;
}

.concurrence-grid {
	display: grid;
	gap: 35px;
	grid-template-columns: 1fr;
}

.concurrence-item {
	background-clip: padding-box;
	background: linear-gradient(180deg, rgba(225,26,99,.05), rgba(80,4,93,.05));
	border-radius: 20px;
	border: 1px solid rgba(0,0,0,.06);
	box-shadow: 0 2px 10px rgba(0,0,0,0.06);
	min-width: 0;
	padding: 30px 25px;
	position: relative;
	text-align: center;
	transition: all 0.3s ease;
}

.concurrence-item .prix-avantage {
	color: #50045d;
	font-size: 1rem;
	font-weight: 600;
	margin-top: 18px;
}

.concurrence-item .prix-avantage .prix {
	color: #e11a63;
	font-size: 1.1rem;
}

.concurrence-item h3 {
	color: #e11a63;
	font-size: 1.15rem;
	font-weight: 600;
	margin-bottom: 12px;
}

.concurrence-item p {
	color: #444;
	font-size: 0.95rem;
	line-height: 1.55;
}

.concurrence-item::before {
	-webkit-mask-composite: xor;
	-webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
	background: linear-gradient(135deg,#f04fb5,#a03bd8);
	border-radius: 20px;
	content: "";
	inset: 0;
	mask-composite: exclude;
	opacity: 0;
	padding: 2px;
	position: absolute;
	transition: opacity 0.3s ease;
}

.concurrence-item:hover {
	box-shadow: 0 10px 20px rgba(0,0,0,0.08);
	transform: translateY(-6px);
}

.concurrence-item:hover::before {
	opacity: 1;
}

.field {
	align-items: center;
	background: #ffffff;
	border-radius: 12px;
	border: 1px solid #e4e7ee;
	display: flex;
	gap: 8px;
	padding: 10px 12px;
}

.field input[type="email"], .field input[type="number"], .field input[type="text"], .field textarea {
	background: #ffffff;
	border: none;
	color: #0b0f15;
	font-family: inherit;
	font-size: 15px;
	outline: none;
	width: 100%;
}

.field textarea {
	resize: none;
}

.field-error {
	border: 1px solid #e00000 !important;
}

.footer {
	color: #ffffff;
	font-size: .9rem;
	padding: 48px 0;
}

.footer a {
	color: #000000;
	opacity: .9;
	text-decoration: none;
}

.grid {
	display: grid;
	gap: 12px;
	grid-template-columns: 1fr;
}

.grid.two>.btns {
	grid-column: 1 / -1 !important;
}

.guarantee {
	align-items: center;
	background: linear-gradient(90deg, rgba(0,211,140,.18), rgba(0,211,140,.10));
	border-radius: 12px;
	border: 1px solid rgba(0,211,140,.35);
	color: #065f46;
	display: flex;
	gap: 10px;
	justify-content: center;
	padding: 10px 12px;
}

.guarantee svg {
	color: #047857;
	height: 22px;
	width: 22px;
}

.hint {
	color: var(--text);
	font-size: 14px;
	font-weight: 600;
	margin-bottom: 8px;
	margin-top: 6px;
}

.imc-card {
	align-content: start;
	background: linear-gradient(180deg, rgba(225,26,99,.05), rgba(80,4,93,.05));
	border-radius: 14px;
	border: 1px solid rgba(0,0,0,.06);
	display: grid;
	gap: 6px;
	padding: 14px;
	transition: transform .18s ease, box-shadow .18s ease;
}

.imc-card h4 {
	color: #374151;
	font-size: 14px;
	font-weight: 800;
	margin: 2px 0 0;
}

.imc-card-icon {
	color: var(--primary-2,#50045d);
	height: 36px;
	margin: 0 auto;
	width: 36px;
}

.imc-card-icon svg {
	height: 100%;
	width: 100%;
}

.imc-card:hover {
	box-shadow: 0 8px 20px rgba(0,0,0,.08);
	transform: translateY(-2px);
}

.imc-foot {
	margin-top: 4px;
}

.imc-foot-inner {
	align-items: flex-start;
	background: linear-gradient(90deg, rgba(225,26,99,.12), rgba(80,4,93,.10));
	border-radius: 12px;
	border: 1px solid rgba(225,26,99,.22);
	color: #1f2937;
	display: flex;
	gap: 10px;
	padding: 10px 12px;
}

.imc-grid {
	display: grid;
	gap: 12px;
	grid-template-columns: 1fr;
}

.imc-head {
	display: grid;
	gap: 8px;
	text-align: center;
}

.imc-head .pill {
	background: rgba(225,26,99,.10);
	border-radius: 999px;
	border: 1px solid rgba(225,26,99,.28);
	color: var(--primary-2,#50045d);
	display: inline-block;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: .2px;
	padding: 6px 12px;
}

.imc-head h3 {
	-webkit-background-clip: text;
	background-clip: text;
	background: linear-gradient(90deg, var(--primary,#e11a63), var(--primary-2,#50045d));
	color: transparent;
	font-size: clamp(20px,3.2vw,28px);
	font-weight: 800;
	line-height: 1.15;
	margin: 0;
}

.imc-loader-card {
	background: var(--imc-card-bg);
	border-radius: 18px;
	border: 1px solid var(--imc-border);
	box-shadow: 0 6px 30px rgba(15,23,42,.06);
	padding: clamp(20px,5vw,40px);
	text-align: center;
	width: min(820px,100%);
}

.imc-loader-hint {
	color: var(--imc-muted);
	font-size: clamp(12px,1.8vw,14px);
	margin: 10px 0 0;
}

.imc-loader-hint, .imc-loader-subtitle {
	font-size: clamp(16px,2.2vw,17px);
}

.imc-loader-progress {
	background: var(--imc-primary-weak);
	border-radius: 999px;
	height: 6px;
	margin: 8px auto 14px;
	overflow: hidden;
	position: relative;
	width: min(480px,86%);
}

.imc-loader-progress .bar {
	animation: imc-slide 1.4s ease-in-out infinite;
	background: linear-gradient(90deg, transparent, var(--imc-primary), transparent);
	border-radius: 999px;
	inset: 0 auto 0 0;
	position: absolute;
	width: 35%;
}

.imc-loader-spinner {
	--size: clamp(72px,10vw,110px);
	animation: imc-spin 1s linear infinite;
	border-radius: 999px;
	border-top-color: var(--imc-primary);
	border: max(4px,.5vw) solid var(--imc-primary-weak);
	display: grid;
	height: var(--size);
	margin-inline: auto;
	place-items: center;
	position: relative;
	width: var(--size);
}

.imc-loader-spinner::after {
	animation: imc-pulse 1.8s ease-in-out infinite;
	background: radial-gradient(closest-side, var(--imc-primary) 0%, transparent 70%);
	border-radius: 999px;
	content: "";
	height: calc(var(--size) * .42);
	opacity: .12;
	width: calc(var(--size) * .42);
}

.imc-loader-steps {
	display: inline-grid;
	gap: 8px;
	justify-content: center;
	list-style: none;
	margin: 0 auto 18px;
	padding: 0;
	text-align: left;
}

.imc-loader-steps .dot {
	animation: imc-breathe 2s ease-out infinite;
	background: var(--imc-primary);
	border-radius: 50%;
	box-shadow: 0 0 0 0 var(--imc-primary-weak);
	height: 10px;
	width: 10px;
}

.imc-loader-steps li {
	align-items: center;
	color: var(--imc-muted);
	display: grid;
	font-size: clamp(13px,2vw,15px);
	font-size: clamp(14px,2vw,15px);
	gap: 10px;
	grid-template-columns: auto 1fr;
	justify-content: start;
}

.imc-loader-steps li:nth-child(2) .dot {
	animation-delay: .33s;
}

.imc-loader-steps li:nth-child(3) .dot {
	animation-delay: .66s;
}

.imc-loader-subtitle {
	color: var(--imc-muted);
	font-size: clamp(14px,2.2vw,17px);
	margin: 0 auto clamp(14px,3.2vw,22px);
	max-width: 52ch;
}

.imc-loader-title {
	font-size: clamp(20px,3.2vw,30px);
	font-size: clamp(26px,3.2vw,30px);
	line-height: 1.2;
	margin: 18px 0 6px;
}

.imc-loader-wrap {
	color: var(--imc-text);
	display: grid;
	min-height: 60vh;
	padding: clamp(16px,4vw,32px);
	place-items: center;
}

.imc-note {
	color: #6b7280;
	font-size: 12px;
	margin: 0;
}

.imc-program-label {
	color: #374151;
	font-size: 1em;
	font-weight: 600;
	grid-area: label;
	text-align: left;
}

.imc-program-note {
	color: #6b7280;
	font-size: 12px;
	grid-area: note;
	line-height: 1.2;
	margin-top: 2px;
	text-align: left;
}

.imc-program-row {
	align-items: center;
	background: #fff;
	border-radius: 10px;
	border: 1px dashed rgba(0,0,0,.08);
	display: grid;
	gap: 6px 12px;
	grid-template-areas: "label value""note note";
	grid-template-columns: 1fr auto;
	justify-content: space-between;
	padding: 10px 12px;
}

.imc-program-rows {
	display: grid;
	gap: 8px;
	margin-top: 4px;
}

.imc-program-value {
	font-size: 20px;
	font-weight: 700;
	grid-area: value;
	text-align: right;
}

.imc-program-value small {
	font-size: 12px;
	font-weight: 600;
	opacity: .8;
}

.imc-spark {
	color: var(--primary-2,#50045d);
	font-size: 16px;
	line-height: 1.2;
}

.imc-sub {
	color: #374151;
	margin: 0;
}

.imc-summary {
	background: #ffffff;
	border-radius: var(--radius,16px);
	border: 1px solid rgba(0,0,0,.06);
	box-shadow: var(--shadow, 0 8px 20px rgba(0,0,0,.06));
	display: grid;
	gap: 18px;
	padding: 18px;
}

.imc-value {
	-webkit-background-clip: text;
	background-clip: text;
	background: linear-gradient(90deg, var(--primary,#e11a63), var(--primary-2,#50045d));
	color: transparent;
	font-size: clamp(18px,4.5vw,26px);
	font-weight: 900;
	line-height: 1.1;
	margin: 0;
}

.nav {
	border-top: 1px solid rgba(0,0,0,0.14) !important;
	display: flex;
	gap: 10px;
	justify-content: space-between;
	margin-top: 16px;
	margin-top: 30px !important;
	padding-top: 16px !important;
}

.nav .next {
	background-color: #fc6207;
	color: #ffffff;
}

.nav .next::after {
	content: "";
	margin-left: 6px;
}

.nav .next::after, .nav .prev::before {
	display: inline-block;
	font-weight: inherit;
}

.nav .next:hover {
	background-color: #ff7c2e;
	color: #ffffff;
}

.nav .prev {
	background: #1a2233;
	color: #e7ecf5;
}

.nav .prev::before {
	content: "";
	margin-right: 6px;
}

.nav a {
	border-radius: 12px;
	border: 0;
	cursor: pointer;
	flex: 1;
	font-size: 18px !important;
	font-weight: 700;
	line-height: 1.2;
	padding: 16px 20px !important;
	text-decoration: none;
}

.nav button {
	border-radius: 12px;
	border: 0;
	cursor: pointer;
	flex: 1;
	font-size: 18px !important;
	font-weight: 700;
	line-height: 1.2;
	padding: 12px 14px;
	padding: 16px 20px !important;
}

.paymentFormDiv {
	max-width: 100%;
	width: 100%;
	width: 500px;
}

.plan-amount {
	color: #111;
	font-size: 28px;
	font-weight: 900;
	line-height: 1;
}

.plan-badge {
	background: #f0abfc;
	border-radius: 999px;
	color: #3b0764;
	font-size: 11px;
	font-weight: 700;
	padding: 4px 8px;
	position: absolute;
	right: 10px;
	top: 10px;
}

.plan-card {
	background: linear-gradient(180deg,#fff,#fff 70%,#fff0ff);
	border-radius: 16px;
	border: 2px solid #e9d7ff;
	cursor: pointer;
	padding: 18px 16px;
	position: relative;
	transition: box-shadow .2s, transform .06s, border-color .2s, background .2s;
}

.plan-card.selected {
	background: linear-gradient(180deg,#fff,#fdf2ff 70%,#f9e8ff);
	border-color: #c026d3;
	box-shadow: 0 10px 30px rgba(192,38,211,.18);
}

.plan-card:active {
	transform: scale(.998);
}

.plan-card:hover {
	box-shadow: 0 8px 24px rgba(153,51,255,.12);
}

.plan-desc {
	color: #555;
	font-size: 13px;
	line-height: 1.35;
}

.plan-grid {
	display: grid;
	gap: 14px;
	grid-template-columns: 1fr 1fr;
	margin: 16px 0 6px;
}

.plan-price {
	align-items: flex-end;
	display: flex;
	gap: 8px;
	margin: 6px 0 2px;
}

.plan-title {
	color: #7c3aed;
	font-size: 14px;
	font-weight: 800;
	letter-spacing: .2px;
	text-transform: uppercase;
}

.plan-unit {
	color: #555;
	font-size: 13px;
	margin-bottom: 2px;
}

.price .trial {
	-webkit-background-clip: text;
	background-clip: text;
	background: linear-gradient(90deg, var(--primary), var(--primary-2));
	color: transparent;
	display: inline-block;
	font-size: clamp(34px,7vw,56px);
	font-weight: 900;
	line-height: 1;
}

.price .trial-note {
	color: #6b7280;
	display: block;
	font-weight: 700;
	margin-top: 4px;
}

.price-card {
	background: #fff;
	border-radius: var(--radius);
	border: 1px solid rgba(0,0,0,.06);
	box-shadow: var(--shadow);
	display: grid;
	gap: 14px;
	padding: 16px;
}

.price-left {
	display: grid;
	gap: 10px;
	justify-items: start;
}

.progress {
	background: #ffffff;
	border-radius: 999px;
	border: 1px solid rgba(0,0,0,.2);
	height: 10px;
	margin: 10px 0 20px;
	overflow: hidden;
}

.progress>span {
	background: linear-gradient(90deg, var(--primary), var(--primary-2));
	display: block;
	height: 100%;
	transition: width .35s ease;
	width: 0%;
}

.q {
	font-size: 18px;
	font-weight: 700;
	margin: 8px 0 14px;
}

.reassurance {
	display: grid;
	gap: 10px;
	grid-template-columns: 1fr;
}

.reassurance .tile {
	background: #ffffff;
	border-radius: 16px;
	border: 1px solid rgba(0,0,0,.06);
	height: 100%;
	padding: 14px;
}

.reassurance h4 {
	color: var(--primary-2);
	margin: 0 0 6px;
}

.reassurance p {
	color: #1f2937;
	margin: 0;
}

.secure {
	align-items: center;
	color: #374151;
	display: flex;
	font-size: 12px;
	gap: 6px;
	margin: 8px 0 0;
}

.secure .lock {
	font-size: 14px;
}

.step {
	display: none;
}

.step.active {
	display: block;
}

.stripe-box {
	background: #fff;
	border-radius: 16px;
	border: 1px solid rgba(0,0,0,.06);
	box-shadow: var(--shadow);
	padding: 16px;
}

.stripe-box h3 {
	color: var(--primary-2);
	font-size: 20px;
	margin: 0 0 10px;
}

.top-logo {
	margin-bottom: 20px;
	margin-top: 20px;
	text-align: center;
	width: 100%;
}

.top-logo img {
	height: auto;
	max-width: 240px;
	width: 40%;
}

.value-points {
	display: grid;
	gap: 8px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.value-points li {
	background: #faf5fb;
	border-radius: 12px;
	border: 1px dashed rgba(80,4,93,.25);
	padding: 10px 12px;
	text-align: left;
}

.wrapper {
	margin: 24px auto 80px;
	max-width: 860px;
	padding: 0 16px;
}

@keyframes imc-breathe {
	0% {
		box-shadow: 0 0 0 0 var(--imc-primary-weak);
	}

	100% {
		box-shadow: 0 0 0 0 transparent;
	}

	70% {
		box-shadow: 0 0 0 10px transparent;
	}
}

@keyframes imc-pulse {
	0%, 100% {
		opacity: .10;
		transform: scale(.9);
	}

	50% {
		opacity: .18;
		transform: scale(1.05);
	}
}

@keyframes imc-slide {
	0% {
		transform: translateX(-120%);
	}

	100% {
		transform: translateX(120%);
	}

	50% {
		transform: translateX(50%);
	}
}

@keyframes imc-spin {
	to {
		transform: rotate(360deg);
	}
}

@keyframes shake {
	10% {
		transform: translateX(-4px);
	}

	100% {
		transform: translateX(0);
	}

	30% {
		transform: translateX(4px);
	}

	50% {
		transform: translateX(-3px);
	}

	70% {
		transform: translateX(3px);
	}

	90% {
		transform: translateX(-2px);
	}
}

@media (max-width: 480px) {
	footer {
		hyphens: auto;
		text-align: justify !important;
		text-justify: inter-word;
	}

	footer::after {
		content: "";
		display: inline-block;
		width: 100%;
	}

	.nav {
		border-top-color: rgba(0,0,0,0.14) !important;
		margin-top: 26px !important;
		padding-top: 14px !important;
	}
}

@media (max-width: 680px) {
	.footer .container {
		align-items: center;
		flex-direction: column;
		gap: 10px;
		text-align: center;
	}

	.footer .container>div:last-child {
		align-items: center;
		display: flex;
		flex-direction: column;
		gap: 8px;
	}
}

@media (max-width: 768px) {
	.top-logo img {
		max-width: 200px;
		width: 60%;
	}

	@keyframes shake {
		10% {
			transform: translateX(-4px);
		}

		100% {
			transform: translateX(0);
		}

		30% {
			transform: translateX(4px);
		}

		50% {
			transform: translateX(-3px);
		}

		70% {
			transform: translateX(3px);
		}

		90% {
			transform: translateX(-2px);
		}
	}
}

@media (max-width: 780px) {
	.imc-program-label {
		font-size: 0.8em;
	}

	.imc-program-note {
		font-size: 11px;
		margin-top: 4px;
		text-align: left;
	}

	.imc-program-value {
		font-size: 18px;
	}

	@keyframes shake {
		10% {
			transform: translateX(-4px);
		}

		100% {
			transform: translateX(0);
		}

		30% {
			transform: translateX(4px);
		}

		50% {
			transform: translateX(-3px);
		}

		70% {
			transform: translateX(3px);
		}

		90% {
			transform: translateX(-2px);
		}
	}
}

@media (max-width:780px) {
	.imc-program-label {
		font-size: 0.8em;
	}

	.plan-grid {
		grid-template-columns: 1fr;
	}

	@keyframes shake {
		10% {
			transform: translateX(-4px);
		}

		100% {
			transform: translateX(0);
		}

		30% {
			transform: translateX(4px);
		}

		50% {
			transform: translateX(-3px);
		}

		70% {
			transform: translateX(3px);
		}

		90% {
			transform: translateX(-2px);
		}
	}
}

@media (min-width: 1024px) {
	.concurrence-grid {
		grid-template-columns: repeat(3, minmax(0,1fr));
	}

	@keyframes shake {
		10% {
			transform: translateX(-4px);
		}

		100% {
			transform: translateX(0);
		}

		30% {
			transform: translateX(4px);
		}

		50% {
			transform: translateX(-3px);
		}

		70% {
			transform: translateX(3px);
		}

		90% {
			transform: translateX(-2px);
		}
	}
}

@media (min-width: 700px) {
	.concurrence-grid {
		grid-template-columns: repeat(2, minmax(0,1fr));
	}

	@keyframes shake {
		10% {
			transform: translateX(-4px);
		}

		100% {
			transform: translateX(0);
		}

		30% {
			transform: translateX(4px);
		}

		50% {
			transform: translateX(-3px);
		}

		70% {
			transform: translateX(3px);
		}

		90% {
			transform: translateX(-2px);
		}
	}
}

@media (min-width: 760px) {
	.imc-grid {
		grid-template-columns: repeat(4,1fr);
	}

	@keyframes shake {
		10% {
			transform: translateX(-4px);
		}

		100% {
			transform: translateX(0);
		}

		30% {
			transform: translateX(4px);
		}

		50% {
			transform: translateX(-3px);
		}

		70% {
			transform: translateX(3px);
		}

		90% {
			transform: translateX(-2px);
		}
	}
}

@media (prefers-reduced-motion: reduce) {
	.imc-loader-spinner, .imc-loader-spinner::after, .imc-loader-steps .dot, .imc-loader-progress .bar {
		animation: none !important;
	}

	@keyframes shake {
		10% {
			transform: translateX(-4px);
		}

		100% {
			transform: translateX(0);
		}

		30% {
			transform: translateX(4px);
		}

		50% {
			transform: translateX(-3px);
		}

		70% {
			transform: translateX(3px);
		}

		90% {
			transform: translateX(-2px);
		}
	}
}

@media(min-width:700px) {
	.grid.two {
		grid-template-columns: repeat(2, minmax(0,1fr));
	}

	@keyframes shake {
		10% {
			transform: translateX(-4px);
		}

		100% {
			transform: translateX(0);
		}

		30% {
			transform: translateX(4px);
		}

		50% {
			transform: translateX(-3px);
		}

		70% {
			transform: translateX(3px);
		}

		90% {
			transform: translateX(-2px);
		}
	}
}

@media(min-width:760px) {
	.price-card {
		align-items: center;
		grid-template-columns: 1fr 1fr;
	}

	.reassurance {
		grid-template-columns: repeat(3,1fr);
	}

	@keyframes shake {
		10% {
			transform: translateX(-4px);
		}

		100% {
			transform: translateX(0);
		}

		30% {
			transform: translateX(4px);
		}

		50% {
			transform: translateX(-3px);
		}

		70% {
			transform: translateX(3px);
		}

		90% {
			transform: translateX(-2px);
		}
	}
}