/*
Theme Name: Roulottes du Sud Vendée
Theme URI: https://www.roulottesudvendee.com
Description: Thème sur mesure pour l'association Les Roulottes du Sud Vendée - Un séjour au rythme de la nature
Author: Hugo
Author URI: https://www.roulottesudvendee.com
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: roulottesudvendee
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
*/

/* ==========================================================================
   Variables CSS - Palette Roulottes du Sud Vendée
   Inspirée de la nature, des chevaux et du bocage vendéen
   ========================================================================== */

:root {
	/* Couleurs principales */
	--rsv-vert: #4A7C59;
	--rsv-vert-clair: #6B9B7A;
	--rsv-vert-fonce: #3A5F46;
	
	--rsv-marron: #8B5A2B;
	--rsv-marron-clair: #A67C52;
	--rsv-marron-fonce: #5D3A1A;
	
	/* Couleurs d'accent */
	--rsv-jaune: #D4A84B;
	--rsv-jaune-clair: #E8C77B;
	--rsv-jaune-fonce: #B8923D;
	
	/* Neutres */
	--rsv-blanc: #FFFFFF;
	--rsv-beige: #F5F0E6;
	--rsv-beige-fonce: #E8E0D0;
	--rsv-gris: #D0D0D0;
	--rsv-gris-fonce: #666666;
	--rsv-texte: #333333;
	
	/* Étoiles avis */
	--rsv-etoile: #F5B800;
	--rsv-etoile-vide: #D0D0D0;
	
	/* Espacements */
	--rsv-spacing-xs: 0.5rem;
	--rsv-spacing-sm: 1rem;
	--rsv-spacing-md: 1.5rem;
	--rsv-spacing-lg: 2rem;
	--rsv-spacing-xl: 3rem;
	--rsv-spacing-xxl: 4rem;
	
	/* Bordures */
	--rsv-radius-sm: 4px;
	--rsv-radius-md: 8px;
	--rsv-radius-lg: 12px;
	--rsv-radius-xl: 16px;
	--rsv-radius-full: 50px;
	
	/* Ombres */
	--rsv-shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.08);
	--rsv-shadow-md: 0 4px 20px rgba(0, 0, 0, 0.1);
	--rsv-shadow-lg: 0 8px 30px rgba(0, 0, 0, 0.15);
	
	/* Transitions */
	--rsv-transition: 0.3s ease;
	
	/* Largeur max contenu */
	--rsv-container-width: 1200px;
	--rsv-container-narrow: 800px;
}

/* ==========================================================================
   Reset et Box-sizing
   ========================================================================== */

*, *::before, *::after {
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
}

body {
	margin: 0;
	padding: 0;
	font-family: 'Segoe UI', -apple-system, BlinkMacSystemFont, Roboto, 'Helvetica Neue', sans-serif;
	font-size: 16px;
	line-height: 1.7;
	color: var(--rsv-texte);
	background-color: var(--rsv-beige);
	overflow-x: hidden;
}

img, video, iframe, embed, object {
	max-width: 100%;
	height: auto;
}

a {
	color: var(--rsv-vert-fonce);
	text-decoration: none;
	transition: color var(--rsv-transition);
}

a:hover {
	color: var(--rsv-marron);
}

h1, h2, h3, h4, h5, h6 {
	margin: 0 0 1rem;
	line-height: 1.3;
	color: var(--rsv-marron-fonce);
}

p {
	margin: 0 0 1rem;
}

ul, ol {
	margin: 0 0 1rem;
	padding-left: 1.5rem;
}

/* ==========================================================================
   Utilitaires
   ========================================================================== */

.rsv-container {
	width: 100%;
	max-width: var(--rsv-container-width);
	margin: 0 auto;
	padding: 0 var(--rsv-spacing-md);
}

.rsv-container-narrow {
	max-width: var(--rsv-container-narrow);
}

.rsv-sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

/* ==========================================================================
   Header
   ========================================================================== */

.rsv-header {
	background: var(--rsv-blanc);
	box-shadow: var(--rsv-shadow-sm);
	position: sticky;
	top: 0;
	z-index: 1000;
}

.rsv-header-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: var(--rsv-spacing-sm) var(--rsv-spacing-md);
	max-width: var(--rsv-container-width);
	margin: 0 auto;
	gap: var(--rsv-spacing-md);
}

.rsv-hero-logo {
	width: 180px;
	height: 180px;
	margin-bottom: var(--rsv-spacing-lg);
	filter: drop-shadow(0 4px 20px rgba(0,0,0,0.5));
	background: white;
	padding-top: 30px;
	border-radius: 50%;
	border: 10px solid white;
	object-fit: contain;
}

.rsv-logo {
	display: flex;
	align-items: center;
	gap: var(--rsv-spacing-sm);
}

.rsv-logo img {
	height: 60px;
	width: auto;
}

.rsv-logo-text {
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--rsv-vert-fonce);
	line-height: 1.2;
}

.rsv-logo-tagline {
	font-size: 0.8rem;
	color: var(--rsv-gris-fonce);
	font-weight: 400;
}

/* Navigation principale */
.rsv-nav {
	display: flex;
	align-items: center;
}

.rsv-nav .rsv-menu,
.rsv-nav > ul {
	display: flex;
	align-items: center;
	gap: var(--rsv-spacing-xs);
	list-style: none;
	margin: 0;
	padding: 0;
}

.rsv-nav .rsv-menu li,
.rsv-nav > ul > li {
	position: relative;
	margin: 0;
}

.rsv-nav .rsv-menu > li > a,
.rsv-nav > ul > li > a {
	display: block;
	padding: var(--rsv-spacing-xs) var(--rsv-spacing-sm);
	color: var(--rsv-texte);
	font-weight: 500;
	border-radius: var(--rsv-radius-md);
	transition: all var(--rsv-transition);
	white-space: nowrap;
}

.rsv-nav .rsv-menu > li > a:hover,
.rsv-nav .rsv-menu > li.current-menu-item > a,
.rsv-nav .rsv-menu > li.current-menu-ancestor > a,
.rsv-nav > ul > li > a:hover,
.rsv-nav > ul > li.current-menu-item > a {
	background-color: var(--rsv-vert);
	color: var(--rsv-blanc);
}

/* Sous-menus */
.rsv-nav .rsv-menu .sub-menu,
.rsv-nav > ul ul {
	position: absolute;
	top: 100%;
	left: 0;
	min-width: 220px;
	background: var(--rsv-blanc);
	box-shadow: var(--rsv-shadow-md);
	border-radius: var(--rsv-radius-md);
	padding: var(--rsv-spacing-xs) 0;
	margin: 0;
	list-style: none;
	opacity: 0;
	visibility: hidden;
	transform: translateY(10px);
	transition: all var(--rsv-transition);
	z-index: 100;
}

.rsv-nav .rsv-menu li:hover > .sub-menu,
.rsv-nav > ul > li:hover > ul {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.rsv-nav .rsv-menu .sub-menu li,
.rsv-nav > ul ul li {
	margin: 0;
}

.rsv-nav .rsv-menu .sub-menu a,
.rsv-nav > ul ul a {
	display: block;
	padding: var(--rsv-spacing-xs) var(--rsv-spacing-md);
	color: var(--rsv-texte);
	font-weight: 400;
	font-size: 0.95rem;
	border-radius: 0;
}

.rsv-nav .rsv-menu .sub-menu a:hover,
.rsv-nav > ul ul a:hover {
	background-color: var(--rsv-beige);
	color: var(--rsv-vert-fonce);
}

/* Menu burger mobile */
.rsv-menu-toggle {
	display: none;
	background: none;
	border: none;
	padding: var(--rsv-spacing-xs);
	cursor: pointer;
	flex-direction: column;
	gap: 5px;
}

.rsv-menu-toggle span {
	display: block;
	width: 25px;
	height: 3px;
	background: var(--rsv-vert-fonce);
	border-radius: 2px;
	transition: all var(--rsv-transition);
}

/* Header contact rapide */
.rsv-header-contact {
	display: flex;
	align-items: center;
	gap: var(--rsv-spacing-sm);
	font-size: 0.9rem;
}

/* Bouton téléphone header */
.rsv-header-contact a {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	background: var(--rsv-vert);
	color: var(--rsv-blanc);
	padding: 0.6rem 1.2rem;
	border-radius: var(--rsv-radius-full);
	font-weight: 600;
	font-size: 0.95rem;
	text-decoration: none;
	transition: all var(--rsv-transition);
	box-shadow: 0 2px 8px rgba(74, 124, 89, 0.3);
}

.rsv-header-contact a:hover {
	background: var(--rsv-vert-fonce);
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(74, 124, 89, 0.4);
}

/* ==========================================================================
   Archives
   ========================================================================== */

/* Archive Hero */
.rsv-archive-hero {
	min-height: 30vh;
}

.rsv-page-hero {
	position: relative;
	min-height: 40vh;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	color: var(--rsv-blanc);
	overflow: hidden;
}

.rsv-page-hero-bg {
	position: absolute;
	inset: 0;
	z-index: 1;
	background: linear-gradient(135deg, var(--rsv-vert) 0%, var(--rsv-vert-fonce) 100%);
}

.rsv-page-hero-bg img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.rsv-page-hero-overlay {
	position: absolute;
	inset: 0;
	z-index: 2;
	background: rgba(0,0,0,0.3);
}

.rsv-page-hero .rsv-container {
	position: relative;
	z-index: 3;
}

.rsv-page-hero h1 {
	color: var(--rsv-blanc);
	font-size: 2.5rem;
	margin-bottom: var(--rsv-spacing-sm);
	text-shadow: 0 2px 10px rgba(0,0,0,0.3);
}

.rsv-page-hero-subtitle {
	font-size: 1.2rem;
	opacity: 0.95;
}

/* ==========================================================================
   Formules
   ========================================================================== */
   
/* Sidebar documents */
.rsv-sidebar-docs {
	/* background: var(--rsv-beige);
	padding: var(--rsv-spacing-md);
	border-radius: var(--rsv-radius-md);
	margin-bottom: var(--rsv-spacing-md);
	 */
    background: var(--rsv-blanc);
    padding: var(--rsv-spacing-md);
    border-radius: var(--rsv-radius-lg);
    box-shadow: var(--rsv-shadow-sm);
    margin-bottom: var(--rsv-spacing-md);
}

.rsv-sidebar-docs h4 {
	font-size: 1rem;
	margin: 0 0 var(--rsv-spacing-sm) 0;
	color: var(--rsv-marron-fonce);
}

.rsv-sidebar-doc-btn {
	display: block;
	padding: 0.6rem 0.8rem;
	margin-bottom: 0.5rem;
	background: var(--rsv-blanc);
	border: 1px solid var(--rsv-gris);
	border-radius: var(--rsv-radius-sm);
	color: var(--rsv-texte);
	text-decoration: none;
	font-size: 0.9rem;
	transition: all var(--rsv-transition);
}

.rsv-sidebar-doc-btn:last-child {
	margin-bottom: 0;
}

.rsv-sidebar-doc-btn:hover {
	background: var(--rsv-vert);
	color: var(--rsv-blanc);
	border-color: var(--rsv-vert);
}

.rsv-btn-outline {
	background: transparent;
	border: 2px solid var(--rsv-vert);
	color: var(--rsv-vert);
}

.rsv-btn-outline:hover {
	background: var(--rsv-vert);
	color: var(--rsv-blanc);
}

.rsv-btn-block {
	display: block;
	width: 100%;
	text-align: center;
}

/* ==========================================================================
   Footer
   ========================================================================== */

.rsv-footer {
	background: var(--rsv-marron-fonce);
	color: var(--rsv-beige);
	padding: var(--rsv-spacing-xxl) 0 var(--rsv-spacing-lg);
	margin-top: var(--rsv-spacing-xxl);
}

.rsv-footer a {
	color: var(--rsv-beige);
}

.rsv-footer a:hover {
	color: var(--rsv-jaune);
}

.rsv-footer-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
	gap: var(--rsv-spacing-xl);
	margin-bottom: var(--rsv-spacing-xl);
}

.rsv-footer-col h3 {
	color: var(--rsv-jaune);
	font-size: 1.1rem;
	margin-bottom: var(--rsv-spacing-md);
	padding-bottom: var(--rsv-spacing-xs);
	border-bottom: 2px solid var(--rsv-marron);
}

.rsv-footer-col ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

.rsv-footer-col li {
	margin-bottom: var(--rsv-spacing-xs);
}

.rsv-footer-contact-item {
	display: flex;
	align-items: flex-start;
	gap: var(--rsv-spacing-sm);
	margin-bottom: var(--rsv-spacing-sm);
}

.rsv-footer-contact-icon {
	font-size: 1.25rem;
	flex-shrink: 0;
}

.rsv-footer-bottom {
	border-top: 1px solid var(--rsv-marron);
	padding-top: var(--rsv-spacing-lg);
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	gap: var(--rsv-spacing-sm);
	font-size: 0.9rem;
	opacity: 0.9;
}

.rsv-footer-legal {
	display: flex;
	flex-wrap: wrap;
	gap: var(--rsv-spacing-sm);
}

.rsv-footer-legal a {
	opacity: 0.8;
}

.rsv-footer-legal a:hover {
	opacity: 1;
}

.rsv-footer-partenaires-grid img {
	max-height: 50px;
	width: auto;
	opacity: 0.8;
	transition: opacity var(--rsv-transition);
	/* Retirer le filtre blanc si présent */
	filter: none;
}

.rsv-footer-partenaires-grid img:hover {
	opacity: 1;
}

/* ==========================================================================
   Boutons
   ========================================================================== */

.rsv-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--rsv-spacing-xs);
	padding: 0.75rem 1.5rem;
	font-size: 1rem;
	font-weight: 600;
	text-decoration: none;
	border: none;
	border-radius: var(--rsv-radius-full);
	cursor: pointer;
	transition: all var(--rsv-transition);
	text-align: center;
}

.rsv-btn-primary {
	background: linear-gradient(135deg, var(--rsv-vert) 0%, var(--rsv-vert-fonce) 100%);
	color: var(--rsv-blanc);
}

.rsv-btn-primary:hover {
	background: linear-gradient(135deg, var(--rsv-vert-clair) 0%, var(--rsv-vert) 100%);
	color: var(--rsv-blanc);
	transform: translateY(-2px);
	box-shadow: var(--rsv-shadow-md);
}

.rsv-btn-secondary {
	background: linear-gradient(135deg, var(--rsv-jaune) 0%, var(--rsv-jaune-fonce) 100%);
	color: var(--rsv-marron-fonce);
}

.rsv-btn-secondary:hover {
	background: linear-gradient(135deg, var(--rsv-jaune-clair) 0%, var(--rsv-jaune) 100%);
	transform: translateY(-2px);
	box-shadow: var(--rsv-shadow-md);
}

.rsv-btn-outline {
	background: transparent;
	border: 2px solid var(--rsv-vert);
	color: var(--rsv-vert);
}

.rsv-btn-outline:hover {
	background: var(--rsv-vert);
	color: var(--rsv-blanc);
}

.rsv-btn-sm {
	padding: 0.5rem 1rem;
	font-size: 0.9rem;
}

.rsv-btn-lg {
	padding: 1rem 2rem;
	font-size: 1.1rem;
}

/* ==========================================================================
   Cartes
   ========================================================================== */

.rsv-card {
	background: var(--rsv-blanc);
	border-radius: var(--rsv-radius-lg);
	box-shadow: var(--rsv-shadow-sm);
	overflow: hidden;
	transition: all var(--rsv-transition);
}

.rsv-card:hover {
	box-shadow: var(--rsv-shadow-md);
	transform: translateY(-4px);
}

.rsv-card-image {
	width: 100%;
	height: 200px;
	object-fit: cover;
}

.rsv-card-content {
	padding: var(--rsv-spacing-md);
}

.rsv-card-title {
	font-size: 1.25rem;
	color: var(--rsv-marron-fonce);
	margin-bottom: var(--rsv-spacing-xs);
}

.rsv-card-meta {
	font-size: 0.9rem;
	color: var(--rsv-gris-fonce);
	margin-bottom: var(--rsv-spacing-sm);
}

.rsv-card-excerpt {
	color: var(--rsv-texte);
	margin-bottom: var(--rsv-spacing-sm);
}

/* ==========================================================================
   Formulaires
   ========================================================================== */

.rsv-form-group {
	margin-bottom: var(--rsv-spacing-md);
}

.rsv-form-group label {
	display: block;
	font-weight: 600;
	color: var(--rsv-marron-fonce);
	margin-bottom: var(--rsv-spacing-xs);
}

.rsv-form-group label .required {
	color: #c0392b;
}

.rsv-form-group input[type="text"],
.rsv-form-group input[type="email"],
.rsv-form-group input[type="tel"],
.rsv-form-group input[type="url"],
.rsv-form-group input[type="number"],
.rsv-form-group input[type="date"],
.rsv-form-group select,
.rsv-form-group textarea {
	width: 100%;
	padding: 0.75rem 1rem;
	font-size: 1rem;
	font-family: inherit;
	border: 2px solid var(--rsv-gris);
	border-radius: var(--rsv-radius-md);
	background: var(--rsv-blanc);
	transition: border-color var(--rsv-transition), box-shadow var(--rsv-transition);
}

.rsv-form-group input:focus,
.rsv-form-group select:focus,
.rsv-form-group textarea:focus {
	outline: none;
	border-color: var(--rsv-vert);
	box-shadow: 0 0 0 3px rgba(74, 124, 89, 0.15);
}

.rsv-form-group input[type="checkbox"],
.rsv-form-group input[type="radio"] {
	width: auto;
	display: inline-block;
	margin-right: 0.5rem;
}

.rsv-form-group textarea {
	resize: vertical;
	min-height: 120px;
}

.rsv-form-group select {
	cursor: pointer;
	appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23333' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 1rem center;
	padding-right: 2.5rem;
}

.rsv-form-checkbox {
	display: flex;
	align-items: flex-start;
	gap: var(--rsv-spacing-sm);
	cursor: pointer;
}

.rsv-form-checkbox input[type="checkbox"] {
	width: auto;
	margin-top: 0.25rem;
	flex-shrink: 0;
}

.rsv-form-row {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--rsv-spacing-md);
}

/* ==========================================================================
   Étoiles (notation avis)
   ========================================================================== */

.rsv-stars {
	display: inline-flex;
	gap: 2px;
}

.rsv-star {
	color: var(--rsv-etoile-vide);
	font-size: 1.25rem;
}

.rsv-star.filled {
	color: var(--rsv-etoile);
}

/* Étoiles interactives (formulaire) */
.rsv-stars-input {
	display: flex;
	gap: 4px;
	flex-direction: row-reverse;
	justify-content: flex-end;
}

.rsv-stars-input input {
	display: none;
}

.rsv-stars-input label {
	cursor: pointer;
	font-size: 1.75rem;
	color: var(--rsv-etoile-vide);
	transition: color var(--rsv-transition);
}

.rsv-stars-input label:hover,
.rsv-stars-input label:hover ~ label,
.rsv-stars-input input:checked ~ label {
	color: var(--rsv-etoile);
}

/* ==========================================================================
   Alertes et messages
   ========================================================================== */

.rsv-alert {
	padding: var(--rsv-spacing-md);
	border-radius: var(--rsv-radius-md);
	margin-bottom: var(--rsv-spacing-md);
}

.rsv-alert-success {
	background: #d4edda;
	color: #155724;
	border: 1px solid #c3e6cb;
}

.rsv-alert-error {
	background: #f8d7da;
	color: #721c24;
	border: 1px solid #f5c6cb;
}

.rsv-alert-warning {
	background: #fff3cd;
	color: #856404;
	border: 1px solid #ffeeba;
}

.rsv-alert-info {
	background: #d1ecf1;
	color: #0c5460;
	border: 1px solid #bee5eb;
}

/* ==========================================================================
   Pagination
   ========================================================================== */

.rsv-pagination {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: var(--rsv-spacing-xs);
	margin-top: var(--rsv-spacing-xl);
}

.rsv-pagination a,
.rsv-pagination span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 40px;
	padding: 0 var(--rsv-spacing-sm);
	border-radius: var(--rsv-radius-md);
	font-weight: 500;
	transition: all var(--rsv-transition);
}

.rsv-pagination a {
	background: var(--rsv-blanc);
	color: var(--rsv-texte);
	border: 1px solid var(--rsv-gris);
}

.rsv-pagination a:hover {
	background: var(--rsv-vert);
	color: var(--rsv-blanc);
	border-color: var(--rsv-vert);
}

.rsv-pagination .current {
	background: var(--rsv-vert);
	color: var(--rsv-blanc);
}

/* ==========================================================================
   CTA Band
   ========================================================================== */

.rsv-cta-band {
	background: linear-gradient(135deg, var(--rsv-vert) 0%, var(--rsv-vert-fonce) 100%);
	color: var(--rsv-blanc);
	padding: var(--rsv-spacing-xxl) 0;
	text-align: center;
}

.rsv-cta-band-content h2 {
	color: var(--rsv-blanc);
	font-size: 2rem;
	margin-bottom: var(--rsv-spacing-sm);
}

.rsv-cta-band-content p {
	font-size: 1.1rem;
	opacity: 0.9;
	margin-bottom: var(--rsv-spacing-lg);
}

.rsv-cta-band-buttons {
	display: flex;
	gap: var(--rsv-spacing-md);
	justify-content: center;
	flex-wrap: wrap;
}

/* ==========================================================================
   Responsive
   ========================================================================== */

@media (max-width: 992px) {
	.rsv-header-contact {
		display: none;
	}
	
	.rsv-nav {
		display: none;
		position: absolute;
		top: 100%;
		left: 0;
		right: 0;
		background: var(--rsv-blanc);
		padding: var(--rsv-spacing-md);
		box-shadow: var(--rsv-shadow-md);
	}
	
	.rsv-nav.active {
		display: block;
	}
	
	.rsv-nav .rsv-menu,
	.rsv-nav > ul {
		flex-direction: column;
		gap: 0;
	}
	
	.rsv-nav .rsv-menu > li,
	.rsv-nav > ul > li {
		width: 100%;
		border-bottom: 1px solid var(--rsv-beige-fonce);
	}
	
	.rsv-nav .rsv-menu > li:last-child,
	.rsv-nav > ul > li:last-child {
		border-bottom: none;
	}
	
	.rsv-nav .rsv-menu > li > a,
	.rsv-nav > ul > li > a {
		display: block;
		width: 100%;
		text-align: center;
		padding: var(--rsv-spacing-sm);
		border-radius: 0;
	}
	
	/* Sous-menus mobile */
	.rsv-nav .rsv-menu .sub-menu,
	.rsv-nav > ul ul {
		position: static;
		box-shadow: none;
		background: var(--rsv-beige);
		opacity: 1;
		visibility: visible;
		transform: none;
		border-radius: 0;
	}
	
	.rsv-nav .rsv-menu .sub-menu a,
	.rsv-nav > ul ul a {
		text-align: center;
		padding: var(--rsv-spacing-xs) var(--rsv-spacing-sm);
	}
	
	.rsv-menu-toggle {
		display: flex;
	}
	
	/* Animation burger -> X */
	.rsv-menu-toggle.active span:nth-child(1) {
		transform: rotate(45deg) translate(5px, 5px);
	}
	
	.rsv-menu-toggle.active span:nth-child(2) {
		opacity: 0;
	}
	
	.rsv-menu-toggle.active span:nth-child(3) {
		transform: rotate(-45deg) translate(7px, -7px);
	}
	
	.rsv-footer-grid {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 768px) {
	:root {
		--rsv-spacing-xl: 2rem;
		--rsv-spacing-xxl: 3rem;
	}
	
	.rsv-form-row {
		grid-template-columns: 1fr;
	}
	
	.rsv-footer-bottom {
		flex-direction: column;
		text-align: center;
	}
}

@media (max-width: 480px) {
	.rsv-logo img {
		height: 45px;
	}
	
	.rsv-logo-text {
		font-size: 1rem;
	}
	
	.rsv-btn {
		width: 100%;
	}
}

/* Admin bar offset */
.admin-bar .rsv-header {
	top: 32px;
}

@media (max-width: 782px) {
	.admin-bar .rsv-header {
		top: 46px;
	}
}
