/* ==========================================================================
   RideForge — Sections & page layouts (loaded after the inlined design system)
   ========================================================================== */

/* ---------- Shared section heading ---------- */
.rf-head { max-width: 64ch; margin-bottom: clamp(28px, 4vw, 48px); }
.rf-head--center { margin-inline: auto; text-align: center; }
.rf-head__title { font-size: clamp(28px, 4vw, 44px); margin: 12px 0 14px; }
.rf-head__lead { font-size: clamp(16px, 2vw, 18px); color: var(--rf-ink-2); }
.rf-section--dark .rf-head__lead { color: var(--rf-on-dark-2); }

/* ==========================================================================
   HERO
   ========================================================================== */
.rf-hero {
  position: relative; color: var(--rf-on-dark); overflow: clip;
  background:
    radial-gradient(120% 90% at 85% -10%, rgba(15,163,163,.28), transparent 55%),
    radial-gradient(90% 80% at 5% 110%, rgba(251,176,52,.14), transparent 50%),
    linear-gradient(160deg, var(--rf-dark) 0%, var(--rf-dark-2) 100%);
}
.rf-hero__inner {
  display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(28px, 5vw, 64px);
  align-items: center; padding-block: clamp(48px, 7vw, 96px); position: relative; z-index: 2;
}
.rf-hero__title { color: #fff; font-size: clamp(34px, 5.4vw, 60px); line-height: 1.04; margin: 16px 0 18px; }
.rf-hero__title .rf-accent { color: var(--rf-accent); }
.rf-hero__sub { font-size: clamp(16px, 2.1vw, 20px); color: var(--rf-on-dark); opacity: .92; max-width: 46ch; }
.rf-hero__cta { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 26px; }
.rf-hero__pills { display: flex; flex-wrap: wrap; gap: 10px 22px; margin-top: 26px; }
.rf-hero__pill { display: inline-flex; align-items: center; gap: 8px; font-size: 14px; font-weight: 600; color: var(--rf-on-dark); }
.rf-hero__pill .rf-ico { color: var(--rf-accent); }
.rf-hero__rating { display: inline-flex; align-items: center; gap: 10px; margin-top: 24px; font-size: 14px; color: var(--rf-on-dark-2); }
.rf-hero__rating .rf-stars { color: var(--rf-accent); }
.rf-hero__badge { display: inline-flex; align-items: center; gap: 8px; padding: 7px 14px; border-radius: var(--rf-r-pill); background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.14); font-size: 13px; font-weight: 600; color: #fff; }
.rf-hero__badge .rf-dot { width: 8px; height: 8px; border-radius: 50%; background: #34d399; box-shadow: 0 0 0 4px rgba(52,211,153,.25); }

/* ==========================================================================
   BOOKING WIDGET
   ========================================================================== */
.rf-booking {
  background: var(--rf-card); color: var(--rf-ink); border-radius: var(--rf-r-lg);
  box-shadow: var(--rf-shadow-lg); padding: clamp(18px, 2.4vw, 26px); position: relative;
  border: 1px solid var(--rf-line);
}
.rf-booking__head { margin-bottom: 16px; }
.rf-booking__title { font-size: 20px; }
.rf-booking__hint { font-size: 13px; color: var(--rf-ink-3); margin-top: 2px; }
.rf-booking__vehicles { display: grid; grid-template-columns: repeat(auto-fit, minmax(86px, 1fr)); gap: 8px; margin-bottom: 16px; }
.rf-veh {
  display: flex; flex-direction: column; align-items: center; gap: 5px; padding: 11px 6px;
  border: 1.5px solid var(--rf-line); border-radius: var(--rf-r-sm); background: var(--rf-bg);
  cursor: pointer; transition: all var(--rf-t); text-align: center;
}
.rf-veh:hover { border-color: var(--rf-primary); }
.rf-veh.is-active { border-color: var(--rf-primary); background: var(--rf-primary-50); box-shadow: var(--rf-ring); }
.rf-veh__icon { color: var(--rf-primary); }
.rf-veh__name { font-size: 11.5px; font-weight: 700; font-family: var(--rf-display); line-height: 1.1; }
.rf-veh__seats { font-size: 10.5px; color: var(--rf-ink-3); }
.rf-booking__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.rf-booking__grid .rf-span-2 { grid-column: 1 / -1; }
.rf-booking__route { position: relative; display: grid; gap: 12px; }
.rf-booking__est {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  margin-top: 14px; padding: 14px 16px; border-radius: var(--rf-r-sm);
  background: var(--rf-primary-50); border: 1px dashed var(--rf-primary);
  min-height: 56px;
}
.rf-booking__est-label { font-size: 13px; color: var(--rf-ink-2); font-weight: 600; }
.rf-booking__est-value { font-family: var(--rf-display); font-weight: 800; font-size: 22px; color: var(--rf-primary-700); }
.rf-booking__est-tag { font-size: 11.5px; color: var(--rf-ink-3); }
.rf-booking__est.is-empty { background: var(--rf-bg-2); border-style: solid; border-color: var(--rf-line); color: var(--rf-ink-3); }
.rf-booking__submit { margin-top: 16px; }
.rf-booking__legal { font-size: 11.5px; color: var(--rf-ink-3); margin-top: 10px; text-align: center; }
.rf-booking__result { margin-top: 16px; padding: 18px; border-radius: var(--rf-r); background: var(--rf-bg-2); border: 1px solid var(--rf-line); display: none; }
.rf-booking__result.is-show { display: block; }
.rf-booking__result-ico { display: inline-grid; place-items: center; width: 46px; height: 46px; border-radius: 50%; background: var(--rf-success); color: #fff; margin-bottom: 10px; }
.rf-booking__ref { font-family: var(--rf-display); font-weight: 800; font-size: 18px; }
.rf-booking__msg { color: var(--rf-ink-2); margin: 6px 0 14px; }
.rf-alert { padding: 11px 14px; border-radius: var(--rf-r-sm); font-size: 14px; font-weight: 500; margin-top: 12px; display: none; }
.rf-alert.is-show { display: block; }
.rf-alert--error { background: #fef2f2; color: var(--rf-danger); border: 1px solid #fecaca; }
body.rf-dark .rf-alert--error { background: #2a1416; border-color: #5b2326; }
.rf-spin { display: inline-block; width: 16px; height: 16px; border: 2px solid currentColor; border-right-color: transparent; border-radius: 50%; animation: rf-spin .7s linear infinite; vertical-align: -3px; margin-right: 7px; }
@keyframes rf-spin { to { transform: rotate(360deg); } }
.rf-booking--page { max-width: 760px; margin-inline: auto; }

/* ==========================================================================
   STATS / TRUST BAR
   ========================================================================== */
.rf-stats__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(16px, 3vw, 32px); }
.rf-stat { text-align: center; padding: 8px; }
.rf-stat__num { font-family: var(--rf-display); font-weight: 800; font-size: clamp(28px, 4vw, 44px); color: var(--rf-primary); line-height: 1; }
.rf-stat__label { margin-top: 8px; font-size: 14px; color: var(--rf-ink-2); font-weight: 500; }
.rf-section--dark .rf-stat__num { color: var(--rf-accent); }
.rf-section--dark .rf-stat__label { color: var(--rf-on-dark-2); }

/* Logo / trust strip */
.rf-trust { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 16px 40px; }
.rf-trust__item { display: inline-flex; align-items: center; gap: 9px; font-weight: 600; font-size: 14.5px; color: var(--rf-ink-2); }
.rf-trust__item .rf-ico { color: var(--rf-primary); }

/* ==========================================================================
   SERVICES
   ========================================================================== */
.rf-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(16px, 2.4vw, 26px); }
.rf-card {
  background: var(--rf-card); border: 1px solid var(--rf-line); border-radius: var(--rf-r-lg);
  padding: clamp(20px, 2.4vw, 28px); transition: transform var(--rf-t), box-shadow var(--rf-t), border-color var(--rf-t);
  display: flex; flex-direction: column;
}
.rf-card:hover { transform: translateY(-4px); box-shadow: var(--rf-shadow-lg); border-color: transparent; }
.rf-card__icon { display: inline-grid; place-items: center; width: 56px; height: 56px; border-radius: var(--rf-r); color: var(--rf-primary); background: var(--rf-primary-50); margin-bottom: 16px; }
.rf-card__title { font-size: 20px; margin-bottom: 8px; }
.rf-card__text { color: var(--rf-ink-2); font-size: 15px; flex: 1; }
.rf-card__foot { display: flex; align-items: center; justify-content: space-between; margin-top: 18px; }
.rf-card__price { font-family: var(--rf-display); font-weight: 700; font-size: 14px; color: var(--rf-ink); }
.rf-card__price span { color: var(--rf-ink-3); font-weight: 600; font-size: 12px; }
.rf-card__link { display: inline-flex; align-items: center; gap: 6px; font-weight: 700; font-size: 14px; color: var(--rf-primary); }
.rf-card__link:hover { gap: 9px; }
.rf-card__media { margin: calc(-1 * clamp(20px,2.4vw,28px)) calc(-1 * clamp(20px,2.4vw,28px)) 18px; border-radius: var(--rf-r-lg) var(--rf-r-lg) 0 0; overflow: hidden; aspect-ratio: 16 / 10; background: var(--rf-bg-3); }
.rf-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--rf-t-slow); }
.rf-card:hover .rf-card__media img { transform: scale(1.05); }

/* ==========================================================================
   WHY CHOOSE
   ========================================================================== */
.rf-why__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(20px, 3vw, 36px); }
.rf-feature { display: flex; gap: 16px; }
.rf-feature__icon { display: inline-grid; place-items: center; width: 52px; height: 52px; flex: none; border-radius: var(--rf-r); color: #fff; background: linear-gradient(135deg, var(--rf-primary), var(--rf-primary-700)); box-shadow: var(--rf-shadow-sm); }
.rf-feature__title { font-size: 17px; margin-bottom: 6px; }
.rf-feature__text { color: var(--rf-ink-2); font-size: 14.5px; }

/* ==========================================================================
   FLEET
   ========================================================================== */
.rf-fleet__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(18px, 2.6vw, 28px); }
.rf-fleetcard { background: var(--rf-card); border: 1px solid var(--rf-line); border-radius: var(--rf-r-lg); overflow: hidden; transition: transform var(--rf-t), box-shadow var(--rf-t); }
.rf-fleetcard:hover { transform: translateY(-4px); box-shadow: var(--rf-shadow-lg); }
.rf-fleetcard__media { aspect-ratio: 16 / 10; background: var(--rf-bg-3); overflow: hidden; }
.rf-fleetcard__media img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--rf-t-slow); }
.rf-fleetcard:hover .rf-fleetcard__media img { transform: scale(1.05); }
.rf-fleetcard__media--placeholder { display: grid; place-items: center; color: var(--rf-primary); background: linear-gradient(135deg, var(--rf-primary-50), var(--rf-bg-3)); }
.rf-fleetcard__body { padding: 20px; }
.rf-fleetcard__name { font-size: 19px; margin-bottom: 6px; }
.rf-fleetcard__meta { display: flex; flex-wrap: wrap; gap: 14px; margin-bottom: 10px; font-size: 13px; color: var(--rf-ink-2); }
.rf-fleetcard__meta span { display: inline-flex; align-items: center; gap: 6px; }
.rf-fleetcard__meta .rf-ico { color: var(--rf-primary); }
.rf-fleetcard__text { color: var(--rf-ink-2); font-size: 14.5px; }

/* ==========================================================================
   POPULAR ROUTES
   ========================================================================== */
.rf-routes__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.rf-route {
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  background: var(--rf-card); border: 1px solid var(--rf-line); border-radius: var(--rf-r);
  padding: 16px 18px; transition: border-color var(--rf-t), box-shadow var(--rf-t), transform var(--rf-t);
}
.rf-route:hover { border-color: var(--rf-primary); box-shadow: var(--rf-shadow); transform: translateY(-2px); }
.rf-route__path { display: flex; align-items: center; gap: 8px; font-family: var(--rf-display); font-weight: 700; font-size: 15px; }
.rf-route__path .rf-ico { color: var(--rf-primary); }
.rf-route__from, .rf-route__to { white-space: nowrap; }
.rf-route__arrow { color: var(--rf-ink-3); }
.rf-route__sub { font-size: 12.5px; color: var(--rf-ink-3); margin-top: 3px; }
.rf-route__price { text-align: right; }
.rf-route__amount { font-family: var(--rf-display); font-weight: 800; font-size: 17px; color: var(--rf-primary-700); }
.rf-route__cta { font-size: 12px; color: var(--rf-ink-3); }
.rf-route__price span { font-size: 11px; color: var(--rf-ink-3); display: block; }

/* ==========================================================================
   HOW IT WORKS
   ========================================================================== */
.rf-steps__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(18px, 3vw, 30px); counter-reset: step; }
.rf-step { position: relative; text-align: center; }
.rf-step__num { display: inline-grid; place-items: center; width: 56px; height: 56px; border-radius: 50%; margin: 0 auto 16px; font-family: var(--rf-display); font-weight: 800; font-size: 22px; color: #fff; background: linear-gradient(135deg, var(--rf-primary), var(--rf-primary-700)); box-shadow: var(--rf-shadow); }
.rf-step__title { font-size: 17px; margin-bottom: 7px; }
.rf-step__text { color: var(--rf-ink-2); font-size: 14.5px; }
.rf-steps--line .rf-step:not(:last-child)::after { content: ""; position: absolute; top: 28px; left: calc(50% + 36px); right: calc(-50% + 36px); height: 2px; background: var(--rf-line); }

/* ==========================================================================
   TESTIMONIALS
   ========================================================================== */
.rf-testimonials__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(18px, 2.6vw, 26px); }
.rf-quote { background: var(--rf-card); border: 1px solid var(--rf-line); border-radius: var(--rf-r-lg); padding: clamp(22px, 2.6vw, 30px); display: flex; flex-direction: column; gap: 14px; }
.rf-quote__stars { color: var(--rf-accent); }
.rf-quote__text { font-size: 16px; color: var(--rf-ink); line-height: 1.6; flex: 1; }
.rf-quote__by { display: flex; align-items: center; gap: 12px; }
.rf-quote__avatar { display: inline-grid; place-items: center; width: 44px; height: 44px; border-radius: 50%; font-family: var(--rf-display); font-weight: 800; color: #fff; background: linear-gradient(135deg, var(--rf-primary), var(--rf-primary-700)); flex: none; }
.rf-quote__name { font-weight: 700; font-family: var(--rf-display); font-size: 15px; }
.rf-quote__role { font-size: 13px; color: var(--rf-ink-3); }

/* ==========================================================================
   APP PROMO
   ========================================================================== */
.rf-app__inner { display: grid; grid-template-columns: 1.1fr .9fr; gap: clamp(28px, 5vw, 60px); align-items: center; }
.rf-app__title { color: #fff; font-size: clamp(28px, 4vw, 42px); margin-bottom: 16px; }
.rf-app__list { display: grid; gap: 12px; margin: 20px 0 26px; }
.rf-app__item { display: flex; align-items: center; gap: 12px; color: var(--rf-on-dark); font-weight: 500; }
.rf-app__item .rf-ico { color: var(--rf-accent); flex: none; }
.rf-app__badges { display: flex; flex-wrap: wrap; gap: 12px; }
.rf-app__visual { position: relative; display: grid; place-items: center; min-height: 280px; }
.rf-phone {
  width: min(260px, 70%); aspect-ratio: 9 / 18; border-radius: 34px; background: linear-gradient(160deg, #1b2740, #0e1626);
  border: 8px solid #060b15; box-shadow: var(--rf-shadow-lg); position: relative; overflow: hidden;
}
.rf-phone::before { content: ""; position: absolute; top: 12px; left: 50%; transform: translateX(-50%); width: 90px; height: 18px; border-radius: 0 0 14px 14px; background: #060b15; }
.rf-phone__screen { position: absolute; inset: 14px; border-radius: 24px; background: radial-gradient(120% 60% at 50% 0%, rgba(15,163,163,.35), transparent 60%), linear-gradient(180deg, #0f1828, #0b1320); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 10px; padding: 20px; text-align: center; }
.rf-phone__mark { display: inline-grid; place-items: center; width: 60px; height: 60px; border-radius: 18px; color: #fff; background: linear-gradient(135deg, var(--rf-primary), var(--rf-primary-700)); }
.rf-phone__brand { color: #fff; font-family: var(--rf-display); font-weight: 800; font-size: 20px; }
.rf-phone__tag { color: var(--rf-on-dark-2); font-size: 12.5px; }

/* ==========================================================================
   CORPORATE
   ========================================================================== */
.rf-corporate__inner { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(28px, 5vw, 56px); align-items: center; }
.rf-corporate__list { display: grid; grid-template-columns: 1fr 1fr; gap: 12px 22px; margin-top: 20px; }
.rf-corporate__item { display: flex; align-items: center; gap: 10px; font-weight: 600; font-size: 14.5px; color: var(--rf-ink-2); }
.rf-corporate__item .rf-ico { color: var(--rf-primary); flex: none; }
.rf-corporate__panel { background: var(--rf-card); border: 1px solid var(--rf-line); border-radius: var(--rf-r-lg); padding: clamp(24px, 3vw, 36px); box-shadow: var(--rf-shadow); }
.rf-corporate__panel h3 { font-size: 22px; margin-bottom: 10px; }

/* ==========================================================================
   FINAL CTA
   ========================================================================== */
.rf-cta__box {
  position: relative; overflow: hidden; border-radius: var(--rf-r-xl);
  padding: clamp(32px, 5vw, 64px); text-align: center; color: #fff;
  background:
    radial-gradient(100% 120% at 100% 0%, rgba(251,176,52,.22), transparent 50%),
    linear-gradient(135deg, var(--rf-primary-700), var(--rf-primary));
  box-shadow: var(--rf-shadow-lg);
}
.rf-cta__title { color: #fff; font-size: clamp(26px, 4vw, 42px); margin-bottom: 14px; }
.rf-cta__text { color: rgba(255,255,255,.92); font-size: clamp(15px, 2vw, 18px); max-width: 56ch; margin: 0 auto 26px; }
.rf-cta__actions { display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; }

/* ==========================================================================
   PAGE / CONTENT
   ========================================================================== */
.rf-page-hero { background: var(--rf-bg-2); border-bottom: 1px solid var(--rf-line); padding-block: clamp(32px, 5vw, 60px); }
.rf-page-hero__title { font-size: clamp(28px, 4.4vw, 46px); }
.rf-page-hero__lead { font-size: clamp(16px, 2vw, 18px); color: var(--rf-ink-2); margin-top: 10px; max-width: 64ch; }
.rf-content { max-width: 760px; margin-inline: auto; }
.rf-content > * + * { margin-top: 1.1em; }
.rf-content h2 { font-size: 28px; margin-top: 1.6em; }
.rf-content h3 { font-size: 22px; margin-top: 1.4em; }
.rf-content p, .rf-content li { color: var(--rf-ink-2); }
.rf-content ul { list-style: disc; padding-inline-start: 1.2em; }
.rf-content ul li { margin-top: .4em; }
.rf-content img { border-radius: var(--rf-r); }
.rf-content a { text-decoration: underline; text-underline-offset: 2px; }
.rf-prose-wrap { padding-block: var(--rf-section); }

/* Contact layout */
.rf-contact__grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: clamp(28px, 4vw, 48px); align-items: start; }
.rf-contact__cards { display: grid; gap: 14px; }
.rf-contact__card { display: flex; gap: 14px; padding: 18px; border: 1px solid var(--rf-line); border-radius: var(--rf-r); background: var(--rf-card); }
.rf-contact__card .rf-ico { color: var(--rf-primary); flex: none; }
.rf-contact__card h4 { font-size: 15px; margin-bottom: 3px; }
.rf-contact__card a, .rf-contact__card p { color: var(--rf-ink-2); font-size: 14.5px; }

/* Single service */
.rf-single__layout { display: grid; grid-template-columns: 1fr 360px; gap: clamp(28px, 4vw, 48px); align-items: start; }
.rf-single__aside { position: sticky; top: 100px; }
.rf-single__card { background: var(--rf-card); border: 1px solid var(--rf-line); border-radius: var(--rf-r-lg); padding: 24px; box-shadow: var(--rf-shadow); }
.rf-single__price { font-family: var(--rf-display); font-weight: 800; font-size: 28px; color: var(--rf-primary-700); }
.rf-single__price span { font-size: 13px; color: var(--rf-ink-3); font-weight: 600; }

/* 404 */
.rf-404 { text-align: center; padding-block: clamp(60px, 10vw, 120px); }
.rf-404__code { font-family: var(--rf-display); font-weight: 800; font-size: clamp(72px, 16vw, 160px); line-height: 1; background: linear-gradient(135deg, var(--rf-primary), var(--rf-accent)); -webkit-background-clip: text; background-clip: text; color: transparent; }
.rf-404__actions { display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; margin-top: 24px; }

/* Archive grid reuse */
.rf-archive { padding-block: var(--rf-section); }

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media (max-width: 1024px) {
  .rf-cards, .rf-fleet__grid, .rf-routes__grid, .rf-testimonials__grid, .rf-why__grid { grid-template-columns: repeat(2, 1fr); }
  .rf-steps__grid { grid-template-columns: repeat(2, 1fr); }
  .rf-steps--line .rf-step::after { display: none; }
  .rf-single__layout { grid-template-columns: 1fr; }
  .rf-single__aside { position: static; }
}
@media (max-width: 880px) {
  .rf-hero__inner { grid-template-columns: 1fr; }
  .rf-app__inner, .rf-corporate__inner, .rf-contact__grid { grid-template-columns: 1fr; }
  .rf-app__visual { order: -1; }
  .rf-stats__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .rf-cards, .rf-fleet__grid, .rf-routes__grid, .rf-testimonials__grid, .rf-why__grid, .rf-steps__grid, .rf-corporate__list { grid-template-columns: 1fr; }
  .rf-booking__vehicles { grid-template-columns: repeat(2, 1fr); }
  .rf-booking__grid { grid-template-columns: 1fr; }
  .rf-feature { flex-direction: column; gap: 10px; }
}

/* ==========================================================================
   SUPPLEMENTAL — sub-elements added with the template layer
   ========================================================================== */

/* Corporate CTA cluster */
.rf-corporate__actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 22px; }

/* Single service — price + aside details */
.rf-single__price { display: flex; align-items: baseline; gap: 8px; margin-bottom: 14px; }
.rf-single__price-label { font-size: 13px; font-weight: 600; color: var(--rf-ink-3); text-transform: uppercase; letter-spacing: .04em; }
.rf-single__price-value { font-family: var(--rf-display); font-weight: 800; font-size: 30px; color: var(--rf-primary); line-height: 1; }
.rf-single__card-text { color: var(--rf-ink-2); font-size: 14.5px; margin-bottom: 16px; }
.rf-single__card .rf-btn + .rf-btn { margin-top: 10px; }
.rf-single__usp { list-style: none; margin: 18px 0 0; padding: 16px 0 0; border-top: 1px solid var(--rf-line); display: grid; gap: 10px; }
.rf-single__usp li { display: flex; align-items: center; gap: 10px; font-size: 14px; font-weight: 600; color: var(--rf-ink-2); }
.rf-single__usp .rf-ico { color: var(--rf-success); flex: none; }

/* Card CTA chevron (archive + lists) */
.rf-card__cta { display: inline-flex; align-items: center; gap: 6px; font-weight: 700; font-size: 14px; color: var(--rf-primary); }
.rf-card__foot { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-top: auto; padding-top: 14px; }

/* 404 */
.rf-404__inner { max-width: 640px; margin-inline: auto; text-align: center; }
.rf-404__code { font-family: var(--rf-display); font-weight: 800; font-size: clamp(64px, 14vw, 120px); line-height: 1; color: var(--rf-primary); opacity: .18; margin-bottom: -10px; }
.rf-404__actions { display: flex; flex-wrap: wrap; justify-content: center; gap: 12px; margin-top: 26px; }
.rf-404__search { margin-top: 26px; max-width: 420px; margin-inline: auto; }

/* Booking page reassurance row */
.rf-bookpage__usp { list-style: none; margin: 26px 0 0; padding: 0; display: flex; flex-wrap: wrap; justify-content: center; gap: 14px 26px; }
.rf-bookpage__usp li { display: flex; align-items: center; gap: 8px; font-size: 14px; font-weight: 600; color: var(--rf-ink-2); }
.rf-bookpage__usp .rf-ico { color: var(--rf-primary); flex: none; }

/* Contact page right column */
.rf-contact__panel { display: grid; gap: 18px; }
.rf-contact__map { border-radius: var(--rf-r); overflow: hidden; border: 1px solid var(--rf-line); line-height: 0; }
.rf-contact__cta { padding: clamp(20px, 3vw, 28px); border: 1px solid var(--rf-line); border-radius: var(--rf-r-lg); background: var(--rf-card); box-shadow: var(--rf-shadow); }
.rf-contact__cta h3 { font-size: 20px; margin-bottom: 6px; }
.rf-contact__cta p { color: var(--rf-ink-2); font-size: 14.5px; margin-bottom: 16px; }
.rf-contact__cta-actions { display: flex; flex-wrap: wrap; gap: 12px; }

/* Paginated post links */
.rf-pagelinks { margin-top: 1.4em; font-weight: 600; }
.rf-pagelinks a, .rf-pagelinks > span { display: inline-block; min-width: 36px; text-align: center; padding: 6px 10px; margin: 0 4px 4px 0; border: 1px solid var(--rf-line); border-radius: var(--rf-r-sm); text-decoration: none; }
.rf-pagelinks a:hover { border-color: var(--rf-primary); color: var(--rf-primary); }

@media (max-width: 560px) {
  .rf-corporate__actions .rf-btn, .rf-contact__cta-actions .rf-btn, .rf-404__actions .rf-btn { flex: 1 1 100%; justify-content: center; }
}

/* ==========================================================================
   GOOGLE-POWERED BOOKING — logo, map, pickers, route chips, vehicle preview
   ========================================================================== */

/* Brand logo image (header + footer) */
.rf-brand__logo { display: inline-flex; align-items: center; }
.rf-brand__logo img { height: 44px; width: auto; display: block; }
.rf-brand__logo--footer img { height: 40px; }
@media (max-width: 600px) { .rf-brand__logo img { height: 38px; } }

/* Pick-up / drop-off with coloured dots */
.rf-place { position: relative; }
.rf-place__input { padding-left: 15px; }
/* Coloured route dots removed by design — the placeholder alone guides the user. */
.rf-place__dot { display: none; }

/* Live route map */
.rf-booking__map {
  height: 220px; margin-top: 12px; border-radius: var(--rf-r);
  border: 1px solid var(--rf-line); overflow: hidden; background: var(--rf-bg-2);
}

/* Distance / duration chips */
.rf-booking__trip { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 12px; transition: opacity var(--rf-t); }
.rf-booking__trip.is-empty { opacity: .5; }
.rf-trip__item {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 7px 13px; border-radius: var(--rf-r-pill);
  background: var(--rf-primary-50); color: var(--rf-ink-2);
  font-size: 13px; font-weight: 600;
}
.rf-trip__item .rf-ico { color: var(--rf-primary); }
.rf-trip__item b { color: var(--rf-ink); font-weight: 800; font-family: var(--rf-display); }

/* Vehicle meta line (seats · bags · A/C) */
.rf-veh__meta { font-size: 10.5px; color: var(--rf-ink-3); line-height: 1.2; }

/* Selected-vehicle preview with a real photo */
.rf-booking__veh-preview {
  display: flex; align-items: center; gap: 14px; margin-top: 14px; padding: 10px;
  border: 1px solid var(--rf-line); border-radius: var(--rf-r); background: var(--rf-card);
}
.rf-booking__veh-preview.is-empty { display: none; }
.rf-vehprev__img { width: 112px; height: 74px; object-fit: cover; border-radius: 10px; flex: none; background: var(--rf-bg-2); }
.rf-vehprev__body { min-width: 0; }
.rf-vehprev__name { font-family: var(--rf-display); font-weight: 800; font-size: 15px; color: var(--rf-ink); }
.rf-vehprev__tag { font-size: 12.5px; color: var(--rf-ink-3); margin: 1px 0 3px; }
.rf-vehprev__specs { font-size: 12.5px; font-weight: 600; color: var(--rf-primary-700); }

/* Custom date / time triggers (styled like inputs) */
.rf-field--picker { position: relative; }
.rf-picker {
  display: flex; align-items: center; gap: 10px; width: 100%;
  text-align: left; cursor: pointer; font: inherit; line-height: 1.2;
}
.rf-picker__icon { color: var(--rf-ink-3); display: inline-flex; flex: none; }
.rf-picker__value { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.rf-picker__value.is-placeholder { color: var(--rf-ink-3); }
.rf-picker[aria-expanded="true"] { border-color: var(--rf-primary); box-shadow: var(--rf-ring); }

/* Calendar popover */
.rf-cal {
  position: absolute; top: calc(100% + 6px); left: 0; z-index: 60;
  width: 286px; max-width: calc(100vw - 40px); padding: 12px;
  background: var(--rf-card); border: 1px solid var(--rf-line);
  border-radius: var(--rf-r); box-shadow: var(--rf-shadow-lg);
}
.rf-cal[hidden] { display: none; }
.rf-cal__head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
.rf-cal__title { font-family: var(--rf-display); font-weight: 700; font-size: 14.5px; color: var(--rf-ink); }
.rf-cal__nav {
  width: 30px; height: 30px; display: flex; align-items: center; justify-content: center;
  border: 1px solid var(--rf-line); border-radius: 8px; background: transparent;
  cursor: pointer; color: var(--rf-ink-2); font-size: 18px; line-height: 1;
}
.rf-cal__nav:hover { border-color: var(--rf-primary); color: var(--rf-primary); }
.rf-cal__nav:disabled { opacity: .35; cursor: default; }
.rf-cal__grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 2px; }
.rf-cal__wd { text-align: center; font-size: 11px; font-weight: 600; color: var(--rf-ink-3); padding: 4px 0; }
.rf-cal__pad { aspect-ratio: 1; }
.rf-cal__day {
  aspect-ratio: 1; min-height: 34px; border: 0; background: transparent; border-radius: 9px;
  cursor: pointer; font-size: 13px; color: var(--rf-ink);
  display: flex; align-items: center; justify-content: center; transition: background var(--rf-t);
}
.rf-cal__day:hover { background: var(--rf-primary-50); }
.rf-cal__day.is-today { box-shadow: inset 0 0 0 1px var(--rf-primary); }
.rf-cal__day.is-selected { background: var(--rf-primary); color: #fff; font-weight: 700; }
.rf-cal__day:disabled, .rf-cal__day.is-disabled { opacity: .3; cursor: default; color: var(--rf-ink-3); }
.rf-cal__day:disabled:hover { background: transparent; }

/* Time popover */
.rf-times {
  position: absolute; top: calc(100% + 6px); left: 0; z-index: 60;
  width: 168px; max-height: 244px; overflow-y: auto; padding: 6px;
  background: var(--rf-card); border: 1px solid var(--rf-line);
  border-radius: var(--rf-r); box-shadow: var(--rf-shadow-lg);
}
.rf-times[hidden] { display: none; }
.rf-times__opt {
  display: block; width: 100%; text-align: left; border: 0; background: transparent;
  padding: 8px 12px; border-radius: 8px; cursor: pointer; font-size: 13.5px; color: var(--rf-ink);
}
.rf-times__opt:hover { background: var(--rf-primary-50); }
.rf-times__opt.is-selected { background: var(--rf-primary-50); color: var(--rf-primary-700); font-weight: 700; }
.rf-times__now { font-weight: 700; color: var(--rf-primary); border-bottom: 1px solid var(--rf-line); border-radius: 0; margin-bottom: 4px; }

/* Google Places autocomplete dropdown (appended to <body>) */
.pac-container {
  z-index: 100000; font-family: var(--rf-font, inherit);
  border-radius: 10px; margin-top: 4px; border: 1px solid var(--rf-line);
  box-shadow: var(--rf-shadow-lg); background: var(--rf-card);
}
.pac-item { padding: 7px 12px; font-size: 13.5px; color: var(--rf-ink-2); border-top: 1px solid var(--rf-line); cursor: pointer; }
.pac-item:hover, .pac-item-selected { background: var(--rf-primary-50); }
.pac-item-query { font-size: 13.5px; color: var(--rf-ink); }
.pac-matched { font-weight: 700; }

@media (max-width: 560px) {
  .rf-cal { left: 50%; transform: translateX(-50%); }
}

/* Unified live trip summary (distance + time + fare, calculated during booking) */
.rf-booking__summary {
  margin-top: 14px; padding: 14px 16px; border-radius: var(--rf-r);
  background: var(--rf-card); border: 1px solid var(--rf-line);
  transition: opacity var(--rf-t), border-color var(--rf-t);
}
.rf-booking__summary.is-empty { opacity: .72; }
.rf-booking__summary:not(.is-empty) { border-color: color-mix(in srgb, var(--rf-primary) 35%, var(--rf-line)); }
.rf-sum__metrics { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.rf-sum__cell { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.rf-sum__label { font-size: 11px; font-weight: 700; color: var(--rf-ink-3); text-transform: uppercase; letter-spacing: .045em; }
.rf-sum__num { font-size: 14px; color: var(--rf-ink-2); }
.rf-sum__num b { font-family: var(--rf-display); font-weight: 800; font-size: 21px; color: var(--rf-ink); }
.rf-sum__fare { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-top: 12px; padding-top: 12px; border-top: 1px dashed var(--rf-line); }
.rf-sum__fare-info { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.rf-sum__tag { font-size: 12px; color: var(--rf-ink-3); }
.rf-sum__price { font-family: var(--rf-display); font-weight: 800; font-size: 26px; line-height: 1.1; color: var(--rf-primary-700); white-space: nowrap; }
.rf-booking__summary.is-empty .rf-sum__price::before { content: '—'; color: var(--rf-ink-3); }

/* Language switcher (built-in) */
.rf-lang__cur { font-weight: 700; letter-spacing: .02em; }

/* ----------------------------------------------------------------------------
   Server address autocomplete (text-mode, RideForge Distance Engine plugin)
   Custom suggestions dropdown shown under pick-up / drop-off when the plugin
   provides a server key. Google Places handles suggestions in live-map mode.
---------------------------------------------------------------------------- */
.rf-ac {
	position: absolute;
	top: calc(100% + 6px);
	left: 0;
	right: 0;
	z-index: 99999;
	display: none;
	max-height: 288px;
	overflow-y: auto;
	background: var(--rf-card);
	border: 1px solid var(--rf-line);
	border-radius: var(--rf-r-sm);
	box-shadow: var(--rf-shadow-lg);
}
.rf-ac.is-open { display: block; }
.rf-ac__item {
	padding: 10px 12px 10px 14px;
	font-size: 14px;
	line-height: 1.35;
	color: var(--rf-ink);
	cursor: pointer;
	border-bottom: 1px solid var(--rf-line);
}
.rf-ac__item:last-child { border-bottom: 0; }
.rf-ac__item:hover,
.rf-ac__item.is-active {
	background: var(--rf-primary-50);
	color: var(--rf-primary);
}

/* ----------------------------------------------------------------------------
   Two-step booking: passenger details reveal after a quote
---------------------------------------------------------------------------- */
.rf-booking__step--details[hidden] { display: none; }
.rf-booking__step--details.is-open { animation: rf-step-in .25s ease; }
@keyframes rf-step-in { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }
.rf-booking__quote { margin-top: 18px; }
.rf-booking__back {
	display: inline-flex; align-items: center; gap: 6px; margin-bottom: 10px;
	background: none; border: 0; cursor: pointer; color: var(--rf-ink-3);
	font-weight: 600; font-size: 13px; padding: 4px 2px;
}
.rf-booking__back:hover { color: var(--rf-primary); }
.rf-booking__back .rf-ico { transform: rotate(180deg); }

.rf-promo__msg { display: block; margin-top: 6px; font-size: 12.5px; font-weight: 600; min-height: 1em; }
.rf-promo__msg.is-ok { color: var(--rf-success); }
.rf-promo__msg.is-bad { color: var(--rf-danger); }

/* ----------------------------------------------------------------------------
   International phone selector (flag + dial code + digits-only number)
---------------------------------------------------------------------------- */
.rf-tel { position: relative; display: flex; gap: 8px; align-items: stretch; }
.rf-tel__country {
	display: inline-flex; align-items: center; gap: 6px; flex: 0 0 auto;
	padding: 0 12px; height: 46px; border: 1px solid var(--rf-line); border-radius: var(--rf-r-sm);
	background: var(--rf-bg); color: var(--rf-ink); cursor: pointer; font-weight: 600;
	transition: border-color var(--rf-t);
}
.rf-tel__country:hover { border-color: var(--rf-primary); }
.rf-tel__flag { font-size: 18px; line-height: 1; }
.rf-tel__dial { font-size: 14px; font-variant-numeric: tabular-nums; }
.rf-tel__caret { font-size: 10px; color: var(--rf-ink-3); }
.rf-tel__num { flex: 1 1 auto; min-width: 0; }
.rf-tel__menu {
	position: absolute; top: calc(100% + 6px); left: 0; z-index: 99999;
	width: min(320px, 86vw); max-height: 300px; display: flex; flex-direction: column;
	background: var(--rf-card); border: 1px solid var(--rf-line); border-radius: var(--rf-r-sm);
	box-shadow: var(--rf-shadow-lg); overflow: hidden;
}
.rf-tel__menu[hidden] { display: none; }
.rf-tel__search {
	margin: 8px; padding: 8px 10px; border: 1px solid var(--rf-line); border-radius: var(--rf-r-sm);
	font-size: 14px; background: var(--rf-bg); color: var(--rf-ink); flex: 0 0 auto;
}
.rf-tel__list { overflow-y: auto; }
.rf-tel__opt {
	display: flex; align-items: center; gap: 10px; padding: 9px 12px; cursor: pointer;
	font-size: 14px; color: var(--rf-ink);
}
.rf-tel__opt:hover { background: var(--rf-primary-50); }
.rf-tel__optflag { font-size: 18px; }
.rf-tel__optname { flex: 1 1 auto; }
.rf-tel__optdial { color: var(--rf-ink-3); font-variant-numeric: tabular-nums; }

/* ----------------------------------------------------------------------------
   Round-trip toggle, return schedule & payment method
---------------------------------------------------------------------------- */
.rf-triptype {
	display: inline-flex; gap: 4px; padding: 4px; margin-bottom: 14px;
	background: var(--rf-bg-2); border: 1px solid var(--rf-line); border-radius: var(--rf-pill);
}
.rf-triptype__opt {
	border: 0; background: none; cursor: pointer; padding: 8px 18px; border-radius: var(--rf-pill);
	font-weight: 700; font-size: 13px; color: var(--rf-ink-2); font-family: var(--rf-display);
	transition: background var(--rf-t), color var(--rf-t);
}
.rf-triptype__opt.is-active { background: var(--rf-primary); color: #fff; box-shadow: var(--rf-shadow-sm); }

.rf-booking__return { padding-top: 4px; }
.rf-booking__return[hidden] { display: none; }
.rf-return__head {
	display: flex; align-items: center; gap: 6px; margin: 4px 0 10px;
	font-size: 12px; font-weight: 700; letter-spacing: .03em; text-transform: uppercase; color: var(--rf-ink-3);
}
.rf-return__head .rf-ico { transform: rotate(180deg); color: var(--rf-primary); }

.rf-pay { margin-top: 16px; display: grid; gap: 8px; }
.rf-pay__label { font-size: 13px; font-weight: 700; color: var(--rf-ink-2); }
.rf-pay__opt {
	display: flex; align-items: center; gap: 10px; padding: 12px 14px; cursor: pointer;
	border: 1.5px solid var(--rf-line); border-radius: var(--rf-r-sm); background: var(--rf-bg);
	font-size: 14px; transition: border-color var(--rf-t), background var(--rf-t);
}
.rf-pay__opt:hover { border-color: var(--rf-primary); }
.rf-pay__opt:has(input:checked) { border-color: var(--rf-primary); background: var(--rf-primary-50); }
.rf-pay__opt input { accent-color: var(--rf-primary); }

/* Disabled (past) time slots */
.rf-times__opt.is-disabled { opacity: .35; cursor: not-allowed; text-decoration: line-through; }

/* ----------------------------------------------------------------------------
   Vehicle seat-capacity feedback
---------------------------------------------------------------------------- */
.rf-veh.is-unavailable {
	opacity: .4; cursor: not-allowed; filter: grayscale(1);
	border-style: dashed; box-shadow: none;
}
.rf-veh.is-unavailable:hover { border-color: var(--rf-line); }
.rf-veh-note {
	margin: -6px 0 14px; font-size: 12.5px; font-weight: 600; color: var(--rf-ink-3);
	min-height: 1em;
}
.rf-veh-note.is-warn { color: var(--rf-danger); }

/* ----------------------------------------------------------------------------
   Booking widget — guarantee the action buttons are always on top & clickable
---------------------------------------------------------------------------- */
.rf-booking, .rf-booking__form, .rf-booking__step { position: relative; }
.rf-booking { overflow: visible; }
.rf-booking__quote, .rf-booking__submit { position: relative; z-index: 3; }

/* ----------------------------------------------------------------------------
   Contact page ([rideforge_contact])
---------------------------------------------------------------------------- */
.rf-contact { max-width: 1080px; margin-inline: auto; }
.rf-contact__grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: clamp(24px, 4vw, 56px); align-items: start; }
@media (max-width: 820px) { .rf-contact__grid { grid-template-columns: 1fr; } }
.rf-contact__title { font-size: clamp(26px, 3.4vw, 40px); margin: 0 0 12px; }
.rf-contact__lead { color: var(--rf-ink-2); font-size: 16px; margin: 0 0 22px; }
.rf-contact__list { list-style: none; margin: 0; padding: 0; display: grid; gap: 14px; }
.rf-contact__list li { display: flex; align-items: center; gap: 12px; font-size: 16px; }
.rf-contact__list a { color: var(--rf-ink); text-decoration: none; }
.rf-contact__list a:hover { color: var(--rf-primary); }
.rf-contact__ico { display: inline-grid; place-items: center; width: 38px; height: 38px; border-radius: 10px; background: var(--rf-primary-50); color: var(--rf-primary); flex: 0 0 auto; }
.rf-contact__form-wrap {
	background: var(--rf-card); border: 1px solid var(--rf-line); border-radius: var(--rf-r-lg);
	box-shadow: var(--rf-shadow); padding: clamp(20px, 2.6vw, 30px);
}
.rf-contact__form { display: grid; gap: 14px; }
.rf-contact__note { padding: 12px 15px; border-radius: var(--rf-r-sm); font-size: 14px; font-weight: 500; margin-bottom: 16px; }
.rf-contact__note--ok { background: #ecfdf5; color: #047857; border: 1px solid #a7f3d0; }
.rf-contact__note--err { background: #fef2f2; color: var(--rf-danger); border: 1px solid #fecaca; }
body.rf-dark .rf-contact__note--ok { background: #06281f; border-color: #0c4a39; }
body.rf-dark .rf-contact__note--err { background: #2a1416; border-color: #5b2326; }

/* Pick-up field helper hint */
.rf-place__hint { display: block; margin-top: 5px; font-size: 12px; color: var(--rf-ink-3); }

/* ----------------------------------------------------------------------------
   Horizontal booking form on desktop (stays vertical on mobile)
   On wide screens the hero stacks (headline above) and the booking widget
   becomes a full-width horizontal bar with fields laid out in rows.
---------------------------------------------------------------------------- */
@media (min-width: 992px) {
	.rf-hero__inner { grid-template-columns: 1fr; gap: 34px; }
	.rf-hero__copy { text-align: center; max-width: 880px; margin-inline: auto; }
	.rf-hero__pills { justify-content: center; }
	.rf-hero__widget { width: 100%; max-width: 1120px; margin-inline: auto; }

	/* Pick-up & drop-off side by side */
	.rf-booking__route { grid-template-columns: 1fr 1fr; align-items: end; }

	/* Schedule: date · time · passengers · luggage on one row */
	.rf-booking__grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
	.rf-booking__grid .rf-span-2 { grid-column: 1 / -1; }
	.rf-booking__return { grid-column: 1 / -1; }
	.rf-booking__return .rf-booking__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }

	/* Keep the action row tidy and full width */
	.rf-booking__quote { width: 100%; }
}

/* Extra-wide: give the schedule a touch more breathing room */
@media (min-width: 1200px) {
	.rf-booking__grid { gap: 16px; }
}

/* App phone screen — custom image variant */
.rf-phone__screen--img { padding: 0; overflow: hidden; }
.rf-phone__screen--img img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* ==========================================================================
   v1.10 — Claymorphism, booking placeholder, trust strip, SEO landing,
   Explore section, FAQ, mega-menu, legal layout, micro-interactions.
   ========================================================================== */

/* ---------- Claymorphism icon treatment ---------- */
.rf-clay,
.rf-card__icon,
.rf-lfeature__icon,
.rf-explore__pin,
.rf-related__ico {
  background: linear-gradient(145deg, color-mix(in srgb, var(--rf-primary) 16%, var(--rf-card)), var(--rf-card));
  box-shadow:
    6px 6px 14px rgba(10,18,32,.10),
    -5px -5px 12px color-mix(in srgb, #fff 70%, transparent),
    inset 2px 2px 4px color-mix(in srgb, #fff 55%, transparent),
    inset -3px -3px 6px rgba(10,18,32,.06);
  color: var(--rf-primary);
  border-radius: 18px;
}
body.rf-dark .rf-clay,
body.rf-dark .rf-card__icon,
body.rf-dark .rf-lfeature__icon,
body.rf-dark .rf-explore__pin,
body.rf-dark .rf-related__ico {
  box-shadow: 6px 6px 14px rgba(0,0,0,.4), -4px -4px 10px rgba(255,255,255,.03), inset 2px 2px 4px rgba(255,255,255,.04), inset -3px -3px 6px rgba(0,0,0,.3);
}
.rf-feature__icon, .rf-step__num {
  box-shadow: 6px 6px 14px rgba(10,18,32,.16), inset 2px 2px 5px rgba(255,255,255,.28), inset -3px -3px 6px rgba(0,0,0,.12);
}
.rf-card:hover .rf-card__icon { transform: translateY(-2px) rotate(-3deg); transition: transform var(--rf-t); }

/* ---------- Booking placeholder (premium empty state) ---------- */
.rf-bookbox__glow { position: absolute; inset: -20% 10% auto; height: 220px; z-index: 1; background: radial-gradient(60% 60% at 70% 20%, color-mix(in srgb, var(--rf-primary) 40%, transparent), transparent 70%); filter: blur(30px); pointer-events: none; }
.rf-bookbox__placeholder {
  position: relative; z-index: 2; background: var(--rf-card); border: 1px solid var(--rf-line);
  border-radius: var(--rf-r-lg); box-shadow: var(--rf-shadow-lg); padding: clamp(22px, 3vw, 32px); text-align: center;
}
.rf-bookbox__badge { display: inline-flex; align-items: center; gap: 8px; padding: 6px 13px; border-radius: var(--rf-r-pill); background: var(--rf-primary-50); color: var(--rf-primary-700); font-family: var(--rf-display); font-weight: 700; font-size: 12px; letter-spacing: .04em; }
.rf-bookbox__badge .rf-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--rf-primary); box-shadow: 0 0 0 4px color-mix(in srgb, var(--rf-primary) 25%, transparent); }
.rf-bookbox__title { font-size: clamp(19px, 2.4vw, 24px); margin: 14px 0 8px; }
.rf-bookbox__text { color: var(--rf-ink-2); font-size: 14.5px; max-width: 40ch; margin: 0 auto; }
.rf-bookbox__skeleton { display: grid; gap: 12px; margin: 22px 0; }
.rf-sk { display: block; border-radius: var(--rf-r-sm); background: linear-gradient(90deg, var(--rf-bg-3) 25%, var(--rf-bg-2) 37%, var(--rf-bg-3) 63%); background-size: 400% 100%; animation: rf-shimmer 1.4s ease infinite; }
.rf-sk--row { height: 46px; }
.rf-sk--split { display: flex; gap: 12px; background: none; animation: none; }
.rf-sk--split i { flex: 1; height: 46px; border-radius: var(--rf-r-sm); background: linear-gradient(90deg, var(--rf-bg-3) 25%, var(--rf-bg-2) 37%, var(--rf-bg-3) 63%); background-size: 400% 100%; animation: rf-shimmer 1.4s ease infinite; }
.rf-sk--btn { height: 52px; border-radius: var(--rf-r-pill); }
@keyframes rf-shimmer { 0% { background-position: 100% 0; } 100% { background-position: -100% 0; } }
@media (prefers-reduced-motion: reduce) { .rf-sk, .rf-sk--split i { animation: none; } }
.rf-bookbox__admin { font-size: 12px; color: var(--rf-ink-3); margin: 4px 0 18px; }
.rf-bookbox__cta { width: 100%; }

/* ---------- Trust & payment strip ---------- */
.rf-trustbar { border-top: 1px solid rgba(255,255,255,.08); padding-block: 22px; }
.rf-trustbar__inner { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 16px 28px; }
.rf-trustbar__msg { display: flex; align-items: center; gap: 10px; color: var(--rf-on-dark); font-size: 14px; font-weight: 500; max-width: 46ch; }
.rf-trustbar__lock { display: inline-grid; place-items: center; width: 34px; height: 34px; border-radius: 10px; background: rgba(255,255,255,.08); color: #5ee08a; flex: none; }
.rf-paylist { display: flex; flex-wrap: wrap; align-items: center; gap: 12px; }
.rf-payb { display: inline-flex; align-items: center; gap: 8px; }
.rf-payb svg { width: 52px; height: 31px; border-radius: 6px; box-shadow: 0 2px 8px rgba(0,0,0,.25); transition: transform var(--rf-t); }
.rf-payb:hover svg { transform: translateY(-2px); }
.rf-payb__bg { fill: #fff; }
.rf-payb__ink { color: #0A1220; }
.rf-payb__ok { color: #16a34a; }
.rf-payb__cash { color: #0A6F6F; }
.rf-payb__tx { fill: #0A1220; font: 700 7px var(--rf-display), sans-serif; letter-spacing: .04em; }
.rf-payb__visa { fill: #1434CB; font: 800 9px var(--rf-display), sans-serif; letter-spacing: .06em; }
.rf-payb__label { font-size: 13px; font-weight: 600; color: var(--rf-on-dark-2); }
.rf-payb__label--sr { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0 0 0 0); }
.rf-footer__sep { margin-inline: 10px; color: rgba(255,255,255,.25); }
.rf-footer__copy { color: var(--rf-on-dark-2); }

/* ---------- Explore / Destinations ---------- */
.rf-explore__inner { display: grid; grid-template-columns: .9fr 1.1fr; gap: clamp(28px, 5vw, 60px); align-items: center; }
.rf-explore__slot { box-shadow: var(--rf-shadow-lg); }
.rf-explore__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin: 22px 0; }
.rf-explore__place { display: flex; align-items: center; gap: 12px; padding: 12px 14px; border: 1px solid var(--rf-line); border-radius: var(--rf-r); background: var(--rf-card); transition: transform var(--rf-t), box-shadow var(--rf-t), border-color var(--rf-t); }
.rf-explore__place:hover { transform: translateY(-2px); box-shadow: var(--rf-shadow); border-color: transparent; }
.rf-explore__pin { display: inline-grid; place-items: center; width: 42px; height: 42px; flex: none; }
.rf-explore__meta { display: flex; flex-direction: column; line-height: 1.25; min-width: 0; }
.rf-explore__name { font-family: var(--rf-display); font-weight: 700; font-size: 15px; color: var(--rf-ink); }
.rf-explore__sub { font-size: 12px; color: var(--rf-ink-3); }
.rf-explore__go { margin-inline-start: auto; color: var(--rf-primary); transition: transform var(--rf-t); }
.rf-explore__place:hover .rf-explore__go { transform: translateX(3px); }
.rf-explore__all { margin-top: 4px; }

/* ---------- SEO landing hero ---------- */
.rf-lhero { background: var(--rf-bg-2); border-bottom: 1px solid var(--rf-line); }
.rf-lhero__inner { display: grid; grid-template-columns: 1.1fr .9fr; gap: clamp(28px, 5vw, 56px); align-items: center; padding-block: clamp(36px, 5vw, 64px); }
.rf-lhero__title { font-size: clamp(30px, 4.4vw, 48px); margin: 12px 0 14px; }
.rf-lhero__lead { font-size: clamp(16px, 2vw, 19px); color: var(--rf-ink-2); max-width: 52ch; }
.rf-lhero__cta { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 24px; }
.rf-lhero__usp { display: flex; flex-wrap: wrap; gap: 10px 22px; margin-top: 22px; }
.rf-lhero__usp li { display: inline-flex; align-items: center; gap: 8px; font-size: 14px; font-weight: 600; color: var(--rf-ink-2); }
.rf-lhero__usp .rf-ico { color: var(--rf-primary); }
.rf-lhero__slot { box-shadow: var(--rf-shadow-lg); }

/* Landing feature grid (claymorphism) */
.rf-lfeatures { display: grid; grid-template-columns: repeat(2, 1fr); gap: clamp(16px, 2.4vw, 24px); margin: 1.6em 0; }
.rf-lfeature { background: var(--rf-card); border: 1px solid var(--rf-line); border-radius: var(--rf-r-lg); padding: clamp(20px, 2.4vw, 26px); }
.rf-lfeature__icon { display: inline-grid; place-items: center; width: 54px; height: 54px; margin-bottom: 14px; }
.rf-lfeature__title { font-size: 18px; margin-bottom: 6px; }
.rf-lfeature__text { color: var(--rf-ink-2); font-size: 14.5px; }
.rf-lfeature__text p { margin: 0; }
.rf-lcta { text-align: center; margin: 2em 0; }

/* Landing related links */
.rf-related { margin-top: 2.4em; }
.rf-related__title { font-size: 22px; margin-bottom: 16px; }
.rf-related__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.rf-related__card { display: flex; flex-direction: column; align-items: flex-start; gap: 10px; padding: 18px; border: 1px solid var(--rf-line); border-radius: var(--rf-r); background: var(--rf-card); transition: transform var(--rf-t), box-shadow var(--rf-t); }
.rf-related__card:hover { transform: translateY(-3px); box-shadow: var(--rf-shadow); }
.rf-related__ico { display: inline-grid; place-items: center; width: 44px; height: 44px; }
.rf-related__name { font-family: var(--rf-display); font-weight: 700; font-size: 15px; color: var(--rf-ink); }
.rf-related__go { color: var(--rf-primary); }

/* ---------- FAQ (details/summary) ---------- */
.rf-faq { margin: 2em 0 1em; }
.rf-faq__title { font-size: clamp(24px, 3vw, 32px); margin-bottom: 18px; }
.rf-faq__list { display: grid; gap: 12px; }
.rf-faq__item { border: 1px solid var(--rf-line); border-radius: var(--rf-r); background: var(--rf-card); overflow: hidden; }
.rf-faq__q { display: flex; align-items: center; justify-content: space-between; gap: 14px; padding: 16px 18px; cursor: pointer; font-family: var(--rf-display); font-weight: 700; font-size: 16px; color: var(--rf-ink); list-style: none; }
.rf-faq__q::-webkit-details-marker { display: none; }
.rf-faq__chev { position: relative; width: 14px; height: 14px; flex: none; }
.rf-faq__chev::before, .rf-faq__chev::after { content: ""; position: absolute; top: 6px; width: 9px; height: 2px; background: var(--rf-primary); border-radius: 2px; transition: transform var(--rf-t); }
.rf-faq__chev::before { left: 0; transform: rotate(45deg); }
.rf-faq__chev::after { right: 0; transform: rotate(-45deg); }
.rf-faq__item[open] .rf-faq__chev::before { transform: rotate(-45deg); }
.rf-faq__item[open] .rf-faq__chev::after { transform: rotate(45deg); }
.rf-faq__a { padding: 0 18px 16px; color: var(--rf-ink-2); font-size: 15px; }
.rf-faq__a p { margin: 0; }

/* ---------- Mega-menu (add CSS class "rf-mega" to a top-level menu item) ---------- */
.rf-menu .rf-mega { position: static; }
.rf-menu .rf-mega > .sub-menu {
  left: 50%; transform: translateX(-50%) translateY(6px);
  width: min(760px, 92vw); max-width: 92vw;
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 4px 18px; padding: 18px;
}
.rf-menu .rf-mega:hover > .sub-menu, .rf-menu .rf-mega:focus-within > .sub-menu { transform: translateX(-50%) translateY(0); }
.rf-menu .rf-mega > .sub-menu > li > a { font-family: var(--rf-display); font-weight: 700; color: var(--rf-ink); }

/* ---------- Legal layout ---------- */
.rf-legal__layout { display: grid; grid-template-columns: 240px 1fr; gap: clamp(28px, 4vw, 56px); align-items: start; }
.rf-legal__toc { position: sticky; top: 100px; border: 1px solid var(--rf-line); border-radius: var(--rf-r); padding: 18px; background: var(--rf-card); }
.rf-legal__toc-title { display: block; font-family: var(--rf-display); font-weight: 700; font-size: 13px; text-transform: uppercase; letter-spacing: .06em; color: var(--rf-ink-3); margin-bottom: 10px; }
.rf-legal__toc ul { display: grid; gap: 4px; }
.rf-legal__toc a { display: block; padding: 6px 10px; border-radius: var(--rf-r-sm); font-size: 13.5px; color: var(--rf-ink-2); }
.rf-legal__toc a:hover { background: var(--rf-primary-50); color: var(--rf-primary); }
.rf-legal { max-width: none; margin: 0; }
.rf-legal h2 { scroll-margin-top: 100px; }
.rf-legal__updated { display: inline-block; font-size: 13px; font-weight: 600; color: var(--rf-primary-700); background: var(--rf-primary-50); padding: 6px 12px; border-radius: var(--rf-r-pill); margin-bottom: 8px; }

/* ---------- WooCommerce account (on-brand) ---------- */
.rf-account .woocommerce-MyAccount-navigation ul { display: grid; gap: 4px; }
.rf-account .woocommerce-MyAccount-navigation a { display: block; padding: 10px 14px; border-radius: var(--rf-r-sm); font-weight: 600; color: var(--rf-ink-2); }
.rf-account .woocommerce-MyAccount-navigation .is-active a, .rf-account .woocommerce-MyAccount-navigation a:hover { background: var(--rf-primary-50); color: var(--rf-primary); }

/* ---------- Micro-interactions ---------- */
.rf-btn { position: relative; overflow: hidden; }
.rf-btn::after { content: ""; position: absolute; top: 0; left: -120%; width: 60%; height: 100%; background: linear-gradient(120deg, transparent, rgba(255,255,255,.35), transparent); transform: skewX(-18deg); transition: left .6s ease; }
.rf-btn:hover::after { left: 130%; }
@media (prefers-reduced-motion: reduce) { .rf-btn::after { display: none; } }
@keyframes rf-float { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-10px); } }
.rf-hero__art .rf-iso, .rf-explore__media .rf-iso { animation: rf-float 7s ease-in-out infinite; }
@media (prefers-reduced-motion: reduce) { .rf-hero__art .rf-iso, .rf-explore__media .rf-iso { animation: none; } }

/* ---------- Responsive (v1.10 components) ---------- */
@media (max-width: 1024px) {
  .rf-related__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 880px) {
  .rf-explore__inner, .rf-lhero__inner { grid-template-columns: 1fr; }
  .rf-lhero__media, .rf-explore__media { order: -1; }
  .rf-legal__layout { grid-template-columns: 1fr; }
  .rf-legal__toc { position: static; }
  .rf-hero__art { display: none; }
}
@media (max-width: 560px) {
  .rf-explore__grid, .rf-lfeatures { grid-template-columns: 1fr; }
  .rf-related__grid { grid-template-columns: 1fr 1fr; }
  .rf-trustbar__inner { flex-direction: column; align-items: flex-start; }
  .rf-lhero__cta .rf-btn { flex: 1 1 100%; justify-content: center; }
}

/* ---------- v1.14.1 — Mega-menu: 3-level Explore (root → groups → pages) ---------- */
.rf-menu .rf-mega > .sub-menu {
  width: min(960px, 94vw);
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 14px 22px; padding: 20px 22px;
  align-items: start;
}
.rf-menu .rf-mega > .sub-menu > li { min-width: 0; }
.rf-menu .rf-mega > .sub-menu > li > a {
  font-family: var(--rf-display); font-weight: 700; font-size: 12px;
  text-transform: uppercase; letter-spacing: .06em; color: var(--rf-muted);
  padding: 4px 10px 6px; cursor: default;
}
.rf-menu .rf-mega > .sub-menu > li > a:hover { background: transparent; color: var(--rf-muted); }
/* The nested lists live INSIDE the panel: neutralise the dropdown behaviour. */
.rf-menu .rf-mega > .sub-menu > li > .sub-menu {
  position: static; opacity: 1; visibility: inherit; transform: none;
  min-width: 0; background: transparent; border: 0; box-shadow: none;
  padding: 0; display: block; transition: none;
}
.rf-menu .rf-mega > .sub-menu > li > .sub-menu a {
  padding: 7px 10px; font-size: 13.5px; font-weight: 500; color: var(--rf-ink-2);
  border-radius: var(--rf-r-sm); display: block;
}
.rf-menu .rf-mega > .sub-menu > li > .sub-menu a:hover { background: var(--rf-primary-50); color: var(--rf-primary); }

/* ---------- v1.15 — Landing hero: featured-image override ---------- */
.rf-lhero__slot--photo { width: 100%; height: auto; border-radius: var(--rf-r-lg); box-shadow: var(--rf-shadow-lg); object-fit: cover; display: block; }

/* ---------- v1.16 — Long-form landing body ---------- */
.rf-longform h2 { margin: 34px 0 12px; font-size: clamp(20px, 2.4vw, 26px); }
.rf-longform p { margin: 0 0 16px; line-height: 1.85; color: var(--rf-ink-2); }

/* ---------- v1.16 — Mega-menu opens on click only ---------- */
.rf-menu .rf-mega:hover > .sub-menu,
.rf-menu .rf-mega:focus-within > .sub-menu {
  opacity: 0; visibility: hidden; transform: translateX(-50%) translateY(6px);
}
.rf-menu .rf-mega.is-open > .sub-menu,
.rf-menu .rf-mega.is-open:hover > .sub-menu {
  opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0);
}
.rf-menu .rf-mega > a::after { content: '▾'; font-size: 10px; margin-inline-start: 6px; opacity: .65; transition: transform var(--rf-t); display: inline-block; }
.rf-menu .rf-mega.is-open > a::after { transform: rotate(180deg); }

/* ---------- v1.16.1 — WooCommerce full compatibility skin ---------- */
.rf-woo-wrap { padding: 34px 0 80px; }
.rf-woo { --wc-gap: 26px; }

/* Notices */
.rf-woo .woocommerce-message, .rf-woo .woocommerce-info, .rf-woo .woocommerce-error {
  border: 1px solid var(--rf-line); border-inline-start: 4px solid var(--rf-primary);
  background: var(--rf-card); border-radius: var(--rf-r); padding: 14px 18px; margin: 0 0 22px;
  list-style: none; color: var(--rf-ink);
}
.rf-woo .woocommerce-error { border-inline-start-color: #D64545; }
.rf-woo .woocommerce-message a.button, .rf-woo .woocommerce-info a.button { float: inline-end; }

/* Product grid */
.rf-woo ul.products { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--wc-gap); list-style: none; margin: 0; padding: 0; }
.rf-woo ul.products li.product {
  background: var(--rf-card); border: 1px solid var(--rf-line); border-radius: var(--rf-r-lg);
  padding: 16px; margin: 0; width: auto; float: none; transition: transform var(--rf-t), box-shadow var(--rf-t);
}
.rf-woo ul.products li.product:hover { transform: translateY(-4px); box-shadow: var(--rf-shadow-lg); }
.rf-woo ul.products li.product img { width: 100%; height: auto; border-radius: var(--rf-r); margin-bottom: 12px; }
.rf-woo ul.products li.product .woocommerce-loop-product__title { font-family: var(--rf-display); font-size: 17px; font-weight: 700; color: var(--rf-ink); }
.rf-woo .price { color: var(--rf-primary); font-weight: 800; }
.rf-woo .price del { color: var(--rf-muted); font-weight: 500; }
.rf-woo .onsale {
  position: absolute; inset-block-start: 12px; inset-inline-start: 12px; z-index: 2;
  background: var(--rf-primary); color: var(--rf-primary-ink, #14181F); border-radius: 999px;
  padding: 5px 12px; font-size: 12px; font-weight: 800; line-height: 1; min-height: 0; min-width: 0;
}
.rf-woo ul.products li.product { position: relative; }
.rf-woo .star-rating span::before, .rf-woo .star-rating::before { color: var(--rf-primary); }

/* Buttons */
.rf-woo .button, .rf-woo button.button, .rf-woo a.button,
.rf-woo button[type='submit'], .rf-woo .woocommerce-Button {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  background: var(--rf-primary); color: var(--rf-primary-ink, #14181F);
  border: 0; border-radius: 999px; padding: 12px 22px; font-weight: 700; font-size: 15px;
  cursor: pointer; transition: filter var(--rf-t), transform var(--rf-t); line-height: 1.2;
}
.rf-woo .button:hover, .rf-woo button[type='submit']:hover { filter: brightness(1.06); transform: translateY(-1px); color: var(--rf-primary-ink, #14181F); }
.rf-woo .button.alt, .rf-woo #place_order { background: var(--rf-ink); color: #fff; }
.rf-woo a.added_to_cart { margin-inline-start: 10px; font-weight: 600; }

/* Forms & quantity */
.rf-woo input.input-text, .rf-woo .quantity .qty, .rf-woo select, .rf-woo textarea,
.rf-woo .select2-container--default .select2-selection--single {
  border: 1px solid var(--rf-line); border-radius: var(--rf-r); padding: 11px 14px;
  background: var(--rf-card); color: var(--rf-ink); font: inherit; width: 100%;
}
.rf-woo .quantity .qty { width: 84px; text-align: center; }
.rf-woo input:focus, .rf-woo select:focus, .rf-woo textarea:focus { outline: 2px solid var(--rf-primary); outline-offset: 1px; }
.rf-woo form .form-row label { font-weight: 600; margin-bottom: 5px; display: inline-block; }

/* Tables (cart, totals, orders) */
.rf-woo table.shop_table {
  width: 100%; border-collapse: separate; border-spacing: 0;
  border: 1px solid var(--rf-line); border-radius: var(--rf-r-lg); overflow: hidden;
}
.rf-woo table.shop_table th, .rf-woo table.shop_table td { padding: 14px 16px; border-bottom: 1px solid var(--rf-line); text-align: start; }
.rf-woo table.shop_table thead th { background: var(--rf-bg-2, var(--rf-card)); font-weight: 700; }
.rf-woo table.shop_table tr:last-child td { border-bottom: 0; }
.rf-woo .cart_item img { width: 64px; border-radius: var(--rf-r); }

/* Single product */
.rf-woo div.product { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: 40px; align-items: start; }
.rf-woo div.product .woocommerce-product-gallery, .rf-woo div.product .summary { width: 100%; float: none; margin: 0; }
.rf-woo div.product .woocommerce-product-gallery img { border-radius: var(--rf-r-lg); }
.rf-woo div.product .product_title { font-family: var(--rf-display); font-size: clamp(26px, 3.4vw, 36px); margin: 0 0 10px; }
.rf-woo div.product .woocommerce-tabs, .rf-woo .related.products, .rf-woo .up-sells { grid-column: 1 / -1; }
.rf-woo .woocommerce-tabs ul.tabs { display: flex; gap: 8px; list-style: none; padding: 0; margin: 30px 0 16px; border-bottom: 1px solid var(--rf-line); }
.rf-woo .woocommerce-tabs ul.tabs li { padding: 0; margin: 0; background: none; border: 0; }
.rf-woo .woocommerce-tabs ul.tabs li a { display: inline-block; padding: 10px 16px; border-radius: var(--rf-r) var(--rf-r) 0 0; font-weight: 600; color: var(--rf-ink-2); }
.rf-woo .woocommerce-tabs ul.tabs li.active a { background: var(--rf-card); border: 1px solid var(--rf-line); border-bottom-color: var(--rf-card); color: var(--rf-ink); }

/* My Account */
.rf-woo .woocommerce-MyAccount-navigation { float: none; width: 100%; margin-bottom: 22px; }
.rf-woo .woocommerce-MyAccount-navigation ul { display: flex; flex-wrap: wrap; gap: 8px; list-style: none; margin: 0; padding: 0; }
.rf-woo .woocommerce-MyAccount-navigation li a {
  display: inline-block; padding: 9px 16px; border: 1px solid var(--rf-line);
  border-radius: 999px; font-weight: 600; color: var(--rf-ink-2); background: var(--rf-card);
}
.rf-woo .woocommerce-MyAccount-navigation li.is-active a { background: var(--rf-primary); border-color: var(--rf-primary); color: var(--rf-primary-ink, #14181F); }
.rf-woo .woocommerce-MyAccount-content { float: none; width: 100%; }

/* Checkout */
.rf-woo form.checkout { display: grid; grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr); gap: 40px; }
.rf-woo form.checkout #order_review_heading, .rf-woo form.checkout #order_review { grid-column: 2; }
.rf-woo form.checkout #customer_details { grid-column: 1; grid-row: 1 / span 2; }
.rf-woo #payment { background: var(--rf-card); border: 1px solid var(--rf-line); border-radius: var(--rf-r-lg); }
.rf-woo #payment .payment_methods { list-style: none; margin: 0; padding: 12px; }
.rf-woo #payment div.form-row.place-order { padding: 12px; }

/* Responsive */
@media (max-width: 980px) {
  .rf-woo ul.products { grid-template-columns: repeat(2, 1fr); }
  .rf-woo div.product, .rf-woo form.checkout { grid-template-columns: 1fr; }
  .rf-woo form.checkout #order_review_heading, .rf-woo form.checkout #order_review, .rf-woo form.checkout #customer_details { grid-column: 1; grid-row: auto; }
}
@media (max-width: 620px) {
  .rf-woo ul.products { grid-template-columns: 1fr; }
  .rf-woo table.shop_table_responsive tr { display: block; border-bottom: 1px solid var(--rf-line); }
  .rf-woo table.shop_table_responsive td { display: flex; justify-content: space-between; border: 0; }
}

/* ---------- v1.17 — Landing body image ---------- */
.rf-landing-figure { margin: 30px 0; }
.rf-landing-figure img { width: 100%; height: auto; border-radius: var(--rf-r-lg); box-shadow: var(--rf-shadow-lg); display: block; }

/* ---------- v1.18 — Mega-menu: closed panel is fully inert ---------- */
.rf-menu .rf-mega > .sub-menu { pointer-events: none; }
.rf-menu .rf-mega.is-open > .sub-menu { pointer-events: auto; }

/* ---------- v1.18 — Booking form alignment ---------- */
@media (min-width: 621px) {
  .rf-booking__route { align-items: start; }
}
.rf-place { position: relative; }
.rf-place__hint { position: absolute; top: 100%; left: 2px; margin-top: 4px; white-space: nowrap; }
.rf-booking__route .rf-field { min-width: 0; }
.rf-booking__grid .rf-field .rf-input,
.rf-booking__grid .rf-field input.rf-input { height: 52px; }

/* ---------- v1.18 — Local instant route suggestions (no API) ---------- */
.rf-place__menu {
  position: absolute; top: calc(100% + 6px); left: 0; right: 0; z-index: 60;
  background: var(--rf-card); border: 1px solid var(--rf-line); border-radius: var(--rf-r);
  box-shadow: var(--rf-shadow-lg); max-height: 260px; overflow: auto; padding: 6px;
  list-style: none; margin: 0;
}
.rf-place__menu li { padding: 10px 12px; border-radius: var(--rf-r-sm); cursor: pointer; display: flex; gap: 8px; align-items: center; }
.rf-place__menu li[aria-selected='true'], .rf-place__menu li:hover { background: var(--rf-primary-50, rgba(15,163,163,.12)); color: var(--rf-primary); }
.rf-place__menu li::before { content: ''; width: 8px; height: 8px; border-radius: 50%; background: var(--rf-primary); opacity: .7; flex: none; }

/* ---------- v1.18 — Futuristic mobile bottom-sheet pickers ---------- */
@media (max-width: 680px) {
  .rf-cal, .rf-times {
    position: fixed !important; left: 0 !important; right: 0 !important; bottom: 0 !important; top: auto !important;
    transform: none !important; width: auto !important; max-width: none !important;
    border-radius: 22px 22px 0 0; padding: 18px 18px calc(18px + env(safe-area-inset-bottom));
    border: 1px solid var(--rf-line); border-bottom: 0;
    background:
      radial-gradient(120% 90% at 50% 0%, rgba(15,163,163,.10), transparent 55%),
      var(--rf-card);
    box-shadow: 0 -18px 60px rgba(6, 14, 28, .35), 0 0 0 100vmax rgba(6, 14, 28, .45);
    animation: rfSheetUp .28s cubic-bezier(.22,.9,.28,1);
    z-index: 999;
  }
  .rf-cal::before, .rf-times::before {
    content: ''; display: block; width: 44px; height: 5px; border-radius: 999px;
    background: var(--rf-line); margin: 0 auto 14px;
  }
  .rf-cal__grid { gap: 6px; }
  .rf-cal__day { min-height: 44px; min-width: 44px; font-size: 16px; border-radius: 12px; }
  .rf-cal__day.is-selected, .rf-cal__day:active {
    background: var(--rf-primary); color: #fff;
    box-shadow: 0 0 0 3px rgba(15,163,163,.25), 0 6px 18px rgba(15,163,163,.35);
  }
  .rf-cal__nav { min-width: 42px; min-height: 42px; border-radius: 12px; }
  .rf-times .rf-time__list button, .rf-times button { min-height: 46px; font-size: 16px; border-radius: 12px; }
}
@keyframes rfSheetUp { from { translate: 0 24px; opacity: .4; } to { translate: 0 0; opacity: 1; } }

/* ---------- v1.19 — Futuristic WooCommerce cart & checkout ---------- */
.woocommerce-cart .rf-woo table.shop_table,
.woocommerce-checkout .rf-woo #order_review {
  background:
    radial-gradient(140% 100% at 100% 0%, rgba(15,163,163,.08), transparent 55%),
    var(--rf-card);
  border: 1px solid rgba(15,163,163,.25);
  box-shadow: 0 24px 60px rgba(6,14,28,.10), inset 0 1px 0 rgba(255,255,255,.6);
  backdrop-filter: blur(6px);
}
.rf-woo .cart_totals { position: sticky; top: 96px; }
.rf-woo .cart_totals h2 { font-family: var(--rf-display); font-size: 20px; }
.rf-woo .cart_totals .order-total .woocommerce-Price-amount {
  font-size: 26px; font-weight: 800; color: var(--rf-primary);
  text-shadow: 0 0 22px rgba(15,163,163,.35);
}
.rf-woo .wc-proceed-to-checkout .checkout-button {
  width: 100%; background: linear-gradient(135deg, var(--rf-primary), #0C8B8B);
  color: #fff; box-shadow: 0 10px 28px rgba(15,163,163,.4);
}
.rf-woo .wc-proceed-to-checkout .checkout-button:hover { filter: brightness(1.08); transform: translateY(-2px); }
.rf-woo dl.variation, .rf-woo .wc-item-meta { font-size: 13.5px; color: var(--rf-ink-2); }
.rf-woo dl.variation dt, .rf-woo .wc-item-meta dt { font-weight: 700; color: var(--rf-ink); }
.woocommerce-cart .rf-woo .product-quantity { display: none; } /* single ride */
.woocommerce-cart .rf-woo td.product-name { font-weight: 700; }
.rf-woo .woocommerce-cart-form .product-remove a {
  width: 34px; height: 34px; display: inline-flex; align-items: center; justify-content: center;
  border-radius: 50%; border: 1px solid var(--rf-line); color: #D64545; background: var(--rf-card);
}

/* ---------- v1.19 — Round-trip discount badge ---------- */
.rf-rt-badge {
  display: inline-flex; align-items: center; margin-inline-start: 8px; padding: 2px 9px;
  border-radius: 999px; background: var(--rf-primary); color: #fff;
  font-size: 11.5px; font-weight: 800; letter-spacing: .02em;
  box-shadow: 0 0 14px rgba(15,163,163,.45);
}
.rf-rt-note { margin: 10px 0 0; font-size: 13.5px; color: var(--rf-primary); font-weight: 600; display: flex; align-items: center; gap: 7px; }
.rf-rt-note::before { content: '%'; display: inline-flex; align-items: center; justify-content: center; width: 20px; height: 20px; border-radius: 50%; background: var(--rf-primary); color: #fff; font-size: 11px; font-weight: 800; }

/* ---------- v1.19.1 — Booking alert visibility + WA button spacing ---------- */
.rf-booking .rf-alert--error:not(:empty) { display: block; }
.rf-booking__wa { margin-top: 10px; }
