<!DOCTYPE html>
<html lang="fr">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>Créer un séjour — 39€ HT | 5sur5 Séjour</title>
<meta name="description" content="Créez un espace séjour professionnel. Prix unique 39€ HT, jusqu'à 45 enfants.">
<link rel="shortcut icon" type="image/x-icon" href="/images/Logo.png">
<link rel="preconnect" href="https://fonts.googleapis.com">
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
<link href="https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap" rel="stylesheet">
<link href="{{ asset('Accueil/vendors/bootstrap/bootstrap.min.css') }}" rel="stylesheet">
<link href="{{ asset('Accueil/vendors/bootstrap-icons/font/bootstrap-icons.min.css') }}" rel="stylesheet">
<style>
:root {
--teal: #41A2AA;
--orange: #F56040;
--dark: #1a1a1a;
--gray: #687276;
--gray-light: #f8f9fa;
--border: #e9ecef;
--white: #ffffff;
}
* { box-sizing: border-box; }
body {
font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
color: var(--dark);
background: var(--white);
line-height: 1.6;
-webkit-font-smoothing: antialiased;
}
/* ========== HEADER MINIMAL ========== */
.header-minimal {
position: sticky;
top: 0;
z-index: 100;
background: rgba(255,255,255,0.95);
backdrop-filter: blur(10px);
border-bottom: 1px solid var(--border);
padding: 16px 0;
}
.header-minimal .container {
display: flex;
align-items: center;
justify-content: space-between;
}
.header-logo {
height: 32px;
}
.header-links {
display: flex;
align-items: center;
gap: 32px;
}
.header-link {
font-size: 14px;
font-weight: 500;
color: var(--gray);
text-decoration: none;
transition: color 0.2s;
}
.header-link:hover {
color: var(--dark);
}
.header-cta {
font-size: 14px;
font-weight: 600;
color: var(--white);
background: var(--dark);
padding: 10px 20px;
border-radius: 8px;
text-decoration: none;
transition: all 0.2s;
}
.header-cta:hover {
background: #333;
color: var(--white);
}
/* ========== HERO ========== */
.hero {
padding: 80px 0 60px;
text-align: center;
}
.hero-label {
display: inline-block;
font-size: 13px;
font-weight: 500;
color: var(--teal);
background: rgba(65, 162, 170, 0.1);
padding: 6px 14px;
border-radius: 20px;
margin-bottom: 24px;
}
.hero-title {
font-size: 48px;
font-weight: 700;
color: var(--dark);
letter-spacing: -0.02em;
margin: 0 0 16px;
line-height: 1.1;
}
.hero-subtitle {
font-size: 20px;
color: var(--gray);
max-width: 560px;
margin: 0 auto 40px;
font-weight: 400;
}
.hero-cta {
display: inline-flex;
align-items: center;
gap: 8px;
font-size: 16px;
font-weight: 600;
color: var(--white);
background: var(--teal);
padding: 16px 32px;
border-radius: 10px;
text-decoration: none;
transition: all 0.2s;
}
.hero-cta:hover {
background: #3a9199;
transform: translateY(-1px);
color: var(--white);
}
/* ========== PRICE CARD ========== */
.price-section {
padding: 40px 0 80px;
background: var(--gray-light);
}
.price-card {
max-width: 420px;
margin: 0 auto;
background: var(--white);
border: 1px solid var(--border);
border-radius: 16px;
padding: 40px;
text-align: center;
}
.price-amount {
font-size: 56px;
font-weight: 700;
color: var(--dark);
letter-spacing: -0.02em;
line-height: 1;
}
.price-amount span {
font-size: 24px;
font-weight: 500;
}
.price-details {
font-size: 14px;
color: var(--gray);
margin-top: 8px;
margin-bottom: 32px;
}
.price-features {
text-align: left;
margin: 0;
padding: 0;
list-style: none;
}
.price-features li {
display: flex;
align-items: flex-start;
gap: 12px;
padding: 12px 0;
font-size: 15px;
color: var(--dark);
border-bottom: 1px solid var(--border);
}
.price-features li:last-child {
border-bottom: none;
}
.price-features li::before {
content: '✓';
color: var(--teal);
font-weight: 600;
flex-shrink: 0;
}
/* ========== FEATURES ========== */
.features {
padding: 80px 0;
}
.features-grid {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 40px;
}
.feature {
text-align: center;
}
.feature-icon {
width: 48px;
height: 48px;
background: var(--gray-light);
border-radius: 12px;
display: flex;
align-items: center;
justify-content: center;
margin: 0 auto 16px;
}
.feature-icon i {
font-size: 22px;
color: var(--teal);
}
.feature-title {
font-size: 16px;
font-weight: 600;
color: var(--dark);
margin: 0 0 8px;
}
.feature-text {
font-size: 14px;
color: var(--gray);
margin: 0;
}
/* ========== FORM ========== */
.form-section {
padding: 80px 0;
background: var(--gray-light);
}
.form-card {
max-width: 680px;
margin: 0 auto;
background: var(--white);
border: 1px solid var(--border);
border-radius: 16px;
padding: 48px;
}
.form-header {
text-align: center;
margin-bottom: 40px;
}
.form-title {
font-size: 28px;
font-weight: 700;
color: var(--dark);
margin: 0 0 8px;
}
.form-subtitle {
font-size: 15px;
color: var(--gray);
margin: 0;
}
.form-section-label {
font-size: 12px;
font-weight: 600;
color: var(--teal);
text-transform: uppercase;
letter-spacing: 0.05em;
margin-bottom: 16px;
padding-top: 24px;
}
.form-section-label:first-of-type {
padding-top: 0;
}
.form-label {
font-size: 14px;
font-weight: 500;
color: var(--dark);
margin-bottom: 6px;
}
.form-control {
padding: 12px 14px;
font-size: 15px;
border: 1px solid var(--border);
border-radius: 8px;
transition: border-color 0.2s, box-shadow 0.2s;
}
.form-control:focus {
border-color: var(--teal);
box-shadow: 0 0 0 3px rgba(65, 162, 170, 0.1);
outline: none;
}
.form-control.is-invalid {
border-color: #dc3545;
}
.form-divider {
height: 1px;
background: var(--border);
margin: 32px 0;
}
/* Payment choice */
.payment-choice {
background: var(--gray-light);
border-radius: 12px;
padding: 24px;
margin: 24px 0;
}
.payment-option {
display: flex;
align-items: flex-start;
gap: 12px;
padding: 16px;
background: var(--white);
border: 1px solid var(--border);
border-radius: 8px;
margin-bottom: 12px;
cursor: pointer;
transition: border-color 0.2s;
}
.payment-option:last-child {
margin-bottom: 0;
}
.payment-option:hover {
border-color: var(--teal);
}
.payment-option.selected {
border-color: var(--teal);
background: rgba(65, 162, 170, 0.03);
}
.payment-option-content {
flex: 1;
}
.payment-option-title {
font-size: 15px;
font-weight: 600;
color: var(--dark);
margin: 0 0 2px;
}
.payment-option-text {
font-size: 13px;
color: var(--gray);
margin: 0;
}
.payment-badge {
font-size: 12px;
font-weight: 600;
color: var(--white);
background: var(--teal);
padding: 4px 10px;
border-radius: 4px;
}
/* Submit */
.btn-submit {
width: 100%;
padding: 16px;
font-size: 16px;
font-weight: 600;
color: var(--white);
background: var(--teal);
border: none;
border-radius: 10px;
cursor: pointer;
transition: background 0.2s;
margin-top: 24px;
}
.btn-submit:hover {
background: #3a9199;
}
.form-footer {
display: flex;
justify-content: center;
gap: 24px;
margin-top: 20px;
font-size: 13px;
color: var(--gray);
}
.form-footer span {
display: flex;
align-items: center;
gap: 6px;
}
/* ========== TRUST ========== */
.trust {
padding: 60px 0;
text-align: center;
}
.trust-label {
font-size: 13px;
color: var(--gray);
margin-bottom: 24px;
}
.trust-stats {
display: flex;
justify-content: center;
gap: 64px;
}
.trust-stat {
text-align: center;
}
.trust-stat-value {
font-size: 32px;
font-weight: 700;
color: var(--dark);
}
.trust-stat-label {
font-size: 14px;
color: var(--gray);
}
/* ========== FAQ ========== */
.faq {
padding: 80px 0;
background: var(--gray-light);
}
.faq-header {
text-align: center;
margin-bottom: 48px;
}
.faq-title {
font-size: 28px;
font-weight: 700;
color: var(--dark);
margin: 0;
}
.faq-list {
max-width: 640px;
margin: 0 auto;
}
.faq-item {
background: var(--white);
border: 1px solid var(--border);
border-radius: 10px;
margin-bottom: 12px;
overflow: hidden;
}
.faq-question {
width: 100%;
padding: 20px 24px;
font-size: 15px;
font-weight: 600;
color: var(--dark);
background: transparent;
border: none;
text-align: left;
cursor: pointer;
display: flex;
justify-content: space-between;
align-items: center;
}
.faq-question::after {
content: '+';
font-size: 20px;
color: var(--gray);
transition: transform 0.2s;
}
.faq-question[aria-expanded="true"]::after {
transform: rotate(45deg);
}
.faq-answer {
padding: 0 24px 20px;
font-size: 14px;
color: var(--gray);
line-height: 1.7;
}
/* ========== FOOTER ========== */
.footer {
padding: 48px 0;
border-top: 1px solid var(--border);
}
.footer-content {
display: flex;
justify-content: space-between;
align-items: center;
}
.footer-logo {
height: 28px;
opacity: 0.6;
}
.footer-links {
display: flex;
gap: 24px;
}
.footer-link {
font-size: 13px;
color: var(--gray);
text-decoration: none;
}
.footer-link:hover {
color: var(--dark);
}
.footer-copy {
font-size: 13px;
color: var(--gray);
}
/* ========== RESPONSIVE ========== */
@media (max-width: 768px) {
.hero-title { font-size: 32px; }
.hero-subtitle { font-size: 17px; }
.features-grid { grid-template-columns: 1fr; gap: 32px; }
.trust-stats { flex-direction: column; gap: 24px; }
.form-card { padding: 32px 24px; }
.header-links { display: none; }
.footer-content { flex-direction: column; gap: 24px; text-align: center; }
.footer-links { flex-wrap: wrap; justify-content: center; }
}
/* Hidden fields */
.visually-hidden { position: absolute; width: 1px; height: 1px; margin: -1px; padding: 0; overflow: hidden; clip: rect(0,0,0,0); border: 0; }
</style>
</head>
<body>
<!-- HEADER MINIMAL -->
<header class="header-minimal">
<div class="container">
<a href="{{ path('page_Accueil') }}">
<img src="/Accueil/imagesAccueil/logoHeader.png" alt="5sur5 Séjour" class="header-logo">
</a>
<div class="header-links">
<a href="{{ path('boite_vocale') }}" class="header-link">Boîte vocale</a>
<a href="{{ path('Besoindaide_5sur5_accueil') }}" class="header-link">Aide</a>
<a href="{{ path('app_back_Acommpa') }}" class="header-cta">Connexion</a>
</div>
</div>
</header>
<!-- HERO -->
<section class="hero">
<div class="container">
<span class="hero-label">Création simple</span>
<h1 class="hero-title">Créez un espace séjour professionnel</h1>
<p class="hero-subtitle">Partagez photos et vidéos avec les familles. Prix unique, sans surprise.</p>
<a href="#form" class="hero-cta">
Créer mon séjour — 39€ HT
</a>
</div>
</section>
<!-- PRICE CARD -->
<section class="price-section">
<div class="container">
<div class="price-card">
<div class="price-amount">39<span>€ HT</span></div>
<p class="price-details">Séjour jusqu'à 45 enfants — sans engagement</p>
<ul class="price-features">
<li>Conçu pour les séjours jusqu'à 45 enfants</li>
<li>Photos, vidéos et messages illimités</li>
<li>Hébergement sécurisé 100% France</li>
<li>Boîte vocale web incluse</li>
<li>Accès accompagnateurs illimités</li>
</ul>
</div>
</div>
</section>
<!-- FEATURES -->
<section class="features">
<div class="container">
<div class="features-grid">
<div class="feature">
<div class="feature-icon"><i class="bi bi-shield-check"></i></div>
<h3 class="feature-title">Sécurisé</h3>
<p class="feature-text">Données hébergées en France, conformité RGPD</p>
</div>
<div class="feature">
<div class="feature-icon"><i class="bi bi-phone"></i></div>
<h3 class="feature-title">Simple</h3>
<p class="feature-text">Publiez depuis votre téléphone en quelques secondes</p>
</div>
<div class="feature">
<div class="feature-icon"><i class="bi bi-people"></i></div>
<h3 class="feature-title">Illimité</h3>
<p class="feature-text">Autant d'accompagnateurs et de parents que nécessaire</p>
</div>
</div>
</div>
</section>
<!-- FORM -->
<section class="form-section" id="form">
<div class="container">
<div class="form-card">
<div class="form-header">
<h2 class="form-title">Créer mon espace séjour</h2>
<p class="form-subtitle">Remplissez ce formulaire, votre séjour sera prêt en quelques minutes</p>
</div>
<form method="post" action="{{ path('accomp_register') }}" novalidate id="creationSejourForm">
<input type="hidden" name="type_user" id="type_user_creation" value="PE">
<input type="hidden" name="idUser" value="PE">
<input type="hidden" name="_csrf_token" value="{{ csrf_token('authenticate') }}">
<input type="hidden" name="payer" id="payer_type" value="parents">
<!-- Coordonnées -->
<div class="form-section-label">Vos coordonnées</div>
<div class="row g-3">
<div class="col-md-6">
<label class="form-label">Nom <span class="text-danger">*</span></label>
<input type="text" class="form-control" id="nomAccompagnature" name="nom_acc" required>
</div>
<div class="col-md-6">
<label class="form-label">Prénom <span class="text-danger">*</span></label>
<input type="text" class="form-control" id="prenomAccompagnature" name="prenom_acc" required>
</div>
<div class="col-md-6">
<label class="form-label">Email <span class="text-danger">*</span></label>
<input type="email" class="form-control" id="mail" name="email" required>
<p style="display:none;color:#dc3545;font-size:13px;margin-top:4px;" id="eroor">Email déjà utilisé</p>
<div id="notification" style="display:none;color:#dc3545;font-size:13px;margin-top:4px;">Email invalide</div>
</div>
<div class="col-md-6">
<label class="form-label">Téléphone <span class="text-danger">*</span></label>
<input type="text" class="form-control masktelph" id="NumTelAcc" name="phone_acc" required>
</div>
<div class="col-md-6">
<label class="form-label">Fonction</label>
<select class="form-control" id="fonction" name="fonction">
<option value="">Sélectionner</option>
{% for fct in listeFonctions %}
<option value="{{ fct.id }}">{{ fct.name }}</option>
{% endfor %}
</select>
</div>
</div>
<div class="form-divider"></div>
<!-- Structure -->
<div class="form-section-label">Structure organisatrice</div>
<div class="row g-3">
<div class="col-md-6">
<label class="form-label">Nom de la structure</label>
<input type="text" class="form-control" id="etablisment" name="etablisment">
</div>
<div class="col-md-6">
<label class="form-label">Ville</label>
<input type="text" class="form-control" id="villeetablisment" name="villeetablisment">
</div>
<div class="col-md-8">
<label class="form-label">Adresse</label>
<input type="text" class="form-control" id="adressetablisment" name="adressetablisment">
</div>
<div class="col-md-4">
<label class="form-label">Code postal</label>
<input type="text" class="form-control masktetcode" id="CODEpOSTALetablisment" name="CODEpOSTALetablisment">
</div>
</div>
<div class="form-divider"></div>
<!-- Séjour -->
<div class="form-section-label">Informations du séjour</div>
<div id="accompSeulSejour">
<div class="row g-3">
<div class="col-md-6">
<label class="form-label">Thème du séjour <span class="text-danger">*</span></label>
<input type="text" id="themeSejour" name="theme_sejour" class="form-control" required>
</div>
<div class="col-md-6">
<label class="form-label">Nombre de participants</label>
<input type="number" min="1" max="45" id="NbEnfant" name="NbEnfant" class="form-control">
</div>
<div class="col-md-8">
<label class="form-label">Adresse du séjour</label>
<input type="text" id="AddresseSejour" name="adress_sejour" class="form-control">
</div>
<div class="col-md-4">
<label class="form-label">Code postal</label>
<input type="text" id="Codeposte" name="codePostal" class="form-control masktetcode">
</div>
<div class="col-md-6">
<label class="form-label">Pays <span class="text-danger">*</span></label>
<select id="selectPays" class="form-control" name="pays" required>
<option value="">Choisir</option>
<option value="France" selected>France</option>
<option value="Belgique">Belgique</option>
<option value="Suisse">Suisse</option>
<option value="Espagne">Espagne</option>
<option value="Italie">Italie</option>
<option value="Allemagne">Allemagne</option>
<option value="Autre">Autre</option>
</select>
</div>
<div class="col-md-6">
<label class="form-label">Ville du séjour</label>
<input type="text" id="VilleSejour" name="ville" class="form-control">
</div>
<div class="col-md-6">
<label class="form-label">Date de début <span class="text-danger">*</span></label>
<input type="date" id="date-range200" name="date_debut_sejour" class="form-control" required>
</div>
<div class="col-md-6">
<label class="form-label">Date de fin <span class="text-danger">*</span></label>
<input type="date" id="date-range201" name="date_fin_sejour" class="form-control" required>
</div>
<div class="col-12">
<label class="form-label">Âge des enfants</label>
<select id="selectAgeGroupe" class="form-control" name="age_dugroupe_sejour">
<option value="">Sélectionner</option>
<option value="entre 3 et 5">3 à 5 ans</option>
<option value="entre 5 et 8">5 à 8 ans</option>
<option value="entre 8 et 10">8 à 10 ans</option>
<option value="entre 10 et 15ans">10 à 15 ans</option>
<option value="Plus de 15ans">Plus de 15 ans</option>
</select>
</div>
</div>
<div id="dom-id"></div>
</div>
<input type="hidden" id="srcLogo" name="srcLogo">
<div class="form-divider"></div>
<!-- Payment choice -->
<div class="form-section-label">Paiement</div>
<div class="payment-choice">
<label class="payment-option selected" for="payer-structure">
<input class="form-check-input" type="radio" name="payer" id="payer-structure" value="structure" checked style="margin-top:3px;">
<div class="payment-option-content">
<p class="payment-option-title">La structure prend en charge</p>
<p class="payment-option-text">Paiement unique de 39€ HT</p>
</div>
<span class="payment-badge">39€ HT</span>
</label>
<label class="payment-option" for="payer-parents">
<input class="form-check-input" type="radio" name="payer" id="payer-parents" value="parents" style="margin-top:3px;">
<div class="payment-option-content">
<p class="payment-option-title">Les parents paient</p>
<p class="payment-option-text">Création gratuite</p>
</div>
</label>
</div>
<!-- Billing (structure only) -->
<div id="structure-billing-fields" class="d-none">
<div class="form-section-label">Facturation</div>
<div class="row g-3 mb-3">
<div class="col-md-6">
<label class="form-label">Email facturation <span class="text-danger">*</span></label>
<input type="email" class="form-control" id="billing_email" name="billing_email">
</div>
<div class="col-md-6">
<label class="form-label">Contact facturation <span class="text-danger">*</span></label>
<input type="text" class="form-control" id="billing_contact" name="billing_contact">
</div>
</div>
<div class="row g-3">
<div class="col-12">
<div class="form-check">
<input class="form-check-input" type="radio" name="payment_method_structure" id="payment_carte" value="carte" checked>
<label class="form-check-label" for="payment_carte">Carte bancaire — activation immédiate</label>
</div>
</div>
<div class="col-12">
<div class="form-check">
<input class="form-check-input" type="radio" name="payment_method_structure" id="payment_virement" value="virement">
<label class="form-check-label" for="payment_virement">Virement bancaire — activation sous 48h</label>
</div>
</div>
</div>
</div>
<button type="submit" class="btn-submit" id="btnCreationAccoSejour">
Créer mon espace séjour
</button>
<div class="form-footer">
<span><i class="bi bi-shield-check"></i> Paiement sécurisé</span>
<span><i class="bi bi-geo-alt"></i> Données en France</span>
</div>
</form>
</div>
</div>
</section>
<!-- TRUST -->
<section class="trust">
<div class="container">
<p class="trust-label">Ils nous font confiance depuis 2018</p>
<div class="trust-stats">
<div class="trust-stat">
<div class="trust-stat-value">500+</div>
<div class="trust-stat-label">Écoles</div>
</div>
<div class="trust-stat">
<div class="trust-stat-value">100K+</div>
<div class="trust-stat-label">Familles</div>
</div>
<div class="trust-stat">
<div class="trust-stat-value">4.7/5</div>
<div class="trust-stat-label">Note moyenne</div>
</div>
</div>
</div>
</section>
<!-- FAQ -->
<section class="faq">
<div class="container">
<div class="faq-header">
<h2 class="faq-title">Questions fréquentes</h2>
</div>
<div class="faq-list">
<div class="faq-item">
<button class="faq-question" type="button" data-bs-toggle="collapse" data-bs-target="#faq1" aria-expanded="false">
Pour combien d'enfants ?
</button>
<div class="collapse" id="faq1">
<div class="faq-answer">
La création simple est conçue pour les séjours jusqu'à 45 enfants. Idéal pour les classes vertes et voyages scolaires.
</div>
</div>
</div>
<div class="faq-item">
<button class="faq-question" type="button" data-bs-toggle="collapse" data-bs-target="#faq2" aria-expanded="false">
Que comprend le prix ?
</button>
<div class="collapse" id="faq2">
<div class="faq-answer">
39€ HT inclut : galerie photos/vidéos illimitée, boîte vocale web, accès accompagnateurs illimités, hébergement sécurisé en France.
</div>
</div>
</div>
<div class="faq-item">
<button class="faq-question" type="button" data-bs-toggle="collapse" data-bs-target="#faq3" aria-expanded="false">
Mes données sont-elles sécurisées ?
</button>
<div class="collapse" id="faq3">
<div class="faq-answer">
Oui. Données hébergées en France, conformité RGPD, chiffrement SSL, sauvegardes quotidiennes.
</div>
</div>
</div>
</div>
</div>
</section>
<!-- FOOTER -->
<footer class="footer">
<div class="container">
<div class="footer-content">
<img src="/Accueil/imagesAccueil/logoHeader.png" alt="5sur5 Séjour" class="footer-logo">
<div class="footer-links">
<a href="{{ path('Mentionlegale_5sur5') }}" class="footer-link">Mentions légales</a>
<a href="{{ path('Conditons_generales_5sur5') }}" class="footer-link">CGU</a>
<a href="{{ path('Politique_Confidentialite_5sur5') }}" class="footer-link">Confidentialité</a>
<a href="{{ path('Besoindaide_5sur5_accueil') }}" class="footer-link">Aide</a>
</div>
<span class="footer-copy">© 2025 5sur5 Séjour</span>
</div>
</div>
</footer>
<!-- Scripts -->
<script src="{{ asset('Accueil/vendors/bootstrap/bootstrap.bundle.min.js') }}"></script>
<script src="{{ asset('js/create-flow.js') }}"></script>
<script>
document.addEventListener('DOMContentLoaded', function() {
const options = document.querySelectorAll('.payment-option');
const structureRadio = document.getElementById('payer-structure');
const parentsRadio = document.getElementById('payer-parents');
const typeField = document.getElementById('type_user_creation');
const billingFields = document.getElementById('structure-billing-fields');
options.forEach(opt => {
opt.addEventListener('click', function() {
options.forEach(o => o.classList.remove('selected'));
this.classList.add('selected');
this.querySelector('input[type="radio"]').checked = true;
updateType();
});
});
function updateType() {
typeField.value = structureRadio.checked ? 'PF' : 'EP';
document.getElementById('payer_type').value = structureRadio.checked ? 'structure' : 'parents';
if (structureRadio.checked) {
billingFields.classList.remove('d-none');
document.getElementById('billing_email').required = true;
document.getElementById('billing_contact').required = true;
} else {
billingFields.classList.add('d-none');
document.getElementById('billing_email').required = false;
document.getElementById('billing_contact').required = false;
}
}
updateType();
// Masks
document.querySelectorAll('.masktelph').forEach(el => {
el.addEventListener('input', function() {
let v = this.value.replace(/\D/g, '').slice(0, 10);
let f = '';
for (let i = 0; i < v.length; i++) {
if (i > 0 && i % 2 === 0) f += ' ';
f += v[i];
}
this.value = f;
});
});
document.querySelectorAll('.masktetcode').forEach(el => {
el.addEventListener('input', function() {
this.value = this.value.replace(/\D/g, '').slice(0, 5);
});
});
});
</script>
</body>
</html>