/*
Theme Name:   Movedo Child
Theme URI:    https://themeforest.net/user/greatives
Description:  Movedo Child Theme
Version:      3.6.0
Author:       Greatives Team
Author URI:   https://greatives.eu
Template:     movedo
*/

#grve-header .grve-light .grve-logo .grve-light {
    filter: brightness(0) invert(1);
}

/* ====== Scope: form CF7 (aplica a todos). 
   Si añadiste html_class: wf-contact-form, quita la primera coma de cada selector y deja solo .wf-contact-form ... ====== */
.wpcf7-form,
.wf-contact-form .wpcf7-form {
  --field-bg: rgba(255,255,255,0.06);
  --field-border: rgba(99,102,241,0.25);
  --field-focus-ring: rgba(99,102,241,0.25);
  --field-text: #e5e7eb;
  --label-text: #cbd5e1;

  /* display: grid; */
  gap: 18px;
  max-width: 720px;
  margin: 0 auto;
}

/* Compacta <p> para que no meta huecos gigantes entre campos */
.wpcf7-form p,
.wf-contact-form .wpcf7-form p {
  margin: 0;
}

/* Dos columnas en desktop, una en móvil */
@media (min-width: 820px) {
  .wpcf7-form,
  .wf-contact-form .wpcf7-form {
    grid-template-columns: 1fr 1fr;
  }
  /* Campos que deben ocupar 2 columnas (asunto, mensaje, consentimiento, submit) */
  .wpcf7-form p:has([name="your-subject"]),
  .wpcf7-form p:has([name="your-message"]),
  .wpcf7-form p:has([name="rgpd-consent"]),
  .wpcf7-form p:has([type="submit"]),
  .wf-contact-form .wpcf7-form p:has([name="your-subject"]),
  .wf-contact-form .wpcf7-form p:has([name="your-message"]),
  .wf-contact-form .wpcf7-form p:has([name="rgpd-consent"]),
  .wf-contact-form .wpcf7-form p:has([type="submit"]) {
    grid-column: 1 / -1;
  }
}

/* Etiquetas: minimal tech */
.wpcf7-form label,
.wf-contact-form .wpcf7-form label {
  display: inline-block;
  font-size: 17px;
  letter-spacing: .06em;
  /* text-transform: uppercase; */
  /* color: var(--label-text); */
  margin: 10px 0 8px;
}

#grve-theme-wrapper input[type="text"], #grve-theme-wrapper input[type="input"], #grve-theme-wrapper input[type="password"], #grve-theme-wrapper input[type="number"], #grve-theme-wrapper input[type="email"], #grve-theme-wrapper input[type="number"], #grve-theme-wrapper input[type="url"], #grve-theme-wrapper input[type="tel"], #grve-theme-wrapper input[type="search"], #grve-theme-wrapper input[type="date"], #grve-theme-wrapper textarea, #grve-theme-wrapper select, #grve-theme-wrapper .select2-choice{
	font-size: 17px;
}

/* Inputs base */
.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form input[type="url"],
.wpcf7-form input[type="tel"],
.wpcf7-form input[type="file"],
.wpcf7-form select,
.wpcf7-form textarea,
.wf-contact-form .wpcf7-form input[type="text"],
.wf-contact-form .wpcf7-form input[type="email"],
.wf-contact-form .wpcf7-form input[type="url"],
.wf-contact-form .wpcf7-form input[type="tel"],
.wf-contact-form .wpcf7-form input[type="file"],
.wf-contact-form .wpcf7-form select,
.wf-contact-form .wpcf7-form textarea {
  width: 100%;
  padding: 14px 16px;
  border-radius: 14px;
  border: 1px solid var(--field-border);
  background: linear-gradient(180deg, rgba(255,255,255,0.07), rgba(255,255,255,0.03));
  color: var(--field-text);
  outline: none;
  transition: border-color .2s ease, box-shadow .2s ease, transform .05s ease;
  backdrop-filter: saturate(120%) blur(6px);
  -webkit-backdrop-filter: saturate(120%) blur(6px);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.08);
}

/* Placeholder más tenue */
.wpcf7-form ::placeholder,
.wf-contact-form .wpcf7-form ::placeholder {
  color: #284369;
}

/* Focus futurista con anillo + leve lift */
.wpcf7-form input:focus,
.wpcf7-form select:focus,
.wpcf7-form textarea:focus,
.wf-contact-form .wpcf7-form input:focus,
.wf-contact-form .wpcf7-form select:focus,
.wf-contact-form .wpcf7-form textarea:focus {
  border-color: var(--witflow-primary);
  box-shadow:
    0 0 0 3px var(--field-focus-ring),
    0 8px 24px -8px rgba(99,102,241,.35);
  transform: translateY(-1px);
}

form.wpcf7-form input, form.wpcf7-form select, form.wpcf7-form textarea {
    margin: 0 !important;
}

/* Select con flecha SVG */
.wpcf7-form select,
.wf-contact-form .wpcf7-form select {
  appearance: none;
  -webkit-appearance: none;
  background-image:
    url("data:image/svg+xml,%3Csvg width='20' height='20' viewBox='0 0 20 20' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M6 8l4 4 4-4' stroke='%23cbd5e1' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 40px;
}

/* Textarea más alto por defecto */
.wpcf7-form textarea,
.wf-contact-form .wpcf7-form textarea {
  min-height: 160px;
  resize: vertical;
}

/* File input con botón estilizado (donde soporte) */
.wpcf7-form input[type="file"]::-webkit-file-upload-button,
.wf-contact-form .wpcf7-form input[type="file"]::-webkit-file-upload-button {
  background: linear-gradient(135deg, var(--witflow-primary), var(--witflow-secondary));
  color: white;
  border: 0;
  border-radius: 10px;
  padding: 10px 14px;
  margin-right: 12px;
  cursor: pointer;
}
.wpcf7-form input[type="file"]::file-selector-button,
.wf-contact-form .wpcf7-form input[type="file"]::file-selector-button {
  background: linear-gradient(135deg, var(--witflow-primary), var(--witflow-secondary));
  color: white;
  border: 0;
  border-radius: 10px;
  padding: 10px 14px;
  margin-right: 12px;
  cursor: pointer;
}

/* Checkbox RGPD con accent-color (fallback a borde) */
.wpcf7-list-item input[type="checkbox"],
.wf-contact-form .wpcf7-list-item input[type="checkbox"] {
  accent-color: var(--witflow-primary);
  transform: translateY(2px);
}
.wpcf7-list-item-label a { color: var(--witflow-accent); text-decoration: underline; }

/* Botón enviar estilo “chip futurista” */
.wpcf7-form .wpcf7-submit,
.wf-contact-form .wpcf7-form .wpcf7-submit,
.wf-submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  border: 0;
  border-radius: 999px;
  padding: 14px 22px;
  font-weight: 600;
  letter-spacing: .02em;
  color: #fff;
  background: linear-gradient(135deg, var(--witflow-primary), var(--witflow-secondary));
  box-shadow:
    0 10px 24px -10px rgba(99,102,241,.55),
    inset 0 1px 0 rgba(255,255,255,.15);
  cursor: pointer;
  transition: transform .08s ease, box-shadow .15s ease, filter .2s ease;
}
.wpcf7-form .wpcf7-submit:hover,
.wf-contact-form .wpcf7-form .wpcf7-submit:hover,
.wf-submit:hover {
  transform: translateY(-1px);
  box-shadow:
    0 14px 28px -10px rgba(139,92,246,.55),
    inset 0 1px 0 rgba(255,255,255,.2);
  filter: saturate(115%);
}
.wpcf7-form .wpcf7-submit:disabled,
.wf-contact-form .wpcf7-form .wpcf7-submit:disabled,
.wf-submit:disabled {
  opacity: .6;
  cursor: not-allowed;
}

/* Spinner CF7 discreto */
.wpcf7-spinner {
  margin-left: 10px;
  filter: drop-shadow(0 2px 6px rgba(0,0,0,.2));
}

/* Mensajes de estado (éxito / error) */
.wpcf7 form .wpcf7-response-output,
.wf-contact-form .wpcf7 form .wpcf7-response-output {
  margin: 8px 0 0;
  border-radius: 12px;
  border: 1px solid transparent;
  padding: 12px 14px;
  font-size: 17px;
  line-height: 1.4;
}
.wpcf7 form .wpcf7-mail-sent-ok,
.wf-contact-form .wpcf7 form .wpcf7-mail-sent-ok {
  background: linear-gradient(180deg, rgba(16,185,129,.12), rgba(16,185,129,.06));
  border-color: rgba(16,185,129,.35);
  color: #0f5132;
}
.wpcf7 form .wpcf7-aborted,
.wpcf7 form .wpcf7-validation-errors,
.wpcf7 form .wpcf7-acceptance-missing,
.wf-contact-form .wpcf7 form .wpcf7-aborted,
.wf-contact-form .wpcf7 form .wpcf7-validation-errors,
.wf-contact-form .wpcf7 form .wpcf7-acceptance-missing {
  background: linear-gradient(180deg, rgba(239,68,68,.12), rgba(239,68,68,.06));
  border-color: rgba(239,68,68,.35);
  color: #7f1d1d;
}

/* Errores por campo */
span.wpcf7-not-valid-tip {
  display: block;
  margin-top: 6px;
  font-size: 17px;
  color: #ef4444;
}

/* Estado válido/invalid (borde) */
.wpcf7-form .wpcf7-not-valid,
.wf-contact-form .wpcf7-form .wpcf7-not-valid {
  border-color: rgba(239,68,68,.6) !important;
}
.wpcf7-form .wpcf7-validates-as-required:not(.wpcf7-not-valid) {}

/* Accesibilidad: focus visible marcado */
.wpcf7-form :focus-visible {
  outline: 2px dashed var(--witflow-accent);
  outline-offset: 2px;
}

/* Reducción de movimiento */
@media (prefers-reduced-motion: reduce) {
  .wpcf7-form * { transition: none !important; }
}

/* Dark mode opcional si tu sitio lo usa */
@media (prefers-color-scheme: dark) {
  .wpcf7-form,
  .wf-contact-form .wpcf7-form {
    --field-bg: rgba(255,255,255,0.04);
    --field-text: #e5e7eb;
    --label-text: #cbd5e1;
  }
}