.elementor-5200 .elementor-element.elementor-element-ae9fd0b{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}/* Start custom CSS for shortcode, class: .elementor-element-cdc08b6 *//* ══════════════════════════════════════════
   VISA CONSULTATION FORM — CF7 COMPATIBLE CSS
   Paste in: Appearance → Customize → Additional CSS
   OR in your child theme's style.css
══════════════════════════════════════════ */

.vc-wrapper {
  max-width: 960px;
  margin: 0 auto;
  padding: 40px 20px 60px;
  font-family: 'Poppins', sans-serif;
}

/* ── Heading ── */
.vc-heading { text-align: center; margin-bottom: 36px; }

.vc-badge {
  display: inline-flex; align-items: center; gap: 8px;
  background: linear-gradient(135deg, rgba(1,103,237,0.09), rgba(16,0,255,0.09));
  border: 1px solid rgba(1,103,237,0.22);
  color: #0157cc; font-size: 13px; font-weight: 600;
  padding: 8px 20px; border-radius: 50px; margin-bottom: 14px;
  letter-spacing: 0.4px; font-family: 'Poppins', sans-serif;
}

.vc-heading h2 {
  font-size: 36px; font-weight: 800;
  background: linear-gradient(135deg, #0167ed, #1000ff);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text; margin: 0 0 10px; line-height: 1.2;
}

.vc-heading p {
  font-size: 15px; color: #667788;
  max-width: 540px; margin: 0 auto; line-height: 1.75;
}

/* ── Card ── */
.vc-card {
  background: #ffffff; border-radius: 26px;
  border: 1px solid rgba(1,103,237,0.13);
  box-shadow: 0 20px 60px rgba(1,103,237,0.10), 0 4px 20px rgba(0,0,0,0.04);
  overflow: hidden;
}

/* ── Sections ── */
.vc-section { padding: 34px 38px; border-bottom: 1px solid #f0f3ff; }
.vc-section:last-of-type { border-bottom: none; }

/* ── Section Title ── */
.vc-stitle { display: flex; align-items: center; gap: 12px; margin-bottom: 26px; }

.vc-sicon {
  width: 40px; height: 40px; border-radius: 12px;
  background: linear-gradient(135deg, #0167ed, #1000ff);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; box-shadow: 0 6px 18px rgba(1,103,237,0.28);
}

.vc-stitle h3 { font-size: 15.5px; font-weight: 700; color: #1a1a2e; margin: 0; }
.vc-stitle h3 span { font-size: 13px; color: #99aaaa; font-weight: 400; margin-left: 4px; }

/* ── Grids ── */
.vc-grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.vc-grid3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 20px; }
.vc-grid4 { display: grid; grid-template-columns: 1fr 1fr 1fr 1fr; gap: 20px; }
.vc-mt20 { margin-top: 20px; }

/* ── Fields ── */
.vc-field { display: flex; flex-direction: column; gap: 7px; }

.vc-field label {
  font-size: 12.5px; font-weight: 600; color: #0157cc;
  letter-spacing: 0.3px; padding-left: 2px;
}

/* CF7 wraps inputs in spans — target them */
.vc-field input,
.vc-field select,
.vc-field textarea,
.vc-field span > input,
.vc-field span > select,
.vc-field span > textarea {
  width: 100% !important;
  padding: 12px 15px !important;
  border-radius: 12px !important;
  border: 1.5px solid #e4ecfb !important;
  background: #fafbff !important;
  font-size: 14px !important;
  color: #1a1a2e !important;
  outline: none !important;
  transition: all 0.25s ease !important;
  font-family: 'Poppins', sans-serif !important;
  box-sizing: border-box !important;
  appearance: none !important;
  -webkit-appearance: none !important;
}

.vc-field span { display: block; width: 100%; }

.vc-field select,
.vc-field span > select {
  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='%230167ed' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 13px center !important;
  padding-right: 40px !important;
  cursor: pointer !important;
}

.vc-field textarea,
.vc-field span > textarea {
  resize: vertical !important;
  line-height: 1.65 !important;
  min-height: 130px !important;
}

.vc-field input:focus,
.vc-field select:focus,
.vc-field textarea:focus {
  border-color: #0167ed !important;
  background: #ffffff !important;
  box-shadow: 0 0 0 4px rgba(1,103,237,0.09), 0 4px 16px rgba(1,103,237,0.09) !important;
  transform: translateY(-1px) !important;
}

/* ── Checkbox ── */
.vc-checkbox {
  display: flex; align-items: flex-start; gap: 13px;
  background: #f6f9ff; border: 1px solid rgba(1,103,237,0.12);
  border-radius: 13px; padding: 16px 18px; cursor: pointer;
  transition: background 0.2s;
}
.vc-checkbox:hover { background: #eef3ff; }

.vc-checkbox input[type="checkbox"],
.vc-checkbox span > input[type="checkbox"] {
  width: 18px !important; height: 18px !important;
  accent-color: #0167ed; margin-top: 2px;
  cursor: pointer; flex-shrink: 0;
  border: none !important; box-shadow: none !important;
  padding: 0 !important;
}

.vc-checkbox p {
  font-size: 13.5px; color: #556677;
  line-height: 1.65; margin: 0;
}
.vc-checkbox p a { color: #0167ed; font-weight: 600; text-decoration: none; }

/* ── Submit Bar ── */
.vc-submit-bar {
  padding: 32px 38px;
  background: linear-gradient(135deg, #f7f9ff, #fafbff);
  border-top: 1px solid #eef2ff;
  display: flex; align-items: center;
  justify-content: space-between;
  gap: 20px; flex-wrap: wrap;
}

.vc-submit-note {
  display: flex; align-items: center; gap: 10px;
  color: #889999; font-size: 13px;
}

/* CF7 Submit Button */
.vc-submit-btn,
.wpcf7-submit.vc-submit-btn {
  background: linear-gradient(135deg, #0167ed, #1000ff) !important;
  color: #ffffff !important; border: none !important;
  padding: 15px 46px !important; border-radius: 60px !important;
  font-size: 15.5px !important; font-weight: 700 !important;
  cursor: pointer !important; transition: all 0.35s ease !important;
  box-shadow: 0 12px 30px rgba(1,103,237,0.28) !important;
  letter-spacing: 0.3px !important; font-family: 'Poppins', sans-serif !important;
}

.vc-submit-btn:hover,
.wpcf7-submit.vc-submit-btn:hover {
  transform: translateY(-3px) scale(1.02) !important;
  box-shadow: 0 18px 40px rgba(1,103,237,0.36), 0 0 0 6px rgba(1,103,237,0.10) !important;
}

/* CF7 Validation Errors */
.vc-field .wpcf7-not-valid-tip {
  color: #e53e3e; font-size: 12px; margin-top: 4px;
}
.vc-field .wpcf7-not-valid {
  border-color: #e53e3e !important;
  background: #fff5f5 !important;
}

/* CF7 Response Messages */
.wpcf7-response-output {
  border-radius: 12px !important; padding: 14px 18px !important;
  font-family: 'Poppins', sans-serif !important; font-size: 14px !important;
  margin: 0 38px 24px !important;
}

/* ── Responsive ── */
@media (max-width: 900px) {
  .vc-grid4 { grid-template-columns: 1fr 1fr; }
  .vc-grid3 { grid-template-columns: 1fr 1fr; }
  .vc-section { padding: 26px 24px; }
  .vc-submit-bar { padding: 26px 24px; flex-direction: column; align-items: stretch; }
  .vc-submit-btn { width: 100% !important; text-align: center !important; }
  .vc-heading h2 { font-size: 28px; }
}

@media (max-width: 600px) {
  .vc-grid2, .vc-grid3, .vc-grid4 { grid-template-columns: 1fr; }
  .vc-heading h2 { font-size: 24px; }
  .vc-section { padding: 20px 16px; }
  .vc-submit-bar { padding: 20px 16px; }
  .vc-wrapper { padding: 24px 14px 40px; }
}/* End custom CSS */