/* ==========================================================
   Public site — Picnic Salalah
   Wilderness Expedition aesthetic, mobile-first, RTL Arabic
   ========================================================== */

/* ----- Site header ----- */
.site-header {
  position: sticky;
  top: 0;
  z-index: 40;
  background: rgba(239, 233, 216, 0.86);
  backdrop-filter: saturate(140%) blur(10px);
  -webkit-backdrop-filter: saturate(140%) blur(10px);
  border-bottom: 1px solid var(--mist);
}
.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-block: 0.7rem;
}
.brand {
  display: inline-flex; align-items: center; gap: var(--sp-3);
  text-decoration: none; color: var(--ink);
}
.brand:hover { text-decoration: none; color: var(--ink); }
.brand__mark {
  width: 38px; height: 38px;
  display: grid; place-items: center;
  background: var(--paper);
  border: 1px solid var(--moss-soft);
  border-radius: 50%;
  box-shadow: var(--sh-1);
}
.brand__mark svg { width: 24px; height: 24px; }
.brand__name {
  font-weight: 700;
  font-size: 1.05rem;
  letter-spacing: -0.005em;
  color: var(--moss-deep);
  line-height: 1;
}
.brand__sub {
  display: block;
  font-weight: 400;
  font-size: 0.72rem;
  color: var(--ink-mute);
  letter-spacing: var(--tracking-eyebrow);
  margin-top: 3px;
}
.site-nav {
  display: none;
  align-items: center;
  gap: var(--sp-5);
}
.site-nav a {
  color: var(--ink-soft);
  font-size: 0.94rem;
  font-weight: 500;
}
.site-nav a:hover { color: var(--moss); text-decoration: none; }
@media (min-width: 820px) {
  .site-nav { display: inline-flex; }
}

.site-header__cta { display: none; }
@media (min-width: 820px) {
  .site-header__cta { display: inline-flex; }
}

/* ----- Hero ----- */
.hero {
  position: relative;
  padding-block: clamp(2.5rem, 6vw, 4rem) clamp(3rem, 8vw, 6rem);
  overflow: hidden;
}
.hero__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(2rem, 4vw, var(--sp-7));
  align-items: center;
}
@media (min-width: 900px) {
  .hero__grid { grid-template-columns: 1.05fr 1fr; }
}
.hero__copy { position: relative; z-index: 2; }
.hero__title {
  font-size: var(--fs-display-1);
  margin-block: var(--sp-4) var(--sp-5);
  letter-spacing: var(--tracking-display);
}
.hero__title em {
  font-style: normal;
  color: var(--khareef-deep);
  position: relative;
  white-space: nowrap;
}
.hero__title em::after {
  content: "";
  position: absolute;
  inset-inline: 0;
  bottom: 4px;
  height: 8px;
  background: var(--ember-soft);
  border-radius: var(--r-pill);
  z-index: -1;
  opacity: 0.65;
}
.hero__lead {
  font-size: var(--fs-lead);
  color: var(--ink-soft);
  max-width: 52ch;
  margin-bottom: var(--sp-5);
}
.hero__chips {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-3);
  margin-bottom: var(--sp-6);
}
.chip {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 14px;
  background: var(--paper);
  border: 1px solid var(--mist-strong);
  border-radius: var(--r-pill);
  font-size: var(--fs-small);
  color: var(--moss);
  font-weight: 500;
}
.chip svg { width: 14px; height: 14px; }
.hero__ctas {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-3);
}

.hero__media {
  position: relative;
  aspect-ratio: 4 / 5;
  border-radius: var(--r-lg);
  overflow: hidden;
  box-shadow: var(--sh-3);
}
.hero__media .imgslot {
  height: 100%;
  border-radius: 0;
  --ar: auto;
}
@media (min-width: 900px) {
  .hero__media { aspect-ratio: 4 / 5; }
}

/* "Field journal" coordinate stamp on the hero photo corner */
.hero__stamp {
  position: absolute;
  top: var(--sp-3);
  inset-inline-start: var(--sp-3);
  background: rgba(250, 246, 232, 0.92);
  backdrop-filter: blur(6px);
  border-radius: var(--r-sm);
  padding: 8px 12px;
  font-family: ui-monospace, "SF Mono", Menlo, monospace;
  font-size: 0.72rem;
  color: var(--moss-deep);
  letter-spacing: 0.04em;
  display: flex;
  align-items: center;
  gap: 6px;
  z-index: 2;
  box-shadow: var(--sh-1);
}
.hero__stamp svg { width: 12px; height: 12px; color: var(--moss); }

/* Hero ornament — trail-line ridge */
.hero__ridge {
  position: absolute;
  inset-inline-start: -4%;
  bottom: -1px;
  width: 108%;
  pointer-events: none;
  color: var(--moss-soft);
  opacity: 0.45;
}

/* ----- About strip ----- */
.about {
  background: var(--paper-warm);
  border-block: 1px solid var(--mist);
}
.about__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-6);
  align-items: center;
}
@media (min-width: 760px) {
  .about__grid { grid-template-columns: 1.4fr 1fr; }
}
.about__title { margin-bottom: var(--sp-3); }
.about__lead { color: var(--ink-soft); max-width: 52ch; }
.about__stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-4);
}
.stat {
  text-align: center;
  padding-block: var(--sp-3);
  border-inline-start: 1px solid var(--stone-soft);
}
.stat:first-child { border-inline-start: 0; }
.stat__num {
  font-size: clamp(1.6rem, 3.4vw, 2.3rem);
  font-weight: 700;
  color: var(--moss);
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.stat__label {
  font-size: var(--fs-small);
  color: var(--ink-mute);
  margin-top: 6px;
}

/* ----- Trips section ----- */
.trips__head {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-3);
  align-items: end;
  margin-bottom: var(--sp-6);
}
@media (min-width: 760px) {
  .trips__head { grid-template-columns: 1fr auto; }
}
.trips__title { max-width: 18ch; }
.trips__sub { color: var(--ink-soft); max-width: 48ch; }

.trip-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-5);
}
@media (min-width: 720px) {
  .trip-grid { grid-template-columns: repeat(3, 1fr); }
}

.trip-card {
  background: var(--paper);
  border-radius: var(--r-lg);
  border: 1px solid var(--mist);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  position: relative;
  transition: transform var(--dur-2) var(--ease-out), box-shadow var(--dur-2) var(--ease-out), border-color var(--dur-2) var(--ease-out);
}
.trip-card::before {
  /* Subtle moss accent strip across the top edge */
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 3px;
  background: linear-gradient(90deg, var(--moss), var(--khareef) 60%, var(--ember));
  z-index: 2;
}
.trip-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--sh-3);
  border-color: var(--moss-soft);
}
.trip-card__media {
  aspect-ratio: 4 / 3;
}
.trip-card__media .imgslot { --ar: 4 / 3; border-radius: 0; }
.trip-card__body {
  padding: var(--sp-5);
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  flex: 1;
}
.trip-card__title {
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--moss-deep);
  letter-spacing: -0.005em;
  line-height: 1.3;
}
.trip-card__time {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: var(--fs-small);
  color: var(--khareef-deep);
  font-variant-numeric: tabular-nums;
  font-weight: 500;
}
.trip-card__includes {
  list-style: none;
  display: grid;
  gap: 6px;
  font-size: 0.94rem;
  color: var(--ink-soft);
}
.trip-card__includes li {
  display: flex;
  gap: 8px;
  align-items: flex-start;
}
.trip-card__includes li::before {
  content: "";
  flex: 0 0 6px;
  width: 6px; height: 6px;
  margin-top: 11px;
  border-radius: 50%;
  background: var(--khareef);
}
.trip-card__price {
  display: flex;
  align-items: baseline;
  gap: 6px;
  margin-top: auto;
}
.trip-card__price-num {
  font-size: 2rem;
  font-weight: 700;
  color: var(--moss);
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.trip-card__price-cur {
  font-size: 0.82rem;
  font-weight: 500;
  color: var(--ink-mute);
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
}
.trip-card__price-per {
  font-size: var(--fs-small);
  color: var(--ink-mute);
  margin-inline-start: auto;
}
.trip-card__cta { width: 100%; }

/* ----- Experience tiles ----- */
.exp {
  background: var(--paper);
  border-block: 1px solid var(--mist);
}
.exp-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-4);
  margin-top: var(--sp-6);
}
@media (min-width: 760px) {
  .exp-grid { grid-template-columns: repeat(4, 1fr); }
}
.exp-tile {
  position: relative;
  display: block;
  border-radius: var(--r-md);
  overflow: hidden;
  aspect-ratio: 1 / 1;
}
.exp-tile .imgslot { --ar: 1 / 1; height: 100%; border-radius: 0; }
.exp-tile__caption {
  position: absolute;
  inset-inline: var(--sp-3);
  bottom: var(--sp-3);
  padding: 8px 12px;
  background: rgba(250, 246, 232, 0.92);
  backdrop-filter: blur(6px);
  border-radius: var(--r-sm);
  font-weight: 600;
  font-size: 0.95rem;
  color: var(--moss-deep);
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.exp-tile__caption svg { width: 18px; height: 18px; color: var(--khareef); }

/* ----- Booking section ----- */
.booking {
  background: linear-gradient(180deg, var(--cream) 0%, var(--paper-warm) 100%);
}
.booking__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-7);
  align-items: start;
}
@media (min-width: 900px) {
  .booking__grid { grid-template-columns: 1fr 1.1fr; gap: var(--sp-8); }
}
.booking__intro h2 { margin-block: var(--sp-3) var(--sp-4); }
.booking__intro p { color: var(--ink-soft); max-width: 44ch; }
.booking__steps {
  margin-top: var(--sp-5);
  display: grid;
  gap: var(--sp-4);
}
.booking-step {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--sp-3);
  align-items: start;
}
.booking-step__num {
  width: 32px; height: 32px;
  border-radius: 50%;
  background: var(--paper);
  border: 1px solid var(--moss);
  color: var(--moss);
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  display: grid;
  place-items: center;
  font-size: 0.95rem;
}
.booking-step__title { font-weight: 600; color: var(--ink); }
.booking-step__text { color: var(--ink-soft); font-size: 0.94rem; }

.booking-card {
  background: var(--paper);
  border-radius: var(--r-lg);
  padding: clamp(1.5rem, 3vw, 2.2rem);
  box-shadow: var(--sh-3);
  border: 1px solid var(--mist);
  position: relative;
}
/* Field-journal corner ticks on the booking card */
.booking-card::before,
.booking-card::after {
  content: "";
  position: absolute;
  width: 18px; height: 18px;
  border: 2px solid var(--moss-soft);
  border-radius: 2px;
  opacity: 0.45;
}
.booking-card::before { top: 10px; inset-inline-start: 10px; border-bottom: 0; border-inline-end: 0; }
.booking-card::after  { bottom: 10px; inset-inline-end: 10px; border-top: 0;    border-inline-start: 0; }

.booking-card__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
  margin-bottom: var(--sp-5);
}
.booking-card__title { font-size: 1.4rem; font-weight: 700; }
.field-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-4);
}
@media (max-width: 520px) {
  .field-row { grid-template-columns: 1fr; }
}

/* Stepper for party size */
.stepper {
  display: inline-flex;
  align-items: center;
  background: var(--paper);
  border: 1px solid var(--mist-strong);
  border-radius: var(--r-md);
  overflow: hidden;
  height: 48px;
}
.stepper button {
  width: 44px; height: 100%;
  background: transparent; border: 0;
  color: var(--moss);
  font-size: 1.4rem; font-weight: 600;
  cursor: pointer;
  transition: background var(--dur-1) var(--ease-out);
}
.stepper button:hover { background: var(--cream); }
.stepper button:disabled { opacity: 0.35; cursor: not-allowed; }
.stepper input {
  width: 50px;
  text-align: center;
  background: transparent;
  border: 0;
  font-family: inherit;
  font-weight: 600;
  font-size: 1rem;
  font-variant-numeric: tabular-nums;
  color: var(--ink);
}
.stepper input:focus { outline: none; }

/* Booking success state */
.booking-success {
  display: none;
  text-align: center;
  padding: var(--sp-5) var(--sp-3);
}
.booking-card.is-success .booking-success { display: block; }
.booking-card.is-success .booking-form { display: none; }
.booking-success__mark {
  width: 72px; height: 72px;
  margin-inline: auto;
  border-radius: 50%;
  background: var(--khareef-mist);
  display: grid; place-items: center;
  color: var(--khareef-deep);
}
.booking-success__title {
  margin-top: var(--sp-4);
  font-size: 1.4rem;
  font-weight: 700;
}
.booking-success__text {
  margin-top: var(--sp-2);
  color: var(--ink-soft);
}
.booking-success__ref {
  display: inline-block;
  margin-top: var(--sp-4);
  padding: 6px 14px;
  background: var(--cream);
  border-radius: var(--r-pill);
  font-family: ui-monospace, monospace;
  font-size: 0.85rem;
  color: var(--moss-deep);
}
.booking-success__ctas {
  margin-top: var(--sp-5);
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-3);
  justify-content: center;
}

/* ----- Contact ----- */
.contact-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-5);
  margin-top: var(--sp-6);
}
@media (min-width: 720px) {
  .contact-grid { grid-template-columns: repeat(3, 1fr); }
}
.contact-card {
  background: var(--paper);
  border: 1px solid var(--mist);
  border-radius: var(--r-md);
  padding: var(--sp-5);
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}
.contact-card__icon {
  width: 38px; height: 38px;
  display: grid; place-items: center;
  background: var(--cream);
  border-radius: 50%;
  color: var(--moss);
  margin-bottom: var(--sp-2);
}
.contact-card__label { font-size: var(--fs-small); color: var(--ink-mute); }
.contact-card__value {
  font-size: 1.05rem;
  color: var(--ink);
  font-weight: 600;
  word-break: break-word;
}
.contact-card a { color: var(--ink); }
.contact-card a:hover { color: var(--moss); }

/* ----- Footer ----- */
.site-footer {
  background: var(--ink);
  color: var(--cream);
  padding-block: var(--sp-7);
  margin-top: var(--sp-8);
  position: relative;
}
.site-footer .container { display: grid; gap: var(--sp-5); }
.site-footer__top { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: var(--sp-4); }
.site-footer .brand__name { color: var(--paper); }
.site-footer .brand__sub { color: var(--stone); }
.site-footer .brand__mark { background: rgba(250, 246, 232, 0.08); border-color: rgba(250, 246, 232, 0.18); }
.site-footer__bottom {
  border-top: 1px solid rgba(250, 246, 232, 0.12);
  padding-top: var(--sp-5);
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-3);
  justify-content: space-between;
  font-size: var(--fs-small);
  color: var(--stone);
}
.site-footer a { color: var(--cream); }

/* ----- Sticky mobile CTA ----- */
.sticky-cta {
  position: fixed;
  bottom: max(14px, env(safe-area-inset-bottom));
  inset-inline: 14px;
  z-index: 30;
  display: flex;
  gap: 10px;
  align-items: center;
}
.sticky-cta .btn {
  box-shadow: var(--sh-3);
  height: 54px;
  min-height: 54px;
}
.sticky-cta .btn:not(.btn-icon) {
  flex: 1 1 auto;
  min-width: 0;
}
.sticky-cta .btn-icon {
  flex: 0 0 54px;
  width: 54px;
  height: 54px;
  padding: 0;
  border-radius: 50%;
}
@media (min-width: 720px) {
  .sticky-cta { display: none; }
}
@media (max-width: 719px) {
  body { padding-bottom: 90px; }
}

/* ----- Section ornament dividers — pine-tree motif ----- */
.ornament {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-3);
  color: var(--moss-soft);
  margin-block: var(--sp-6);
}
.ornament svg { width: 28px; height: 28px; }
.ornament::before,
.ornament::after {
  content: "";
  flex: 0 1 100px;
  height: 1px;
  background: linear-gradient(to var(--ornament-dir, right), transparent, var(--moss-soft));
}
.ornament::after { --ornament-dir: left; }
