.df-hourly-hidden-select {
  position: absolute !important;
  opacity: 0 !important;
  pointer-events: none !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
}

.df-hourly-inline-controls {
  margin: 18px 0 10px;
  padding: 18px;
  border: 1px solid #e9eaf0;
  border-radius: 16px;
  background: #f7f8fd;
}

.df-hourly-inline-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.df-hourly-inline-field label,
.df-hourly-time-col label,
.df-hourly-duration-field label {
  display: block;
  font-weight: 600;
  margin-bottom: 6px;
}

.df-hourly-inline-select,
.df-hourly-duration-field select,
.df-hourly-timepicker select {
  width: 100%;
  min-height: 44px;
  border: 1px solid #d9dce8;
  background: #fff;
  padding: 10px 12px;
  border-radius: 10px;
  outline: none;
}

.df-hourly-endtime,
.df-hourly-time-preview {
  display: block;
  margin-top: 6px;
  color: #666;
}

.df-hourly-timepicker { margin-top: 0; }
.df-hourly-time-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
  gap: 10px;
  align-items: end;
}
.df-hourly-time-separator {
  align-self: center;
  font-size: 24px;
  font-weight: 700;
  color: #666;
  padding-bottom: 4px;
}
.df-hourly-line {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 600;
  flex-wrap: wrap;
}
.df-hourly-rate sub { font-size: 12px; }
.df-hourly-multiplier { opacity: .65; }
.travelers-field .title-area span { max-width: 320px; display: block; }

@media (max-width: 991px) {
  .df-hourly-inline-grid { grid-template-columns: 1fr; }
}

@media (max-width: 767px) {
  .df-hourly-time-grid { grid-template-columns: 1fr; }
  .df-hourly-time-separator { display: none; }
}

.df-hourly-inline-controls .df-hourly-custom-control { display:block; }
.booking-modal .df-hourly-hidden-select { display:none !important; }
.df-hourly-inline-controls .df-hourly-inline-field { min-width: 0; }

.df-hourly-source-block-hidden{display:none !important;}
.df-hourly-source-context-hidden .df-pack-msg{display:none !important;}

.df-hourly-inline-controls { display:block !important; }
.df-hourly-inline-controls select { appearance:auto; -webkit-appearance:auto; }


/* v1.6.5: keep native selectable controls, improve spacing, and move Start Time onto its own row */
.booking-modal .df-hourly-inline-controls {
  margin: 24px 0 14px;
  padding: 24px;
  border: 1px solid var(--borders-color, #e9eaf0);
  border-radius: 20px;
  background: #f7f8fd;
}

.booking-modal .df-hourly-inline-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 22px 24px;
  align-items: start;
}

.booking-modal .df-hourly-inline-harbour,
.booking-modal .df-hourly-inline-duration,
.booking-modal .df-hourly-inline-time,
.booking-modal .df-hourly-time-col {
  min-width: 0;
}

.booking-modal .df-hourly-inline-time {
  grid-column: 1 / -1;
}

.booking-modal .df-hourly-inline-field > label,
.booking-modal .df-hourly-time-col > label,
.booking-modal .df-hourly-duration-field > label {
  color: var(--title-color, #111827);
  font-family: var(--font-poppins, inherit);
  font-size: 16px;
  font-weight: 500;
  line-height: 1.35;
  margin-bottom: 10px;
}

.booking-modal .df-hourly-inline-time > label {
  margin-bottom: 14px;
}

.booking-modal .df-hourly-inline-controls .df-hourly-custom-control,
.booking-modal .df-hourly-inline-controls .df-hourly-inline-select,
.booking-modal .df-hourly-inline-controls .df-hourly-duration-field select,
.booking-modal .df-hourly-inline-controls .df-hourly-timepicker select {
  width: 100%;
  min-height: 52px;
  height: 52px;
  padding: 0 16px;
  border: 1px solid var(--borders-color, #d9dce8);
  border-radius: 10px;
  background-color: var(--white-color, #fff);
  color: var(--title-color, #111827);
  font-family: var(--font-poppins, inherit);
  font-size: 15px;
  font-weight: 500;
  line-height: 50px;
  box-shadow: none;
  outline: none;
}

.booking-modal .df-hourly-inline-controls .df-hourly-custom-control:focus,
.booking-modal .df-hourly-inline-controls .df-hourly-inline-select:focus,
.booking-modal .df-hourly-inline-controls .df-hourly-duration-field select:focus,
.booking-modal .df-hourly-inline-controls .df-hourly-timepicker select:focus {
  border-color: var(--primary-color1, #2f80ed);
}

.booking-modal .df-hourly-time-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px 20px;
  align-items: start;
}

.booking-modal .df-hourly-time-separator {
  display: none;
}

.booking-modal .df-hourly-endtime,
.booking-modal .df-hourly-time-preview {
  display: block;
  min-height: 20px;
  margin-top: 10px;
  color: var(--text-color, #666666);
  font-family: var(--font-roboto, inherit);
  font-size: 14px;
  line-height: 1.45;
}

.booking-modal .df-hourly-time-preview {
  margin-top: 12px;
}

@media (max-width: 991px) {
  .booking-modal .df-hourly-inline-controls {
    padding: 20px;
  }

  .booking-modal .df-hourly-inline-grid {
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .booking-modal .df-hourly-inline-time {
    grid-column: auto;
  }
}

@media (max-width: 767px) {
  .booking-modal .df-hourly-inline-controls {
    padding: 18px;
    border-radius: 16px;
  }

  .booking-modal .df-hourly-time-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }
}
