.elementor-11194 .elementor-element.elementor-element-3afd4bd{--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;--gap:20px 20px;--row-gap:20px;--column-gap:20px;--padding-top:6%;--padding-bottom:6%;--padding-left:3%;--padding-right:3%;}.elementor-widget-text-editor{font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-weight:var( --e-global-typography-text-font-weight );color:var( --e-global-color-text );}.elementor-widget-text-editor.elementor-drop-cap-view-stacked .elementor-drop-cap{background-color:var( --e-global-color-primary );}.elementor-widget-text-editor.elementor-drop-cap-view-framed .elementor-drop-cap, .elementor-widget-text-editor.elementor-drop-cap-view-default .elementor-drop-cap{color:var( --e-global-color-primary );border-color:var( --e-global-color-primary );}@media(min-width:768px){.elementor-11194 .elementor-element.elementor-element-3afd4bd{--content-width:900px;}}@media(max-width:1024px){.elementor-11194 .elementor-element.elementor-element-3afd4bd{--padding-top:40px;--padding-bottom:40px;--padding-left:40px;--padding-right:40px;}}@media(max-width:767px){.elementor-11194 .elementor-element.elementor-element-3afd4bd{--padding-top:30px;--padding-bottom:30px;--padding-left:20px;--padding-right:20px;}}/* Start custom CSS for container, class: .elementor-element-3afd4bd */.gdm-step-label { display: flex; align-items: center; gap: 6px; }
.gdm-step-label svg { width: 16px; height: 16px; }

/* ============================================================
   GOLDEN DESERT MOROCCO — Booking Form & Steps Bar
   Full stylesheet — paste entirely into Additional CSS
   ============================================================ */

/* ── Outer form wrapper ── */
#uacf7-form-wrapper, .uacf7-wrapper-default { background: #fff; border-radius: 16px; border: 1px solid #ede8de; padding: 2rem; max-width: 680px; margin: 0 auto; font-family: 'Helvetica Neue', Arial, sans-serif; box-shadow: 0 4px 24px rgba(0, 0, 0, 0.06); }

/* ── Step fade-in animation ── */
.uacf7-step.step-content { animation: gdmFadeIn 0.3s ease; }
@keyframes gdmFadeIn {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}

/* ── Step headings ── */
.uacf7-step.step-content h3 { font-size: 19px; font-weight: 700; color: #1a1a1a; margin-bottom: 1.25rem; padding-bottom: 0.75rem; border-bottom: 2px solid #f5efe3; font-family: Georgia, serif; }

/* ── Labels ── */
.uacf7-wrapper-default label { display: block; font-size: 11px; font-weight: 700; color: #888; text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: 0.9rem; }

/* ── All inputs, selects, textareas ── */
.uacf7-wrapper-default .wpcf7-form-control.wpcf7-text, .uacf7-wrapper-default .wpcf7-form-control.wpcf7-email, .uacf7-wrapper-default .wpcf7-form-control.wpcf7-tel, .uacf7-wrapper-default .wpcf7-form-control.wpcf7-number, .uacf7-wrapper-default .wpcf7-form-control.wpcf7-date, .uacf7-wrapper-default .wpcf7-form-control.wpcf7-select, .uacf7-wrapper-default .wpcf7-form-control.wpcf7-textarea { width: 100%; display: block; padding: 11px 13px; font-size: 14px; border: 1.5px solid #e5e0d8; border-radius: 10px; background: #fdfaf5; color: #1a1a1a; margin-top: 6px; font-family: inherit; -webkit-appearance: none; appearance: none; transition: border-color 0.2s, box-shadow 0.2s, background 0.2s; }
.uacf7-wrapper-default .wpcf7-form-control:focus { outline: none; border-color: #c8973a; box-shadow: 0 0 0 3px rgba(200, 151, 58, 0.12); background: #fff; }

/* ── Custom select arrow ── */
.uacf7-wrapper-default .wpcf7-form-control.wpcf7-select { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='7' viewBox='0 0 11 7'%3E%3Cpath d='M1 1l4.5 4.5L10 1' stroke='%23c8973a' stroke-width='1.7' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 13px center; padding-right: 36px; cursor: pointer; }

/* ── Textarea ── */
.uacf7-wrapper-default .wpcf7-form-control.wpcf7-textarea { height: 95px; resize: vertical; }

/* ── Number inputs ── */
.uacf7-wrapper-default .wpcf7-form-control.wpcf7-number { text-align: center; font-size: 18px; font-weight: 700; color: #2d6a4f; padding: 10px 8px; }

/* ── 2-column grid ── */
.uacf7-col-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 0.5rem; }

/* ── 3-column grid ── */
.uacf7-col-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; margin-bottom: 0.5rem; }

/* ── Navigation buttons row ── */
.uacf7-step .uacf7-buttons { display: flex; gap: 10px; margin-top: 1.5rem; align-items: center; padding: 0; }

/* Previous button */
.uacf7-step .uacf7-buttons .uacf7-prev { padding: 11px 20px; border-radius: 10px; font-size: 14px; font-weight: 700; cursor: pointer; background: transparent; border: 1.5px solid #e5e0d8; color: #aaa; font-family: inherit; transition: all 0.2s; white-space: nowrap; }
.uacf7-step .uacf7-buttons .uacf7-prev:hover { background: #f5efe3; border-color: #c8973a; color: #c8973a; }

/* Next button */
.uacf7-step .uacf7-buttons .uacf7-next { padding: 11px 22px; border-radius: 10px; font-size: 14px; font-weight: 700; cursor: pointer; background: #c8973a; border: none; color: #fff; font-family: inherit; flex: 1; box-shadow: 0 2px 8px rgba(200, 151, 58, 0.25); transition: all 0.2s; }
.uacf7-step .uacf7-buttons .uacf7-next:hover { background: #a87c2e; transform: translateY(-1px); box-shadow: 0 4px 12px rgba(200, 151, 58, 0.3); }

/* Hide ajax spinner */
.uacf7-step .uacf7-ajax-loader { display: none; }

/* ── Submit button (step 4) ── */
.uacf7-wrapper-default .wpcf7-submit { width: 100%; padding: 14px 24px; background: #2d6a4f; color: #fff; font-size: 16px; font-weight: 700; border: none; border-radius: 10px; cursor: pointer; letter-spacing: 0.03em; font-family: inherit; box-shadow: 0 2px 10px rgba(45, 106, 79, 0.25); transition: all 0.2s; margin-top: 0.5rem; }
.uacf7-wrapper-default .wpcf7-submit:hover { background: #1e4d38; transform: translateY(-1px); box-shadow: 0 4px 16px rgba(45, 106, 79, 0.35); }

/* ── Validation errors ── */
.uacf7-wrapper-default .wpcf7-not-valid { border-color: #e05c5c !important; background: #fff8f8 !important; }
.uacf7-wrapper-default .wpcf7-not-valid-tip { font-size: 11px; color: #c0392b; margin-top: 5px; display: block; font-weight: 700; }

/* ── Success message ── */
.uacf7-wrapper-default .wpcf7-mail-sent-ok { background: #eaf5ef; border: 1.5px solid #2d6a4f; border-radius: 12px; padding: 1.25rem 1.5rem; color: #2d6a4f; font-weight: 700; font-size: 15px; text-align: center; margin-top: 1rem; }

/* ── Step 4 info paragraph ── */
.uacf7-step.step-end p:not(.uacf7-buttons) { background: #fdfaf5; border: 1px solid #ede8de; border-radius: 10px; padding: 14px 16px; font-size: 14px; color: #777; line-height: 1.7; margin-bottom: 1.25rem; }

/* ============================================================
   ALWAYS-VISIBLE STEPS BAR (sits above the form)
   ============================================================ */

.gdm-steps-bar { display: flex; align-items: center; justify-content: center; max-width: 680px; margin: 0 auto 1.25rem; padding: 1.25rem 1.75rem; background: #fff; border: 1px solid #ede8de; border-radius: 14px; box-shadow: 0 2px 12px rgba(0, 0, 0, 0.05); gap: 0; }

/* connector line */
.gdm-step-line { flex: 1; height: 2px; background: #e8e0d0; min-width: 16px; transition: background 0.4s; }
.gdm-step-line.done { background: #2d6a4f; }

/* each step item */
.gdm-step { display: flex; flex-direction: column; align-items: center; gap: 8px; cursor: default; min-width: 72px; }

/* circle */
.gdm-step-circle { width: 42px; height: 42px; border-radius: 50%; background: #f0ebe0; color: #ccc; display: flex; align-items: center; justify-content: center; border: 2px solid #e8e0d0; transition: all 0.3s; flex-shrink: 0; position: relative; }

/* SVG icon inside circle */
.gdm-step-circle svg { width: 16px; height: 16px; stroke: currentColor; display: block; flex-shrink: 0; transition: opacity 0.2s; }

/* step label */
.gdm-step-label { font-size: 10px; color: #bbb; font-weight: 700; text-align: center; text-transform: uppercase; letter-spacing: 0.05em; line-height: 1.3; transition: color 0.3s; font-family: 'Helvetica Neue', Arial, sans-serif; }

/* ── DONE state ── */
.gdm-step.done .gdm-step-circle { background: #2d6a4f; border-color: #2d6a4f; color: #fff; }
.gdm-step.done .gdm-step-label { color: #2d6a4f; }

/* hide original icon when done, show checkmark via pseudo */
.gdm-step.done .gdm-step-circle svg { display: none; }
.gdm-step.done .gdm-step-circle::after { content: ''; display: block; width: 16px; height: 16px; 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='white' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-size: contain; background-position: center; }

/* ── ACTIVE state ── */
.gdm-step.active .gdm-step-circle { background: #c8973a; border-color: #c8973a; color: #fff; box-shadow: 0 0 0 5px rgba(200, 151, 58, 0.15); }
.gdm-step.active .gdm-step-label { color: #c8973a; }

/* ── UPCOMING state (default, already set above but explicit) ── */
.gdm-step:not(.active):not(.done) .gdm-step-circle { background: #f0ebe0; border-color: #e8e0d0; color: #ccc; }
.gdm-step:not(.active):not(.done) .gdm-step-label { color: #ccc; }

/* ============================================================
   MOBILE
   ============================================================ */

@media (max-width: 600px) {
  #uacf7-form-wrapper, .uacf7-wrapper-default { padding: 1.25rem; border-radius: 12px; }
  .uacf7-col-2, .uacf7-col-3 { grid-template-columns: 1fr; }
  .gdm-steps-bar { padding: 1rem 0.75rem; border-radius: 12px; margin-bottom: 1rem; }
  .gdm-step { min-width: 44px; gap: 5px; }
  .gdm-step-circle { width: 34px; height: 34px; }
  .gdm-step-circle svg { width: 13px; height: 13px; }
  .gdm-step-label { font-size: 8px; letter-spacing: 0; }
  .gdm-step-line { min-width: 8px; }
  .uacf7-step .uacf7-buttons .uacf7-prev, .uacf7-step .uacf7-buttons .uacf7-next { padding: 10px 14px; font-size: 13px; }
}/* End custom CSS */