/* villa-pricing.css - styles for booking form & pricing components */

.villa-booking-form input[type=text],
.villa-booking-form input[type=email],
.villa-booking-form select,
.villa-booking-form textarea {
  width: 100%;
  padding: 8px;
  border: 1px solid #ededed;
  border-radius: 5px;
  margin-bottom: 5px;
  box-sizing: border-box;
  font-size: 14px;
  line-height: 14px;
  color: #333;
}

.villa-booking-form .form-group { margin-bottom: 10px; }

/* Buttons */
.btn-book {
  background: #ff5722!important;
  color: #fff;
  border: none;
  padding: 12px 24px;
  border-radius: 4px;
  cursor: pointer;
  font-weight: 700;
  margin-top: 12px;
}
.btn-book:hover{
	background: #dd3500;
	color: #fff
}
.btn-book:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  background: #ff5722!important;
}

#price-result{
    font-size: 14px;
}
/* Payable summary */
.payable-summary {
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
  margin-top: 10px;
}
.payable-summary a {
  font-weight: normal;
  text-decoration: none;
  color: #ff5722!important;
  padding-left: 5px;
  padding-right: 5px;
  font-size: 0.9em;
}

/* price details layout */
.price-detail {
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
  border-bottom: 1px solid #ddd;
  padding: 10px 0;
  line-height: 1.5em;
}
.price-detail.no-line { border-bottom: none; }
#tax-line{font-size: 0.8em;}

/* tax badge */
.badge {
  display: inline-block;
  padding: 2px 6px;
  font-size: 12px;
  font-weight: 600;
  color: #fff;
  background-color: #007bff;
  border-radius: 10px;
  vertical-align: middle;
}
.badge-percent { background-color: #6c757d; }

/* Flatpickr */
.flatpickr-calendar.multiMonth .flatpickr-days .dayContainer:nth-child(n+2) .flatpickr-day.inRange:nth-child(7n+1) {
    box-shadow: none;
}
.flatpickr-day.inRange {
    border-radius: 0;
    box-shadow: -5px 0 0 #ffcdb0, 5px 0 0 #ffcdb0!important;
    background: #ffcdb0!important;
    border-color: #ffcdb0!important;
}
.flatpickr-day.endRange.startRange:before,
.flatpickr-day.selected.startRange:before,
.flatpickr-day.startRange.startRange:before {
    background-color: #ffcdb0!important;
    content: "";
    height: inherit;
    left: 52%;
    position: absolute;
    top: -1px;
    width: 65%;
    z-index: -1;
}
.flatpickr-day.endRange.endRange:before, .flatpickr-day.selected.startRange~.flatpickr-day.selected.endRange.endRange:before {
    background-color: #ffcdb0!important;
    content: "";
    height: inherit;
    left: -6px;
    position: absolute;
    top: -1px;
    width: 65%;
    z-index: -1;
}
.flatpickr-day.selected, .flatpickr-day.startRange, .flatpickr-day.endRange, .flatpickr-day.selected.inRange, .flatpickr-day.startRange.inRange, .flatpickr-day.endRange.inRange, .flatpickr-day.selected:focus, .flatpickr-day.startRange:focus, .flatpickr-day.endRange:focus, .flatpickr-day.selected:hover, .flatpickr-day.startRange:hover, .flatpickr-day.endRange:hover, .flatpickr-day.selected.prevMonthDay, .flatpickr-day.startRange.prevMonthDay, .flatpickr-day.endRange.prevMonthDay, .flatpickr-day.selected.nextMonthDay, .flatpickr-day.startRange.nextMonthDay, .flatpickr-day.endRange.nextMonthDay{
    background: #ff5722!important;
    border-color: #ff5722!important;
}
.flatpickr-day.selected.startRange, .flatpickr-day.startRange.startRange, .flatpickr-day.endRange.startRange,
.flatpickr-day.selected.endRange, .flatpickr-day.startRange.endRange, .flatpickr-day.endRange.endRange{
    border-radius: 50px!important;
}

.flatpickr-day.selected.startRange + .endRange:not(:nth-child(7n+1)), .flatpickr-day.startRange.startRange + .endRange:not(:nth-child(7n+1)), .flatpickr-day.endRange.startRange + .endRange:not(:nth-child(7n+1)) {
    -webkit-box-shadow: -10px 0 0 #ff5722!important;
    box-shadow: none!important;
}

/* flatpickr clear button inside calendar */
.flatpickr-clear-btn {
  width: 100%;
  display: block;
  text-align: center;
  background: #f6f6f6;
  border: none;
  padding: 8px;
  font-size: 13px;
  cursor: pointer;
  border-top: 1px solid #ddd;
  transition: all .12s ease;
}
.flatpickr-clear-btn:hover { background: #e9e9e9; }

/* Flatpickr inline full width */
.bk-ical-single .flatpickr-calendar,
.bk-ical-single .flatpickr-rContainer,
.bk-ical-single .flatpickr-days{
	width:100%!important
}

.bk-ical-single .dayContainer{
	width: 50%;
	max-width: 50%;
}
.bk-ical-single .flatpickr-day{
	max-width: 13%!important;
	height: 43px!important;
}
@media(max-width:767px){
	.bk-ical-single .dayContainer {
        width: 100%;
        max-width: 100%;
	}
}
.bk-ical-single .flatpickr-weekdays{
	height:40px
}

/* price breakdown box */
#price-breakdown {
    margin-top: 12px;
    background: #fff;
    padding: 12px;
    padding-bottom: 0;
    border: 1px solid #efefef;
    font-size: 12px;
}
#price-breakdown h4{
    font-size: 15px;
    margin-bottom: 10px;
}
#price-breakdown ul li{
    border-bottom: 1px solid #eee;
    line-height: 2.5em;
}
#price-breakdown ul li:last-child{
    border-bottom: none;
}
/* small responsive tweaks */
@media (max-width: 768px) {
  .payable-summary { font-size: 14px; }
}

.seasonal-pricing-wrapper {
    margin: 30px 0;
}

.pricing-table-container {
    overflow-x: auto;
    font-size: 14px;
}

.seasonal-pricing-table {
    width: 100%;
    border-collapse: collapse;
    /* background: white; */
}

.seasonal-pricing-table thead {
    /* background: #000; */
    color: white;
}
.seasonal-pricing-table thead:after {
    content: "";
    display: block;
    margin-bottom: 1rem;
}
.seasonal-pricing-table th {
    padding: 15px;
    text-align: left;
    font-weight: 600;
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    white-space: nowrap;
    background: #ff5722;
}
/* .seasonal-pricing-table th:first-child{
    border-top-left-radius: 10px;
    border-bottom-left-radius: 10px;
}
.seasonal-pricing-table th:last-child{
    border-top-right-radius: 10px;
	border-bottom-right-radius: 10px;
} */

.seasonal-pricing-table td {
    padding: 15px;
    border-bottom: 1px solid #f9f9f9;
    vertical-align: middle;
    white-space: nowrap;
    background: #ffffff;
}

.seasonal-pricing-table tbody tr:hover {
    background-color: #f9fafb;
}

.base-price-row:hover {
    background-color: #e0f2fe !important;
}

.current-season {
    background-color: #fef3c7;
    border-left: 4px solid #f59e0b;
}

.current-season:hover {
    background-color: #fde68a !important;
}

.season-name {
    font-weight: 600;
    color: #1f2937;
    font-size: 15px;
}

.current-badge {
    display: inline-block;
    background: #f59e0b;
    color: white;
    padding: 2px 8px;
    border-radius: 12px;
    font-size: 11px;
    font-weight: 600;
    margin-left: 8px;
    text-transform: uppercase;
}

.period-cell {
    color: #6b7280;
}

.date-range {
    display: inline-block;
}

.separator {
    margin: 0 5px;
    color: #9ca3af;
}

.days-count {
    display: block;
    font-size: 12px;
    color: #9ca3af;
    margin-top: 4px;
}

.price-cell {
    text-align: left;
}

.price-amount {
    font-size: 18px;
    font-weight: 700;
    color: #ff5722!important;
    display: block;
}

.price-change {
    display: block;
    font-size: 12px;
    margin-top: 4px;
    font-weight: 500;
}

.price-change.increase {
    color: #dc2626;
}

.price-change.decrease {
    color: #ff5722!important;
}

.pricing-notes {
    margin-top: 20px;
    padding: 15px;
    background: #f9fafb;
    border-left: 4px solid #3b82f6;
    border-radius: 4px;
}

.note-item {
    margin: 5px 0;
    font-size: 13px;
    color: #6b7280;
}

/* Responsive */
@media (max-width: 768px) {
    .seasonal-pricing-table {
        font-size: 13px;
    }
    
    .seasonal-pricing-table th,
    .seasonal-pricing-table td {
        padding: 10px 8px;
    }
    
    .price-amount {
        font-size: 16px;
    }
    
    .days-count {
        display: none;
    }
}
/* Pricing discount */
.pricing-discounts-info{
    margin-top: 25px;
    padding: 15px;
    background: #ffffff;
    border-left: 4px solid #ff5722!important;
    border-radius: 4px;
    box-shadow: 2px 2px 10px #eeeeee;
}
.pricing-discounts-info h4{
    margin-top: 0;
    font-size: 1.1em;
    color: #333;
    margin-bottom: 15px;
}
.pricing-discounts-info ul{
    margin: 0;
    padding-left: 20px;
    color: #555;
    font-size: 15px;
}
.pricing-discounts-info ul li{
    margin-bottom: 5px;
}
/* Validasi */
#inquiry-error,
#price-error{
    display: none;
    margin-top: 20px;
    padding: 15px;
    background: #fee;
    border-left: 4px solid #c00;
    color: #c00;
}
#inquiry-error{
    font-style: italic;
}
#inquiry-thanks{
    display: none;
    margin-top: 12px;
    color: #2db742;
    font-weight: 700;
}