/* =========================================================
   ODESSA RESORT — Guided enquiry funnel
   ========================================================= */
:root{
  --midnight:#0C1E38; --midnight-2:#081628; --abyss:#060F1E;
  --panel:#13294A; --panel-2:#16315A;
  --gold:#C9A14A; --gold-soft:#E6CB8A; --gold-bright:#F3DCA0;
  --text:#F1EAD9; --text-soft:rgba(241,234,217,.66); --text-faint:rgba(241,234,217,.42);
  --line:rgba(201,161,74,.30); --line-soft:rgba(241,234,217,.10);
  --serif:"Playfair Display", Georgia, serif;
  --sans:"Mulish", system-ui, sans-serif;
  --pad:clamp(20px,6vw,40px);
  --ease:cubic-bezier(.22,.61,.36,1);
}
html[lang="ar"]{ --serif:"El Messiri", serif; --sans:"Cairo", system-ui, sans-serif; }

*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);color:var(--text);min-height:100svh;
  background:
    radial-gradient(120% 50% at 50% 0%, rgba(22,49,90,.6), transparent 60%),
    radial-gradient(90% 50% at 50% 100%, rgba(201,161,74,.07), transparent 60%),
    linear-gradient(180deg,#0C2040,#0A1B33 55%,#081527);
  background-color:#0A1B33;
  display:flex;justify-content:center;
  padding:env(safe-area-inset-top) 0 env(safe-area-inset-bottom);
}
img{display:block;max-width:100%}
input,button{font-family:inherit}

.funnel{width:100%;max-width:560px;min-height:100svh;display:flex;flex-direction:column;padding:18px var(--pad) 34px;position:relative}

/* top bar */
.fbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px}
.fbrand{display:flex;align-items:center;gap:9px;color:var(--text);text-decoration:none}
.fbrand svg{color:var(--gold)}
.fbrand__name{font-family:var(--serif);font-weight:600;letter-spacing:.16em;font-size:1.05rem}
.flang{display:flex;align-items:center;gap:.4em;background:rgba(241,234,217,.06);border:1px solid var(--line);
  color:var(--text);border-radius:999px;padding:7px 13px;font-size:.78rem;cursor:pointer}
.flang__opt{opacity:.5}.flang__opt.is-active{opacity:1;color:var(--gold);font-weight:700}.flang__sep{opacity:.35}

/* progress */
.fprog{height:3px;background:rgba(241,234,217,.1);border-radius:99px;overflow:hidden}
.fprog__bar{display:block;height:100%;width:25%;border-radius:99px;
  background:linear-gradient(90deg,var(--gold),var(--gold-soft));transition:width .5s var(--ease)}
.fstepcount{margin-top:8px;font-size:.72rem;letter-spacing:.18em;color:var(--text-faint);text-transform:uppercase}
html[lang="ar"] .fstepcount{letter-spacing:.05em}

/* stage + steps */
.fstage{flex:1;display:flex;align-items:center;position:relative;padding:14px 0}
.step{
  width:100%;display:none;
  animation:slideIn .5s var(--ease);
}
.step.is-active{display:block}
@keyframes slideIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}

.step__kick{font-size:.72rem;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:.8rem}
html[lang="ar"] .step__kick{letter-spacing:.06em}
.step__title{font-family:var(--serif);font-weight:600;line-height:1.06;font-size:clamp(2rem,8vw,2.9rem);margin-bottom:.6rem}
.step__sub{color:var(--text-soft);font-weight:300;font-size:1rem;margin-bottom:1.8rem;max-width:34ch}

/* fields */
.field{display:block;margin-bottom:1.2rem}
.field__label{display:block;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--text-faint);margin-bottom:.6rem;font-weight:600}
html[lang="ar"] .field__label{letter-spacing:.03em}
.field input{
  width:100%;background:rgba(241,234,217,.05);border:1px solid var(--line-soft);
  border-radius:14px;padding:16px 18px;color:var(--text);font-size:1.05rem;outline:none;
  transition:border-color .25s,background .25s;
}
.field input::placeholder{color:var(--text-faint)}
.field input:focus{border-color:var(--gold);background:rgba(241,234,217,.08)}
.field input[type=date]{color-scheme:dark}

/* custom inline calendar */
.cal{background:rgba(241,234,217,.04);border:1px solid var(--line-soft);border-radius:18px;padding:16px 14px;margin-bottom:1.3rem;width:100%}
.cal__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.cal__title{font-family:var(--serif);font-size:1.15rem;font-weight:600;text-transform:capitalize}
.cal__nav{width:40px;height:40px;border-radius:50%;border:1px solid var(--line-soft);background:rgba(241,234,217,.05);color:var(--gold-soft);font-size:1.4rem;line-height:1;cursor:pointer;display:grid;place-items:center;transition:background .2s}
.cal__nav:hover{background:rgba(201,161,74,.18)}
.cal__nav:disabled{opacity:.3;cursor:not-allowed}
.cal__week{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:6px}
.cal__week span{text-align:center;font-size:.62rem;letter-spacing:.04em;text-transform:uppercase;color:var(--text-faint);padding:4px 0;overflow:hidden}
.cal__grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}
.cal__day{aspect-ratio:1;border:none;background:transparent;color:var(--text);border-radius:10px;cursor:pointer;font-size:.9rem;font-family:inherit;display:grid;place-items:center;transition:background .15s,color .15s}
.cal__day:hover:not(:disabled):not(.is-start):not(.is-end){background:rgba(241,234,217,.1)}
.cal__day--empty{visibility:hidden;cursor:default}
.cal__day:disabled{color:var(--text-faint);opacity:.3;cursor:not-allowed}
.cal__day.is-between{background:rgba(201,161,74,.16)}
.cal__day.is-start,.cal__day.is-end{background:linear-gradient(120deg,var(--gold),var(--gold-soft));color:var(--midnight-2);font-weight:700;border-radius:10px}
.cal__sel{display:flex;gap:10px;margin-top:14px}
.cal__chip{flex:1;display:flex;flex-direction:column;gap:3px;background:rgba(241,234,217,.04);border:1px solid var(--line-soft);border-radius:12px;padding:10px 12px;min-width:0}
.cal__chip-k{font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-faint);font-weight:600}
.cal__chip-v{font-size:.92rem;font-weight:600;color:var(--gold-soft)}

/* stepper */
.stepper{display:inline-flex;align-items:center;gap:0;border:1px solid var(--line);border-radius:14px;overflow:hidden}
.stepper__btn{width:54px;height:52px;background:rgba(241,234,217,.04);border:none;color:var(--gold-soft);font-size:1.5rem;cursor:pointer;transition:background .2s}
.stepper__btn:hover{background:rgba(201,161,74,.16)}
.stepper__val{min-width:64px;text-align:center;font-size:1.2rem;font-weight:600;font-family:var(--serif)}

/* villa cards */
.villas{display:flex;flex-direction:column;gap:12px;margin-bottom:1.4rem}
.vcard{
  display:flex;align-items:center;gap:14px;text-align:start;cursor:pointer;
  background:rgba(241,234,217,.04);border:1px solid var(--line-soft);border-radius:16px;
  padding:10px;color:var(--text);transition:border-color .25s,transform .2s,background .25s;position:relative;
}
.vcard:hover{border-color:var(--line)}
.vcard img{width:84px;height:84px;border-radius:11px;object-fit:cover;flex:none}
.vcard__info{display:flex;flex-direction:column;gap:.25rem;flex:1}
.vcard__name{font-family:var(--serif);font-size:1.3rem;font-weight:600;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.vcard__badge{font-family:var(--sans);font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;font-weight:700;
  color:var(--midnight-2);background:linear-gradient(120deg,var(--gold),var(--gold-soft));padding:3px 8px;border-radius:99px}
.vcard__meta{font-size:.82rem;color:var(--text-soft)}
.vcard__tick{position:absolute;top:50%;inset-inline-end:16px;transform:translateY(-50%) scale(.6);
  width:26px;height:26px;border-radius:50%;display:grid;place-items:center;
  background:linear-gradient(120deg,var(--gold),var(--gold-soft));color:var(--midnight-2);font-weight:700;
  opacity:0;transition:.3s var(--ease)}
.vcard.is-sel{border-color:var(--gold);background:rgba(201,161,74,.1)}
.vcard.is-sel .vcard__tick{opacity:1;transform:translateY(-50%) scale(1)}
.vcard--vip{border-color:rgba(201,161,74,.4)}

/* summary */
.summary{list-style:none;margin-bottom:1.6rem;border:1px solid var(--line);border-radius:16px;overflow:hidden;background:rgba(241,234,217,.03)}
.summary li{display:flex;justify-content:space-between;gap:16px;padding:14px 18px;font-size:.95rem;border-bottom:1px solid var(--line-soft)}
.summary li:last-child{border-bottom:none}
.summary .k{color:var(--text-faint);font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600;align-self:center}
html[lang="ar"] .summary .k{letter-spacing:.02em}
.summary .v{color:var(--text);font-weight:600;text-align:end}

/* buttons + nav */
.step__nav{display:flex;gap:12px;margin-top:.8rem}
.step__nav--center{justify-content:center;margin-top:1.2rem}
.fbtn{
  flex:1;display:inline-flex;align-items:center;justify-content:center;gap:.6em;
  padding:16px 22px;border-radius:999px;font-size:1rem;font-weight:600;cursor:pointer;
  border:1px solid transparent;transition:transform .2s var(--ease),box-shadow .3s,background .3s,opacity .2s;
}
.fbtn--lg{width:100%;padding:18px 24px;font-size:1.05rem}
.fbtn:active{transform:scale(.97)}
.fbtn--gold{background:linear-gradient(120deg,var(--gold),var(--gold-soft));color:var(--midnight-2);box-shadow:0 10px 28px -10px rgba(201,161,74,.7)}
.fbtn--gold:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}
.fbtn--ghost{flex:0 0 auto;background:rgba(241,234,217,.05);border-color:rgba(241,234,217,.3);color:var(--text);padding-inline:26px}
.fbtn--ghost:hover{background:rgba(241,234,217,.1)}
.fbtn--wa{background:linear-gradient(120deg,var(--gold),var(--gold-soft));color:var(--midnight-2);box-shadow:0 12px 32px -10px rgba(201,161,74,.8);text-decoration:none}
.fbtn--wa:hover{transform:translateY(-2px)}

@media(prefers-reduced-motion:reduce){ *{animation:none!important;transition:none!important} }
