

/* ── CSS Variables ── */
:root {
  --gcf-gold:        #BD7B1D;
  --gcf-gold-dark:   #A25803;
  --gcf-gold-light:  #D89A34;
  --gcf-border:      #222222;
  --gcf-bg:          #ffffff00;
  --gcf-input-bg:    #ffffff;
  --gcf-text:        #1f2937;
  --gcf-placeholder: #9ca3af;
  --gcf-label:       #111827;
  --gcf-radius:      12px;
}

/* ── Wrapper ── */
.wpcf7,
.gcf-wrapper {
  font-family: var(--gcf-font);
  max-width: 900px;
  margin: 0 auto;
  padding: 20px 12px;
  background: var(--gcf-bg);
  border-radius: 16px;
}

.wpcf7 br {
    display: none;
}

/* ── Grid Layout ── */
.gcf-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px 28px;
  margin-bottom: 20px;
}

.gcf-full {
  margin-bottom: 20px;
}

@media (max-width: 640px) {
  .gcf-row {
    grid-template-columns: 1fr;
  }
}

/* ── Labels ── */
.wpcf7 label,
.gcf-row label,
.gcf-full label {
  display: block;
  font-size: 14px;
  font-weight: 700;
  color: var(--gcf-label);
  margin-bottom: 8px;
  letter-spacing: 0.01em;
}

.required {
  color: var(--gcf-gold);
}

/* ── Text / Email / Tel Inputs ── */
.wpcf7 input[type="text"],
.wpcf7 input[type="email"],
.wpcf7 input[type="tel"],
.wpcf7 input[type="url"],
.wpcf7 input[type="number"] {
  width: 100%;
  padding: 14px 16px;
  font-family: var(--gcf-font);
  font-size: 14px;
  color: var(--gcf-text);
  background: var(--gcf-input-bg);
  border: 2px solid var(--gcf-border);
  border-radius: var(--gcf-radius);
  outline: none;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  box-sizing: border-box;
}

.wpcf7 input[type="text"]::placeholder,
.wpcf7 input[type="email"]::placeholder,
.wpcf7 input[type="tel"]::placeholder {
  color: var(--gcf-placeholder);
  font-weight: 400;
}

.wpcf7 input[type="text"]:focus,
.wpcf7 input[type="email"]:focus,
.wpcf7 input[type="tel"]:focus {
  border-color: var(--gcf-gold);
  box-shadow: 0 0 0 3px rgba(184, 137, 42, 0.15);
}

/* ── Select Dropdowns ── */
.wpcf7 select {
  width: 100%;
  padding: 14px 42px 14px 16px;
  font-family: var(--gcf-font);
  font-size: 14px;
  color: var(--gcf-placeholder);
  background: var(--gcf-input-bg);
  border: 2px solid var(--gcf-border);
  border-radius: var(--gcf-radius);
  outline: none;
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  cursor: pointer;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  box-sizing: border-box;
}

.wpcf7 select:focus {
  border-color: var(--gcf-gold);
  box-shadow: 0 0 0 3px rgba(184, 137, 42, 0.15);
  color: var(--gcf-text);
}

.wpcf7 select option {
  color: var(--gcf-text);
}

.wpcf7 select option:first-child {
  color: var(--gcf-placeholder);
}

/* ── File Upload ── */
.wpcf7 input[type="file"],
.wpcf7 .gcf-file-input {
  width: 100%;
  padding: 14px 16px;
  font-family: var(--gcf-font);
  font-size: 14px;
  color: var(--gcf-placeholder);
  background: var(--gcf-input-bg);
  border: 1.5px solid var(--gcf-border);
  border-radius: var(--gcf-radius);
  cursor: pointer;
  box-sizing: border-box;
  position: relative;
  transition: border-color 0.2s ease;
}

/* Attach Document wrapper with icon */
.gcf-full .wpcf7-form-control-wrap {
  position: relative;
  display: block;
}

.wpcf7 input[type="file"]:focus {
  border-color: var(--gcf-gold);
  outline: none;
}

.gcf-hint {
  font-size: 12px;
  color: var(--gcf-placeholder);
  margin-top: 6px;
  line-height: 1.5;
}

.wpcf7-form-control-wrap[data-name="document"] {
  display: block;
  position: relative;
  min-height: 50px;
}

.wpcf7-form-control-wrap[data-name="document"]::before {
  content: "Attach Document";
  display: block;
  width: 100%;
  padding: 14px 52px 14px 16px;
  font-family: var(--gcf-font);
  font-size: 14px;
  color: var(--gcf-placeholder);
  background: var(--gcf-input-bg);
  border: 2px solid var(--gcf-border);
  border-radius: var(--gcf-radius);
  box-sizing: border-box;
  line-height: 1.4;
  min-height: 50px;
  pointer-events: none;
}

.wpcf7-form-control-wrap[data-name="document"]::after {
  content: "";
  position: absolute;
  right: 14px;
  top: 50%;
  transform: translateY(-50%);
  width: 22px;
  height: 22px;
  background-color: var(--gcf-gold);
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 15v4a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-4'/%3E%3Cpolyline points='17 8 12 3 7 8'/%3E%3Cline x1='12' y1='3' x2='12' y2='15'/%3E%3C/svg%3E");
  mask-repeat: no-repeat;
  mask-size: contain;
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 15v4a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-4'/%3E%3Cpolyline points='17 8 12 3 7 8'/%3E%3Cline x1='12' y1='3' x2='12' y2='15'/%3E%3C/svg%3E");
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-size: contain;
  pointer-events: none;
  z-index: 3;
}

.wpcf7-form-control-wrap[data-name="document"]:hover::before {
  border-color: var(--gcf-gold);
  box-shadow: 0 0 0 3px rgba(184, 137, 42, 0.15);
}

.wpcf7-form-control-wrap[data-name="document"][data-filename]::before {
  content: attr(data-filename);
  color: var(--gcf-text);
}



/* ── Textarea ── */
.wpcf7 textarea {
  width: 100%;
  max-height: 120px;
  padding: 14px 16px;
  font-family: var(--gcf-font);
  font-size: 14px;
  color: var(--gcf-text);
  background: var(--gcf-input-bg);
  border: 2px solid var(--gcf-border);
  border-radius: var(--gcf-radius);
  outline: none;
  resize: vertical;
  line-height: 1.6;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  box-sizing: border-box;
}

.wpcf7 textarea::placeholder {
  color: var(--gcf-placeholder);
  font-weight: 400;
}

.wpcf7 textarea:focus {
  border-color: var(--gcf-gold);
  box-shadow: 0 0 0 3px rgba(184, 137, 42, 0.15);
}

/* ── Consent Checkbox ── */
.gcf-consent {
  margin: 8px 0 24px;
}

.gcf-consent .wpcf7-acceptance {
  display: flex;
  align-items: flex-start;
  gap: 12px;
}

.gcf-consent .wpcf7-acceptance input[type="checkbox"] {
  width: 18px;
  height: 18px;
  min-width: 18px;
  border: 2px solid var(--gcf-border);
  border-radius: 8px;
  accent-color: var(--gcf-gold);
  cursor: pointer;
  margin-top: 2px;
}

.gcf-consent .wpcf7-acceptance .wpcf7-list-item-label,
.gcf-consent .wpcf7-acceptance label {
  font-size: 15px;
  color: #4b5563;
  line-height: 1.6;
  font-weight: 400;
}


/* ── Consent Checkbox — REDESIGNED ── */
.gcf-consent {
  margin: 8px 0 24px;
}

.gcf-consent .wpcf7-acceptance {
  display: block;
}

.gcf-consent .wpcf7-acceptance .wpcf7-list-item {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  margin: 0;
  padding: 8px;
  background: transparent;
  border-radius: var(--gcf-radius);
  cursor: pointer;
}

/* Hide default checkbox */
.gcf-consent .wpcf7-acceptance input[type="checkbox"] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

/* Custom checkbox box */
.gcf-consent .wpcf7-acceptance .wpcf7-list-item-label::before {
  content: "";
  display: inline-block;
  width: 22px;
  height: 22px;
  min-width: 22px;
  border: 2px solid var(--gcf-placeholder);
  border-radius: 6px;
  background: #ffffff;
  vertical-align: top;
  margin-top: 1px;
  margin-right: 14px;
  transition: border-color 0.2s ease, background 0.2s ease;
  box-sizing: border-box;
}

/* Checked state — gold checkmark */
.gcf-consent .wpcf7-acceptance input[type="checkbox"]:checked + .wpcf7-list-item-label::before {
  background: var(--gcf-gold);
  border-color: var(--gcf-gold);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'%3E%3C/polyline%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 14px;
}

/* Hover state */
.gcf-consent .wpcf7-acceptance .wpcf7-list-item-label:hover::before {
  border-color: var(--gcf-gold);
}

/* Label text */
.gcf-consent .wpcf7-acceptance .wpcf7-list-item-label {
  display: flex;
  align-items: flex-start;
  font-size: 14px;
  color: #4b5563;
  line-height: 1.6;
  font-weight: 400;
  cursor: pointer;
}


/* ── Submit Button ── */
.wpcf7 input[type="submit"],
.wpcf7 .gcf-submit {
  display: block;
  margin: 0 auto;
  padding: 16px 48px;
  font-family: var(--gcf-font);
  font-size: 16px;
  font-weight: 700;
  color: #ffffff;
  /* background: linear-gradient(135deg, var(--gcf-gold) 0%, var(--gcf-gold-dark) 100%); */
  background: linear-gradient(180deg, #D89A34 0%, #BD7B1D 50%, #A25803 100%);
  border: none;
  border-radius: 50px;
  cursor: pointer;
  letter-spacing: 0.02em;
  transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
  box-shadow: 0 4px 16px rgba(184, 137, 42, 0.35);
}

.wpcf7 input[type="submit"]:hover,
.wpcf7 .gcf-submit:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(184, 137, 42, 0.45);
  background: linear-gradient(180deg, #A25803 0%, #BD7B1D 50%, #D89A34 100%);
  /* background: linear-gradient(135deg, var(--gcf-gold-light) 0%, var(--gcf-gold) 100%); */
}

.wpcf7 input[type="submit"]:active {
  transform: translateY(0);
}

/* ── CF7 Validation Errors ── */
.wpcf7 .wpcf7-not-valid {
  border-color: #ef4444 !important;
}

.wpcf7 .wpcf7-not-valid-tip {
  font-size: 12px;
  color: #ef4444;
  margin-top: 4px;
  display: block;
}

.wpcf7 .wpcf7-response-output {
  margin-top: 16px;
  padding: 12px 16px;
  border-radius: var(--gcf-radius);
  font-size: 14px;
  text-align: center;
  border: none !important;
}

.wpcf7 .wpcf7-mail-sent-ok {
  background: #f0fdf4;
  color: #16a34a;
}

.wpcf7 .wpcf7-mail-sent-ng,
.wpcf7 .wpcf7-aborted {
  background: #fef2f2;
  color: #dc2626;
}

/* ── span wrappers CF7 injects ── */
.wpcf7 span.wpcf7-form-control-wrap {
  display: block;
}

/*Display error css*/
.screen-reader-response {
    display: none;
}