/*--------------------------------------------------------------
# GLOBAL FORM STYLES — unified across all pages
# Reference: rendez-vous page (dark theme, Figtree/Barlow font)
# NOTE: .page-light overrides restore white-background pages
--------------------------------------------------------------*/

/* ── Variables ── */
:root {
  --form-bg:          rgba(255, 255, 255, 0.05);
  --form-bg-focus:    rgba(255, 255, 255, 0.08);
  --form-border:      rgba(255, 255, 255, 0.15);
  --form-border-focus:rgba(255, 255, 255, 0.9);
  --form-border-accent:var(--tecture-base, #c3d200);
  --form-text:        #b6b6b6;
  --form-text-focus:  #ffffff;
  --form-placeholder: rgba(182, 182, 182, 0.5);
  --form-label-color: rgba(255, 255, 255, 0.75);
  --form-error:       #ef4444;
  --form-success:     #10b981;
  --form-radius:      0px;
  --form-padding:     18px 25px;
  --form-font-size:   1rem;
  --form-font:        "Figtree", sans-serif;
  --form-label-font:  "Barlow Semi Condensed", sans-serif;
  --form-transition:  all 0.3s ease;
}

/* ── Label ── */
.gf-label,
.form-label,
.field-label,
.form-group label,
.contact-one__input-box label {
  display: block;
  font-family: var(--form-label-font);
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--form-label-color);
  text-transform: uppercase;
  letter-spacing: 1.5px;
  margin-bottom: 10px;
}

.gf-label span,
.field-label span,
.form-label.required::after {
  content: " *";
  color: var(--form-border-accent);
}

/* ── Base input / textarea / select ── */
.gf-input,
.form-control,
.form-select,
.form-input,
.form-textarea,
.contact-one__input-box input,
.contact-one__input-box textarea,
.contact-one__input-box select,
.form-group input,
.form-group select,
.form-group textarea {
  width: 100%;
  font-family: var(--form-font) !important;
  font-size: var(--form-font-size) !important;
  font-weight: 400;
  color: var(--form-text) !important;
  background: var(--form-bg) !important;
  border: 2px solid var(--form-border) !important;
  border-radius: var(--form-radius) !important;
  padding: var(--form-padding) !important;
  transition: var(--form-transition) !important;
  outline: none !important;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  box-shadow: none !important;
  line-height: 1.5;
}

/* ── Placeholder ── */
.gf-input::placeholder,
.form-control::placeholder,
.form-input::placeholder,
.form-textarea::placeholder,
.contact-one__input-box input::placeholder,
.contact-one__input-box textarea::placeholder,
.form-group input::placeholder,
.form-group textarea::placeholder {
  color: var(--form-placeholder) !important;
  font-family: var(--form-font) !important;
  font-size: var(--form-font-size) !important;
}

/* ── Focus ── */
.gf-input:focus,
.form-control:focus,
.form-select:focus,
.form-input:focus,
.form-textarea:focus,
.contact-one__input-box input:focus,
.contact-one__input-box textarea:focus,
.contact-one__input-box select:focus,
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  background: var(--form-bg-focus) !important;
  border-color: var(--form-border-focus) !important;
  color: var(--form-text-focus) !important;
  box-shadow: 0 0 0 4px rgba(255, 255, 255, 0.08) !important;
}

/* ── Hover ── */
.gf-input:hover,
.form-control:hover,
.form-select:hover,
.form-input:hover,
.form-textarea:hover,
.contact-one__input-box input:hover,
.contact-one__input-box textarea:hover,
.form-group input:hover,
.form-group select:hover,
.form-group textarea:hover {
  border-color: rgba(255, 255, 255, 0.3) !important;
}

/* ── Textarea ── */
textarea.gf-input,
textarea.form-control,
textarea.form-input,
textarea.form-textarea,
.contact-one__input-box textarea,
.form-group textarea {
  min-height: 150px !important;
  resize: vertical;
}

/* ── Select arrow ── */
select.gf-input,
.form-control.form-select,
.form-select,
.form-group select {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23ffffff' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e") !important;
  background-repeat: no-repeat !important;
  background-position: right 20px center !important;
  background-size: 14px 10px !important;
  padding-right: 50px !important;
  cursor: pointer;
}

/* ── Select options ── */
.form-group select option,
.form-select option,
.form-input option {
  background-color: #151817 !important;
  color: #ffffff !important;
  font-family: var(--form-font);
}

.form-group select option:checked,
.form-select option:checked {
  background: #c3d200 !important;
  color: #000000 !important;
}

/* ── Validation states ── */
.gf-input.is-invalid,
.form-control.is-invalid,
.form-input.is-invalid,
.form-group input.is-invalid,
.form-group select.is-invalid,
.form-group textarea.is-invalid {
  border-color: var(--form-error) !important;
}

.gf-input.is-valid,
.form-control.is-valid,
.form-input.is-valid {
  border-color: var(--form-success) !important;
}

.invalid-feedback,
.text-danger.small,
.error-message {
  color: var(--form-error);
  font-family: var(--form-font);
  font-size: 0.8rem;
  margin-top: 6px;
  display: block;
}

/* ── Checkbox / Radio ── */
.form-check-input,
.checkbox-input {
  width: 18px;
  height: 18px;
  cursor: pointer;
  accent-color: var(--tecture-base, #c3d200);
  border: 2px solid var(--form-border);
  background: var(--form-bg);
}

.form-check-input:checked {
  background-color: var(--tecture-base, #c3d200) !important;
  border-color: var(--tecture-base, #c3d200) !important;
}

.form-check-label,
.checkbox-label {
  font-family: var(--form-font);
  font-size: 0.9rem;
  color: var(--form-text);
  line-height: 1.5;
}

.form-check-label a,
.checkbox-label a {
  color: var(--tecture-base, #c3d200);
  text-decoration: none;
}

.form-check-label a:hover,
.checkbox-label a:hover {
  opacity: 0.8;
  text-decoration: underline;
}

/* ── Field wrapper spacing ── */
.form-group,
.field-group,
.contact-one__input-box {
  margin-bottom: 1.5rem;
}

/* ── Responsive ── */
@media (max-width: 768px) {
  :root {
    --form-padding: 15px 18px;
    --form-font-size: 0.95rem;
  }
}

@media (max-width: 480px) {
  :root {
    --form-padding: 13px 16px;
    --form-font-size: 0.9rem;
  }
}

/*--------------------------------------------------------------
# LIGHT THEME OVERRIDE — for white-background pages (devis, etc.)
# Applied via .page-light class on body or a wrapper
--------------------------------------------------------------*/
.quote-section .form-control,
.quote-section .form-select,
.quote-section .form-input,
.quote-section .form-textarea,
.quote-section .form-group input,
.quote-section .form-group select,
.quote-section .form-group textarea {
  background: #ffffff !important;
  border: 1px solid #e5e5e5 !important;
  color: #262626 !important;
  border-radius: 12px !important;
  padding: 0.8rem 1rem !important;
  font-size: 0.95rem !important;
}

.quote-section .form-control:focus,
.quote-section .form-select:focus,
.quote-section .form-input:focus,
.quote-section .form-textarea:focus,
.quote-section .form-group input:focus,
.quote-section .form-group select:focus,
.quote-section .form-group textarea:focus {
  background: #ffffff !important;
  border-color: #ff6b35 !important;
  color: #171717 !important;
  box-shadow: 0 0 0 3px rgba(255,107,53,0.1) !important;
}

.quote-section .form-control::placeholder,
.quote-section .form-input::placeholder,
.quote-section .form-textarea::placeholder,
.quote-section .form-group input::placeholder,
.quote-section .form-group textarea::placeholder {
  color: #a3a3a3 !important;
}

.quote-section .form-control:hover,
.quote-section .form-select:hover,
.quote-section .form-group input:hover,
.quote-section .form-group select:hover,
.quote-section .form-group textarea:hover {
  border-color: #d4d4d4 !important;
}

.quote-section .form-label,
.quote-section .form-group label {
  color: #404040 !important;
  font-size: 0.8rem !important;
  text-transform: uppercase !important;
  letter-spacing: 0.3px !important;
  font-weight: 500 !important;
  font-family: "Figtree", sans-serif !important;
}

.quote-section .form-label.required::after {
  color: #ff6b35 !important;
}

.quote-section select.form-control,
.quote-section .form-select,
.quote-section .form-group select {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23737373' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e") !important;
  background-color: #ffffff !important;
}

.quote-section .form-group select option,
.quote-section .form-select option {
  background-color: #ffffff !important;
  color: #262626 !important;
}

.quote-section .form-check-input {
  background: #ffffff !important;
  border-color: #d4d4d4 !important;
  accent-color: #ff6b35;
}

.quote-section .form-check-label,
.quote-section .checkbox-label {
  color: #404040 !important;
  text-transform: none !important;
  letter-spacing: normal !important;
  font-weight: 400 !important;
}

.quote-section .form-check-label a,
.quote-section .checkbox-label a {
  color: #ff6b35 !important;
}

.quote-section textarea.form-control,
.quote-section .form-textarea {
  min-height: 100px !important;
}


/* ── Variables ── */
:root {
  --form-bg:          rgba(255, 255, 255, 0.05);
  --form-bg-focus:    rgba(255, 255, 255, 0.08);
  --form-border:      rgba(255, 255, 255, 0.15);
  --form-border-focus:rgba(255, 255, 255, 0.9);
  --form-border-accent:var(--tecture-base, #c3d200);
  --form-text:        #b6b6b6;
  --form-text-focus:  #ffffff;
  --form-placeholder: rgba(182, 182, 182, 0.5);
  --form-label-color: rgba(255, 255, 255, 0.75);
  --form-error:       #ef4444;
  --form-success:     #10b981;
  --form-radius:      0px;
  --form-padding:     18px 25px;
  --form-font-size:   1rem;
  --form-font:        "Figtree", sans-serif;
  --form-label-font:  "Barlow Semi Condensed", sans-serif;
  --form-transition:  all 0.3s ease;
}

/* ── Label ── */
.gf-label,
.form-label,
.field-label,
.form-group label,
.contact-one__input-box label {
  display: block;
  font-family: var(--form-label-font);
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--form-label-color);
  text-transform: uppercase;
  letter-spacing: 1.5px;
  margin-bottom: 10px;
}

.gf-label span,
.field-label span,
.form-label.required::after {
  content: " *";
  color: var(--form-border-accent);
}

/* ── Base input / textarea / select ── */
.gf-input,
.form-control,
.form-select,
.form-input,
.form-textarea,
.contact-one__input-box input,
.contact-one__input-box textarea,
.contact-one__input-box select,
.form-group input,
.form-group select,
.form-group textarea {
  width: 100%;
  font-family: var(--form-font) !important;
  font-size: var(--form-font-size) !important;
  font-weight: 400;
  color: var(--form-text) !important;
  background: var(--form-bg) !important;
  border: 2px solid var(--form-border) !important;
  border-radius: var(--form-radius) !important;
  padding: var(--form-padding) !important;
  transition: var(--form-transition) !important;
  outline: none !important;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  box-shadow: none !important;
  line-height: 1.5;
}

/* ── Placeholder ── */
.gf-input::placeholder,
.form-control::placeholder,
.form-input::placeholder,
.form-textarea::placeholder,
.contact-one__input-box input::placeholder,
.contact-one__input-box textarea::placeholder,
.form-group input::placeholder,
.form-group textarea::placeholder {
  color: var(--form-placeholder) !important;
  font-family: var(--form-font) !important;
  font-size: var(--form-font-size) !important;
}

/* ── Focus ── */
.gf-input:focus,
.form-control:focus,
.form-select:focus,
.form-input:focus,
.form-textarea:focus,
.contact-one__input-box input:focus,
.contact-one__input-box textarea:focus,
.contact-one__input-box select:focus,
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  background: var(--form-bg-focus) !important;
  border-color: var(--form-border-focus) !important;
  color: var(--form-text-focus) !important;
  box-shadow: 0 0 0 4px rgba(255, 255, 255, 0.08) !important;
}

/* ── Hover ── */
.gf-input:hover,
.form-control:hover,
.form-select:hover,
.form-input:hover,
.form-textarea:hover,
.contact-one__input-box input:hover,
.contact-one__input-box textarea:hover,
.form-group input:hover,
.form-group select:hover,
.form-group textarea:hover {
  border-color: rgba(255, 255, 255, 0.3) !important;
}

/* ── Textarea ── */
textarea.gf-input,
textarea.form-control,
textarea.form-input,
textarea.form-textarea,
.contact-one__input-box textarea,
.form-group textarea {
  min-height: 150px !important;
  resize: vertical;
}

/* ── Select arrow ── */
select.gf-input,
.form-control.form-select,
.form-select,
.form-group select {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23ffffff' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e") !important;
  background-repeat: no-repeat !important;
  background-position: right 20px center !important;
  background-size: 14px 10px !important;
  padding-right: 50px !important;
  cursor: pointer;
}

/* ── Select options ── */
.form-group select option,
.form-select option,
.form-input option {
  background-color: #151817 !important;
  color: #ffffff !important;
  font-family: var(--form-font);
}

.form-group select option:checked,
.form-select option:checked {
  background: #c3d200 !important;
  color: #000000 !important;
}

/* ── Validation states ── */
.gf-input.is-invalid,
.form-control.is-invalid,
.form-input.is-invalid,
.form-group input.is-invalid,
.form-group select.is-invalid,
.form-group textarea.is-invalid {
  border-color: var(--form-error) !important;
}

.gf-input.is-valid,
.form-control.is-valid,
.form-input.is-valid {
  border-color: var(--form-success) !important;
}

.invalid-feedback,
.text-danger.small,
.error-message {
  color: var(--form-error);
  font-family: var(--form-font);
  font-size: 0.8rem;
  margin-top: 6px;
  display: block;
}

/* ── Checkbox / Radio ── */
.form-check-input,
.checkbox-input {
  width: 18px;
  height: 18px;
  cursor: pointer;
  accent-color: var(--tecture-base, #c3d200);
  border: 2px solid var(--form-border);
  background: var(--form-bg);
}

.form-check-input:checked {
  background-color: var(--tecture-base, #c3d200) !important;
  border-color: var(--tecture-base, #c3d200) !important;
}

.form-check-label,
.checkbox-label {
  font-family: var(--form-font);
  font-size: 0.9rem;
  color: var(--form-text);
  line-height: 1.5;
}

.form-check-label a,
.checkbox-label a {
  color: var(--tecture-base, #c3d200);
  text-decoration: none;
}

.form-check-label a:hover,
.checkbox-label a:hover {
  opacity: 0.8;
  text-decoration: underline;
}

/* ── Field wrapper spacing ── */
.form-group,
.field-group,
.contact-one__input-box {
  margin-bottom: 1.5rem;
}

/* ── Responsive ── */
@media (max-width: 768px) {
  :root {
    --form-padding: 15px 18px;
    --form-font-size: 0.95rem;
  }
}

@media (max-width: 480px) {
  :root {
    --form-padding: 13px 16px;
    --form-font-size: 0.9rem;
  }
}
