/* ================================================================
   Rétractation Vente — front.css
   Style: La Boutique de la Mémée
   ================================================================ */

/* ── Wrapper ─────────────────────────────────────────────────── */
.rv-form-wrapper {
	max-width: 700px;
	margin: 0 auto;
}

/* ── Formulaire ──────────────────────────────────────────────── */
.rv-form {
	background: linear-gradient(135deg, rgba(20, 36, 81, 0.03) 0%, rgba(242, 226, 208, 0.2) 100%);
	padding: 40px;
	border-radius: 16px;
	border: 2px solid rgba(240, 185, 240, 0.3);
	box-sizing: border-box;
}

@media (max-width: 600px) {
	.rv-form {
		padding: 25px 20px;
	}
}

/* ── Lignes & grille ──────────────────────────────────────────── */
.rv-form-row {
	margin-bottom: 20px;
}

.rv-form-row-2 {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 20px;
}

@media (max-width: 600px) {
	.rv-form-row-2 {
		grid-template-columns: 1fr;
	}
}

/* ── Champ ────────────────────────────────────────────────────── */
.rv-field {
	display: flex;
	flex-direction: column;
}

.rv-field label {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 8px;
	font-weight: 500;
	font-size: 15px;
	color: #142451;
}

.rv-field label svg {
	color: #F0B9F0;
	flex-shrink: 0;
}

.rv-required {
	color: #F0B9F0;
}

/* ── Inputs, select, textarea ────────────────────────────────── */
.rv-form input[type="text"],
.rv-form input[type="email"],
.rv-form textarea {
	width: 100%;
	padding: 14px 16px;
	border: 2px solid #F2E2D0;
	border-radius: 10px;
	font-size: 15px;
	color: #142451;
	background: #fff;
	box-sizing: border-box;
	transition: border-color 0.25s ease, box-shadow 0.25s ease;
}

.rv-form input[type="text"]:focus,
.rv-form input[type="email"]:focus,
.rv-form textarea:focus {
	outline: none;
	border-color: #F0B9F0;
	box-shadow: 0 0 0 4px rgba(240, 185, 240, 0.15);
}

.rv-form input::placeholder,
.rv-form textarea::placeholder {
	color: #999;
}

.rv-form textarea {
	resize: vertical;
	min-height: 140px;
}

/* ── Case RGPD ────────────────────────────────────────────────── */
.rv-field-checkbox label {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	cursor: pointer;
	font-size: 13px;
	color: #666;
	font-weight: 400;
}

.rv-field-checkbox input[type="checkbox"] {
	width: 20px;
	height: 20px;
	margin-top: 2px;
	accent-color: #F0B9F0;
	cursor: pointer;
	flex-shrink: 0;
}

.rv-field-checkbox a {
	color: #142451;
	text-decoration: underline;
}

/* ── Bouton submit ────────────────────────────────────────────── */
.rv-submit-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	width: 100%;
	padding: 16px 32px;
	background: linear-gradient(135deg, #142451 0%, #1a3066 100%)!important;
	color: #F2E2D0!important;
	border: none!important;
	border-radius: 10px!important;
	font-size: 17px!important;
	font-weight: 600!important;
	cursor: pointer!important;
	transition: transform 0.25s ease, box-shadow 0.25s ease, background 0.25s ease, color 0.25s ease!important;
	text-decoration: none !important;
	box-sizing: border-box!important;
}

.rv-submit-btn:hover {
	transform: translateY(-2px)!important;
	box-shadow: 0 8px 25px rgba(20, 36, 81, 0.3)!important;
	background: #F0B9F0!important;
	color: #142451!important;
}

.rv-submit-btn:active {
	transform: translateY(0);
}

.rv-submit-btn svg {
	transition: transform 0.25s ease;
}

.rv-submit-btn:hover svg {
	transform: translateX(3px) translateY(-3px);
}

/* ── Alertes ──────────────────────────────────────────────────── */
.rv-alert {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	padding: 16px 20px;
	border-radius: 12px;
	margin-bottom: 24px;
	font-size: 15px;
	line-height: 1.5;
}

.rv-alert svg {
	flex-shrink: 0;
	margin-top: 2px;
}

.rv-alert-success {
	background: #e8f5e9;
	border: 2px solid #a5d6a7;
	color: #2e7d32;
}

.rv-alert-error {
	background: #ffebee;
	border: 2px solid #ef9a9a;
	color: #c62828;
}

.rv-alert ul {
	margin: 0;
	padding-left: 18px;
}

/* ── Honeypot ─────────────────────────────────────────────────── */
.rv-hp {
	position: absolute !important;
	left: -9999px !important;
	top: auto;
	width: 1px;
	height: 1px;
	overflow: hidden;
}
