.elementor-16716 .elementor-element.elementor-element-9b20ab9{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-16716 .elementor-element.elementor-element-4bd8dc2{--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;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-16716 .elementor-element.elementor-element-7142f18{--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;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-16716 .elementor-element.elementor-element-a472f62 > .elementor-widget-container{margin:0px 0px 0px 0px;padding:0px 0px 0px 0px;}.elementor-16716 .elementor-element.elementor-element-477344b{--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;}.elementor-16716 .elementor-element.elementor-element-c6cecd0 > .elementor-widget-container{margin:0px 0px 0px 0px;padding:0px 0px 0px 0px;}.elementor-16716 .elementor-element.elementor-element-c6cecd0.elementor-element{--align-self:center;}.elementor-16716 .elementor-element.elementor-element-c6cecd0 .fluentform-widget-wrapper .ff-el-group .ff-btn-submit{background-color:#1a7efb !important;color:#ffffff !important;}/* Start custom CSS for fluent-form-widget, class: .elementor-element-c6cecd0 *//* =============================================
   PREMIUM FORM STYLING - Open Day Registration
   Light Theme - Elegant & Interactive
   Font: IBM Plex Sans Arabic
   Optimized for Fluent Forms + Elementor
   ============================================= */

/* ---- Force Light Background on Form Section ---- */
#join {
  background-color: #f4f3f0 !important;
  background-image: none !important;
}

#join > .e-con-inner,
#join .elementor-widget-container {
  background-color: transparent !important;
  background-image: none !important;
}

/* ---- Form Wrapper ---- */
#join .fluentform,
#join .frm-fluent-form {
  font-family: 'IBM Plex Sans Arabic', sans-serif;
  background: #ffffff;
  border: 1px solid rgba(0, 0, 0, 0.06);
  border-radius: 24px;
  padding: 32px 28px;
  box-shadow:
    0 1px 2px rgba(0,0,0,0.02),
    0 8px 32px rgba(0,0,0,0.04);
  max-width: 720px;
  margin: 0 auto;
  position: relative;
  overflow: hidden;
  transition: box-shadow 0.4s ease;
}

#join .fluentform:hover,
#join .frm-fluent-form:hover {
  box-shadow:
    0 1px 2px rgba(0,0,0,0.02),
    0 16px 50px rgba(0,0,0,0.06);
}

/* Top Gradient Accent */
#join .fluentform::before,
#join .frm-fluent-form::before {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  height: 3px;
  background: linear-gradient(90deg, #c9a227, #d4af37, #e8c84a, #d4af37, #c9a227);
  background-size: 200% 100%;
  animation: goldShimmer 4s ease-in-out infinite;
  border-radius: 24px 24px 0 0;
}

@keyframes goldShimmer {
  0%   { background-position: 0% 50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

/* =============================================
   LABELS
============================================= */
#join .ff-el-input--label label,
#join .ff-el-group label {
  font-family: 'IBM Plex Sans Arabic', sans-serif;
  font-size: 0.88rem;
  font-weight: 600;
  color: #1a1a1a;
  margin-bottom: 5px;
  letter-spacing: 0.2px;
}

/* =============================================
   ALL INPUT FIELDS
============================================= */
#join .ff-el-form-control,
#join .ff-el-input--content input[type="text"],
#join .ff-el-input--content input[type="email"],
#join .ff-el-input--content input[type="tel"],
#join .ff-el-input--content input[type="url"],
#join .ff-el-input--content input[type="number"],
#join .ff-el-input--content input[type="date"],
#join .ff-el-input--content select,
#join .ff-el-input--content textarea {
  font-family: 'IBM Plex Sans Arabic', sans-serif;
  width: 100%;
  padding: 11px 16px;
  font-size: 0.95rem;
  font-weight: 400;
  color: #1a1a1a;
  background: #fafaf8;
  border: 1.5px solid #e8e6e1;
  border-radius: 10px;
  outline: none;
  transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

/* Placeholder */
#join .ff-el-form-control::placeholder {
  color: #b0ada5;
  font-weight: 300;
  font-size: 0.88rem;
}

/* Hover */
#join .ff-el-form-control:hover:not(:focus) {
  border-color: #cbc8c0;
  background: #f5f4f1;
}

/* Focus */
#join .ff-el-form-control:focus {
  background: #ffffff;
  border-color: #d4af37;
  box-shadow: 0 0 0 3px rgba(212, 175, 55, 0.08);
}

/* Textarea */
#join .ff-el-input--content textarea {
  min-height: 110px;
  resize: vertical;
  line-height: 1.7;
}

/* Select Arrow */
#join .ff-el-input--content select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2.5' 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: left 16px center;
  padding-left: 38px;
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
}

/* =============================================
   RADIO & CHECKBOX - Natural Styling
============================================= */
#join .ff-el-input--content input[type="radio"],
#join .ff-el-input--content input[type="checkbox"] {
  accent-color: #d4af37;
  cursor: pointer;
  margin-left: 6px;
}

/* =============================================
   RADIO/CHECKBOX LAYOUT - Inline
============================================= */
#join .ff-el-input--content .ff-el-form-check {
  display: inline-flex;
  align-items: center;
  margin-left: 12px;
  margin-bottom: 4px;
}

#join .ff-el-form-check label {
  font-family: 'IBM Plex Sans Arabic', sans-serif;
  font-size: 0.9rem;
  font-weight: 400;
  color: #333;
  cursor: pointer;
  padding: 5px 10px;
  border-radius: 8px;
  transition: all 0.25s ease;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  border: 1.5px solid transparent;
}

#join .ff-el-form-check label:hover {
  background: rgba(212, 175, 55, 0.05);
  border-color: rgba(212, 175, 55, 0.2);
}

/* =============================================
   FIELD SPACING - Compact
============================================= */
#join .ff-el-group {
  margin-bottom: 12px;
}

/* =============================================
   REQUIRED ASTERISK
============================================= */
#join .ff-el-input--label .ff-el-required {
  color: #c9a227;
  font-weight: 700;
}

/* =============================================
   SUBMIT BUTTON
============================================= */
#join .ff-btn-submit,
#join .fluentform button[type="submit"],
#join .frm-fluent-form button[type="submit"] {
  font-family: 'IBM Plex Sans Arabic', sans-serif;
  width: 100%;
  padding: 14px 32px;
  font-size: 1.05rem;
  font-weight: 600;
  color: #1a1a1a;
  background: linear-gradient(135deg, #d4af37, #e8c84a);
  border: none;
  border-radius: 10px;
  cursor: pointer;
  transition: all 0.35s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  box-shadow: 0 4px 16px rgba(212, 175, 55, 0.2);
  position: relative;
  overflow: hidden;
  letter-spacing: 0.3px;
  margin-top: 6px;
  text-align: center;
  display: block;
}

#join .ff-btn-submit:hover,
#join .fluentform button[type="submit"]:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 35px rgba(212, 175, 55, 0.3);
  background: linear-gradient(135deg, #e8c84a, #d4af37);
}

#join .ff-btn-submit:active,
#join .fluentform button[type="submit"]:active {
  transform: translateY(0);
  box-shadow: 0 4px 16px rgba(212, 175, 55, 0.25);
}

/* Button Shimmer */
#join .ff-btn-submit::after,
#join .fluentform button[type="submit"]::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.3), transparent);
  transition: left 0.6s ease;
  pointer-events: none;
}

#join .ff-btn-submit:hover::after,
#join .fluentform button[type="submit"]:hover::after {
  left: 100%;
}

/* =============================================
   VALIDATION
============================================= */
#join .ff-el-is-error .ff-el-form-control {
  border-color: #e53e3e;
  background: #fefafa;
  box-shadow: 0 0 0 3px rgba(229, 62, 62, 0.06);
}

#join .ff-el-is-error .text-danger {
  font-family: 'IBM Plex Sans Arabic', sans-serif;
  color: #c53030;
  font-size: 0.78rem;
  font-weight: 500;
  margin-top: 4px;
}

/* Success */
#join .ff-message-success {
  font-family: 'IBM Plex Sans Arabic', sans-serif;
  background: rgba(52, 211, 153, 0.06);
  border: 1px solid rgba(52, 211, 153, 0.2);
  border-radius: 14px;
  padding: 24px;
  color: #065f46;
  font-size: 1rem;
  font-weight: 500;
  text-align: center;
}

/* =============================================
   FORM REVEAL ANIMATION
============================================= */
#join .fluentform,
#join .frm-fluent-form {
  animation: formSlideIn 0.7s ease-out both;
}

@keyframes formSlideIn {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* =============================================
   SECTION TITLE (if using Elementor heading)
============================================= */
#join .elementor-heading-title {
  font-family: 'IBM Plex Sans Arabic', sans-serif;
  color: #1a1a1a;
}

/* =============================================
   RESPONSIVE
============================================= */
@media (max-width: 768px) {
  #join .fluentform,
  #join .frm-fluent-form {
    padding: 24px 18px;
    border-radius: 18px;
    margin: 0 8px;
  }

  #join .ff-el-form-control,
  #join .ff-el-input--content input,
  #join .ff-el-input--content select,
  #join .ff-el-input--content textarea {
    padding: 10px 13px;
    font-size: 0.9rem;
    border-radius: 8px;
  }

  #join .ff-btn-submit,
  #join .fluentform button[type="submit"] {
    padding: 13px 24px;
    font-size: 1rem;
    border-radius: 8px;
  }
}

@media (max-width: 480px) {
  #join .fluentform,
  #join .frm-fluent-form {
    padding: 20px 14px;
    border-radius: 14px;
  }

  #join .ff-el-group {
    margin-bottom: 10px;
  }
}/* End custom CSS */