body:not(.rtl) .elementor-148070203 .elementor-element.elementor-element-ttmengo .elementor-drop-cap{margin-right:10px;}body.rtl .elementor-148070203 .elementor-element.elementor-element-ttmengo .elementor-drop-cap{margin-left:10px;}/* Start custom CSS for html, class: .elementor-element-poquveh *//* ========================================================= */
/* STYLE GLOBAL FORM */
/* ========================================================= */
#sav-form {
  max-width: 700px;
  margin: auto;
  background: #ffffff;
  padding: 30px 40px;
  border-radius: 12px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
  font-family: "Roboto", Arial, sans-serif;
}

/* --- Labels --- */
#sav-form label {
  display: block;
  margin-top: 25px;
  font-size: 16px;
  font-weight: 500;
  color: #3c4043;
}

/* --- Inputs / Textareas / Selects --- */
#sav-form input,
#sav-form select,
#sav-form textarea {
  width: 100%;
  padding: 14px 16px;
  margin-top: 8px;
  font-size: 16px;
  border: 1px solid #dadce0;
  border-radius: 8px;
  background: #fff;
  color: #202124;
  box-sizing: border-box;
  transition: all 0.2s ease;
}

/* Hover + Focus */
#sav-form input:focus,
#sav-form textarea:focus,
#sav-form select:focus {
  outline: none;
  border-color: #1a73e8;
  box-shadow: 0 0 0 3px rgba(26, 115, 232, 0.2);
}

/* Textarea */
#sav-form textarea {
  min-height: 120px;
  resize: vertical;
}

/* --- Button --- */
#sav-form button {
  margin-top: 35px;
  padding: 12px 26px;
  background-color: #ff0000;
  color: white;
  font-size: 16px;
  font-weight: 500;
  border: none;
  border-radius: 8px;
  cursor: pointer;
  transition: 0.2s ease;
}

#sav-form button:hover {
  background-color: #1668d6;
}

#sav-form button:active {
  background-color: #0f5cc0;
}

/* Fix padding datetime */
#sav-form input[type="datetime-local"] {
  padding: 10px;
}

/* ========================================================= */
/* STYLE DU CHAMP INTELLIGENT SEARCH */
/* ========================================================= */
.smart-product-search {
  position: relative;
  width: 100%;
  overflow: visible !important;
}

/* Icône de loupe */
.search-icon {
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 18px;
  opacity: 0.55;
  pointer-events: none;
}

/* Ajustement padding input à cause de la loupe */
.smart-product-search input {
  padding-left: 42px !important;
}

/* Loader animé */
.loader {
  display: none;
  position: absolute;
  right: 14px;
  top: 50%;
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  border: 3px solid #1a73e8;
  border-top-color: transparent;
  border-radius: 50%;
  animation: smart-spin 0.7s linear infinite;
}

@keyframes smart-spin {
  to {
    transform: translateY(-50%) rotate(360deg);
  }
}

/* ========================================================= */
/* LISTE DÉROULANTE DES RÉSULTATS SEARCH */
/* ========================================================= */
.smart-results {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  width: 100%;
  max-height: 280px;
  overflow-y: auto;
  background: #fff;
  border: 1px solid #dadce0;
  border-radius: 8px;
  list-style: none;
  padding: 0;
  margin: 0;
  z-index: 9999;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
}

.smart-results li {
  padding: 12px 14px;
  font-size: 15px;
  color: #202124;
  border-bottom: 1px solid #f1f3f4;
  cursor: pointer;
  transition: background 0.15s ease;
}

.smart-results li:hover {
  background: #f6f9fe;
}

.smart-results li:last-child {
  border-bottom: none;
}

.smart-results strong {
  font-size: 15px;
  color: #1a73e8;
  display: block;
  margin-bottom: 3px;
}

.smart-results small {
  color: #5f6368;
}

/* ========================================================= */
/* CHAMPS OBLIGATOIRES */
/* ========================================================= */
label:has(+ input[required]),
label:has(+ textarea[required]),
label:has(+ select[required]) {
  position: relative;
}

label:has(+ input[required])::after,
label:has(+ textarea[required])::after,
label:has(+ select[required])::after {
  content: " *";
  color: #b30000;
  font-weight: bold;
}

/* ========================================================= */
/* VALIDATION */
/* ========================================================= */
.field-error {
  border: 2px solid #b30000 !important;
  background-color: #fff6f6;
}

input:invalid,
textarea:invalid,
select:invalid {
  box-shadow: none;
}

/* ========================================================= */
/* HINTS */
/* ========================================================= */
.form-hint {
  display: block;
  margin-top: 6px;
  font-size: 12px;
  color: #666;
}

/* ========================================================= */
/* FIX OVERFLOW PRESTASHOP */
/* ========================================================= */
#sav-form {
  overflow: visible !important;
}

/* ========================================================= */
/* CHECKBOX CONDITIONS */
/* ========================================================= */
.checkbox-row {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-top: 18px;
}

.checkbox-row input[type="checkbox"] {
  width: 18px;
  min-width: 18px;
  height: 18px;
  margin: 2px 0 0 0;
  padding: 0;
  flex: 0 0 18px;
}

.checkbox-row label {
  display: block;
  margin: 0 !important;
  font-size: 16px;
  line-height: 1.45;
  font-weight: 500;
  color: #3c4043;
}/* End custom CSS */