@import url('https://fonts.googleapis.com/css2?family=Figtree:wght@300;400;500;600;700&display=swap');
@import url(https://www.planyo.com/libs/apis-fonts/open-sans.css);

/* ─── Global reset ───────────────────────────────────── */
* { margin: 0; padding: 0; }
.planyo .table td { box-sizing: border-box; }
#resdetailsblock { display: none; }

/* ─── Base ───────────────────────────────────────────── */
html .planyo {
  font-family: 'Figtree', sans-serif;
  font-size: 14px;
  font-weight: 400;
  font-style: normal;
  color: #1A1A1A;
  background-color: #F5F3EE;
  line-height: 1.25rem;
  clear: both;
  -webkit-font-smoothing: antialiased;
  box-sizing: initial;
  -webkit-box-sizing: initial;
  overflow-x: hidden;
  padding: 0;
  margin: 0;
}

html .planyo a {
  box-shadow: none;
  -webkit-box-shadow: none;
  color: #1A1A1A;
  text-decoration: underline;
  text-decoration-color: #DDD9D0;
  transition: opacity 0.15s ease;
}
html .planyo a:hover {
  color: #1A1A1A;
  opacity: 0.65;
  text-decoration: none;
  -webkit-box-shadow: none;
}

html .planyo ol, html .planyo ul, html .planyo ul li {
  list-style: none;
  list-style-type: none;
}

html .planyo img {
  margin: 0;
  -webkit-transform: initial !important;
  transform: initial !important;
  transition: initial !important;
}

html .planyo .img-thumbnail { transform: initial !important; }
html .planyo .lead { font-size: 14px; color: #1A1A1A; }

/* ─── Layout ─────────────────────────────────────────── */
html .planyo .container-fluid {
  padding-left: 0;
  padding-right: 0;
  border-top: none;
  max-width: none;
}
html .container.planyo { margin: 0; }

/* 2-col checkout */
.crr-checkout {
  display: flex;
  align-items: flex-start;
  gap: 2.5rem;
  max-width: 960px;
  margin: 0 auto;
  padding: 2rem;
}
.crr-checkout__main { flex: 1 1 0%; min-width: 0; }
.crr-checkout__aside { flex: 0 0 300px; width: 300px; position: sticky; top: 1.5rem; }

/* single-column pages */
.crr-page { max-width: 640px; margin: 0 auto; padding: 2rem 1.5rem; }

/* ─── Containers ─────────────────────────────────────── */
#reserve_form, .completed-code { max-width: 100%; padding: 4rem; }
.planyo .col-md-4 { align-items: center; }
#res_form_buttons { background-color: white; padding-bottom: 4rem; border-radius: 5px; }

/* ─── Ratebox containers ─────────────────────────────── */
.ratebox-container {
  display: flex;
  flex-direction: column;
  background-color: #EDE9E1;
  width: 100%;
  padding: 3rem;
  box-sizing: border-box;
}
.ratebox-row, .ratebox-row-2 {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  max-width: 300px;
}
.ratebox-col-full { flex: 1; align-items: center; text-align: center; display: flex; justify-content: space-between; }
.ratebox-col-left  { flex: 1; text-align: left; }
.ratebox-col-right { flex: 1; text-align: right; font-weight: 400; }

/* ─── Step indicator ─────────────────────────────────── */
.custom_reserve_steps_div {
  font-size: 10px;
  display: flex;
  justify-content: center;
  width: 100%;
  text-align: center;
  line-height: 12px;
  padding: 5px 0;
  margin-top: 1rem;
  border-radius: 30px;
  background-color: #EDE9E1;
  gap: 1.25rem;
}
.custom_reserve { padding-left: 2rem; flex: 1; margin: 0; }

/* ─── Ratebox text elements ──────────────────────────── */
.custom_ratebox_title_left, .custom_ratebox_title_right, .custom_ratebox_price { text-transform: uppercase; }
.custom_ratebox_title_left, .custom_ratebox_title_right { padding-bottom: 0.1rem; font-size: 18px; }
.custom_ratebox_title_left  { text-align: left; }
.custom_ratebox_title_right { text-align: right; }
.custom_ratebox_price {
  padding: 5px 10px;
  border-radius: 50px;
  background-color: #D1D1A5;
  color: black;
  text-align: right;
}

/* ─── Additional products ────────────────────────────── */
.additional-products-form { display: flex; flex-direction: column; align-items: stretch; }
.planyo .col-6 { padding: 0; }

.html .planyo .planyo-form-row-wrapper { display: flex; flex-wrap: wrap; }
html .planyo .planyo-form-item-group { flex: 1; min-width: 100%; box-sizing: border-box; padding: 0 15px; }

#reservation-code .row, #products-code .row {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  margin: 0 !important;
}

.row.product-desc { font-size: 15px; padding: 0.5rem 0; font-weight: lighter; display: flex; flex-wrap: wrap; max-width: 40%; padding-left: 115px; }

#reservation-code .additional-products-form,
#reservation-code .pricebox,
#products-code .pricebox {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  border: 0;
  background-color: white;
  flex: 1;
}

.additional-products-container { display: flex; flex-direction: column; width: 100%; padding: 0; }
.additional-product { width: 100%; margin: 1rem 0; border: 0; border-radius: 8px; padding: 1rem; box-shadow: 0 2px 4px rgba(0,0,0,.1); }

.planyo .list-group-item { border: 0; }
.planyo .col-md-6 { height: 100%; }

.list-group-item .row { display: flex; flex-direction: row; align-items: center; justify-content: flex-start; gap: 10px; }
.list-group-item .col-extra { order: -1; flex: 0 0 auto; margin-right: 10px; display: flex; align-items: center; max-width: 80px; }
.list-group-item .col-prodname { display: flex; flex-direction: column; align-items: flex-start; }
.product-name { margin: 0; display: flex; align-items: center; }
.product-desc { margin-top: 5px; margin-left: 0; font-size: 0.95em; color: #6A6A6A; line-height: 1.4; }

.btn.btn-primary { font-size: 14px; padding: 5px 10px; border-radius: 20px; background-color: #333; color: #fff; }

.prodheader, .col-subtotal, #oneprodtot_, #recprodtot_ { display: none !important; }

.planyo .input-group > .form-control { flex-basis: 0; }

#selplusbtn_27240, #selminusbtn_27240 { border-radius: 50px; }

.custom_ratebox_vanity {
  display: flex;
  flex-wrap: wrap;
  padding-top: 2rem;
  justify-content: space-between;
  padding-left: 0;
  padding-right: 0;
}
.reserve-buttons { display: flex; justify-content: center; margin-top: 2rem; }
.custom_rb_description { flex: 1; text-align: left; }
.custom_rb_price       { flex: 1; text-align: right; }

.custombreakdown, .custombreakdown-2 { line-height: 1.5rem; }
.custombreakdown-2 { font-weight: 500; }

/* BUG FIX: was font-size: 15em — caused giant overlapping text */
.custombreakdown-total { font-size: 1em; font-weight: 500; line-height: 1.5; }

.custombreakdown-p { font-weight: 400; text-align: left; padding-bottom: 1.5rem; }

.payment-deposit {
  text-align: center;
  background-color: #E4EFFF;
  padding: 5px;
  border-radius: 50px;
  margin: 20px 0 1rem;
  display: block;
  width: 100%;
  box-sizing: border-box;
  font-weight: bold;
}

/* ─── Stripe button ──────────────────────────────────── */
#stripe_checkout_logo {
  background-image: url('https://uploads-ssl.webflow.com/6546634a5fd8fa6155a73ecf/66a0f219bc57dc41e56fd24b_withstripe.jpg') !important;
  background-size: contain !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
}

.planyo #stripe_checkout_button.btn-primary,
#stripe_checkout_submit.btn-primary {
  border-color: transparent !important;
  display: inline-block !important;
  font-family: 'Figtree', sans-serif !important;
  font-weight: 600 !important;
  font-size: 16px !important;
  margin: 0 !important;
  padding: 12px 28px !important;
  text-align: center !important;
  white-space: nowrap !important;
  vertical-align: middle !important;
  color: #fff !important;
  background-color: #1A1A1A !important;
  border-radius: 6px !important;
  background-image: none !important;
  line-height: 1.45em !important;
  border-width: 0 !important;
}

#stripe_checkout_submit.btn-primary:hover {
  background-color: #383838 !important;
  color: #fff !important;
}

/* ─── Completion page ────────────────────────────────── */
#reservation-details { padding-top: 0; margin-top: 0; }

#completion-code .container-fluid { display: flex; flex-wrap: wrap; margin-top: 0; border: none; }
#completion-code .row { width: 100%; margin-top: 0 !important; }
#completion-code .left-content,
#completion-code .right-content { flex: 1; min-width: 300px; box-sizing: border-box; }
#completion-code .left-content  { background-color: white; }
#completion-code .right-content { background-color: #EDE9E1; }
#completion-code .completed-code { padding: 0 4rem; }
#completion-code .completion-content { padding: 4rem 0; }
#completion-code .ratebox-container {
  background-color: #EDE9E1;
  padding: 30px;
  display: flex;
  flex-direction: column;
  align-content: space-between;
  justify-content: space-around;
  align-items: center;
}
#confirmation-notification { margin-top: 0; }

/* ─── Tables ─────────────────────────────────────────── */
.planyo .table td, .planyo .table th {
  padding: 0.25rem;
  vertical-align: top;
  border-bottom: 0;
  border-top: 0;
}

/* ─── Buttons ────────────────────────────────────────── */
html .planyo a.btn.btn-primary,
html .planyo a.btn.btn-primary.btn-lg,
html .planyo a.btn.btn-info.btn-lg,
html .planyo .btn-primary.btn-lg,
html .planyo .btn-primary,
html .planyo input[type="button"],
html .planyo .btn-group .btn-primary,
input.cart_popup_button,
input#add_cart_button {
  border-color: #D1D1A5;
  display: inline-block;
  font-family: 'Figtree', sans-serif;
  font-size: 15px;
  margin: 0;
  padding: 6px 12px;
  text-align: center;
  white-space: nowrap;
  vertical-align: middle;
  color: #FFF;
  background-color: #1A1A1A;
  border-radius: 30px;
  background-image: none;
  line-height: 1.45em;
  border-width: 0;
}

html .planyo a.btn.btn-primary:hover,
html .planyo .btn-primary.btn-lg:hover,
html .planyo .btn-primary:hover,
html .planyo input[type="button"]:hover,
html .planyo .btn-group .btn-primary:hover,
input.cart_popup_button:hover,
input#add_cart_button:hover {
  border-color: #357ebd;
  background-color: #383838;
  color: #FFF;
  cursor: pointer;
}

/* hide extra back button */
#price_info_area { display: none; }

/* ─── Resource list ──────────────────────────────────── */
#resources .resource-info, #searchview-code .resource-info { margin-bottom: 70px; zoom: 1; }
#resources .resource-image, #searchview-code .resource-image { padding: 0; max-height: 270px; overflow: hidden; }
.planyo .img-responsive { width: 100%; }
#resources .resource-info:first-child, #searchview-code .resource-info:first-child { margin-top: 0; }
#resources .resource-description, #searchview-code .resource-description { text-align: justify; margin-bottom: 10px; }
#resources .resource-contents h2, #searchview-code .resource-contents h2 { margin-top: 0; }
#resources .resource-props, #searchview-code .resource-props { text-align: right; }
#resources .action-buttons, #searchview-code .action-buttons { float: right; text-align: right; position: relative; bottom: 0; right: 0; padding: 0; }
#resources .resource-name, #search-results .resource-name { font-size: 30px; }
#resources .resource-description, #search-results .resource-description { font-size: 14px; color: #333; }

.col-sm-12.resource-contents { padding: 0; margin: 0; }
.col-xs-12.custom_properties { text-align: right; margin-bottom: 5px; padding: 0; }

#resources .custom_property, #searchview-code .custom_property {
  text-align: center;
  margin: 5px 2px;
  padding: 3px 5px;
  border-radius: 4px;
  display: inline-block;
  font-weight: 400;
  color: #428bca;
  font-size: 12px;
  border: 1px solid #428bca;
}

/* ─── Reservation form ───────────────────────────────── */
html .planyo textarea,
html .planyo input[type="text"],
html .planyo input[type="password"],
html .planyo input[type="date"],
html .planyo input[type="email"],
html .planyo input[type="tel"],
html .planyo input[type="number"] {
  background: #FFFFFF;
  color: #1A1A1A;
  border: 1px solid #DDD9D0;
  border-radius: 4px;
  -webkit-box-shadow: none;
  box-shadow: none;
  transition: border-color 0.15s ease;
  box-sizing: inherit;
  line-height: initial !important;
}

html .planyo input[type="text"],
html .planyo input[type="password"],
html .planyo input[type="date"],
html .planyo input[type="email"],
html .planyo input[type="tel"],
html .planyo input[type="number"] { height: 40px !important; padding: 9px 12px; }

html .planyo textarea { min-height: 96px; resize: vertical; padding: 9px 12px; }
html .planyo textarea#user_notes { min-height: 128px; }

html .planyo input[type="text"]:focus,
html .planyo input[type="email"]:focus,
html .planyo input[type="tel"]:focus,
html .planyo input[type="number"]:focus,
html .planyo textarea:focus {
  border-color: #1A1A1A !important;
  box-shadow: none !important;
  outline: none;
}

.checkout-details-form #reserve_form { margin-top: 0; }

html .planyo .form-control, #planyolang {
  border-radius: 4px;
  box-shadow: none;
  -webkit-box-shadow: none;
  padding: 6px 12px;
  display: block;
  height: 40px;
  font-size: 14px;
  color: #1A1A1A;
  background-color: #FFFFFF;
  border: 1px solid #DDD9D0;
}

.planyo .form-control-static { min-height: 0; }

#reserve_form label {
  display: block;
  float: none;
  width: 100%;
  color: #1A1A1A;
  font-size: 14px;
}
#reserve_form .help-block { color: #9E9E9E; }

#reserve_form.title_left label.col-sm-1 { width: 12%; float: left; }
#reserve_form.title_left label.col-sm-3 { float: left; width: 25%; }
#reserve_form.title_left { margin-left: 15px; }

#planyolang {
  display: block;
  width: 100%;
  height: 34px;
  font-size: 14px;
  color: #555;
  background-color: #fff;
  border: 0;
}

.planyo .datefld .input-group-addon:hover { cursor: pointer; }
.number-parent .input-group-addon .input-group-text { line-height: 16px; }
#search_form.form-inline .poweredby { display: none; }
#search_form.form-inline .number-parent input.form-control { max-width: 80px; }
#reserve_form #row_resource_name { display: none; }
.planyo .language { float: right; padding-left: 0; }

#reservation-code #resource_name { display: none; }
#reservation-code .col-xs-6.prefix { padding-right: 0; }
#reservation-code .col-xs-6.p_number { padding-left: 0; }
#reservation-code select#mobile_country_param,
#reservation-code select#phone_country_param { border-bottom-right-radius: 0; border-top-right-radius: 0; border-right: 0; }
#reservation-code input#mobile_number_param,
#reservation-code input#phone { border-bottom-left-radius: 0; border-top-left-radius: 0; border-left: 0; }
#reservation-code #from_calendar { padding: 0 0 0 15px; }
#reservation-code .date-part-day select, #reservation-code .date-part-year select { padding: 6px 0 6px 10px; }
#reservation-code .date-part-day   { width: 22%; padding-right: 0; float: left; }
#reservation-code .date-part-month { width: 48%; padding-right: 0; float: left; }
#reservation-code .date-part-year  { width: 26%; float: left; }

#reservation-code h3 {
  font-size: 11px;
  font-family: 'Figtree', sans-serif;
  font-weight: 600;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: #9E9E9E;
  padding: 1.75rem 0 0.5rem;
}

html .planyo .form-control-static { padding: 0; }

/* ─── Price info box ─────────────────────────────────── */
#price_info { color: #1A1A1A; padding: 0; }
#reservation_form_info { display: flex; }
#price_info dl { margin-bottom: 5px; }

#price_info_div_floating, .nonfloating_text {
  margin: 0;
  border-radius: 6px;
  background-color: #EDE9E1;
  color: #1A1A1A;
  display: inline-block;
  box-shadow: none;
  border: 1px solid #DDD9D0;
  padding: 1.5rem;
  width: 100%;
  box-sizing: border-box;
}

.planyo .pricebox { padding-right: 0; margin-bottom: 20px; }

/* Hide "Your rate" / "Price estimate" title */
html .price_info_div .title { display: none !important; }

.rate_recurring_totals, .rate_recurring_totals_custom { font-size: medium; font-weight: bold; }
.planyo #price_info .rate_extra { font-size: 13px; }
.planyo #price_info .rate_extra .par_err { clear: both; }
html .price_info_div .lead { margin: 0; }
#price_info_div_floating .rate_extra, #price_info_div_floating .extra_price_info { font-size: small; color: #6A6A6A; }
.price_info_div .price_info { color: #1A1A1A; }
.price_info_div #price_info_coupon { clear: both; font-size: 13px; margin: 15px 0; display: block; color: #6A6A6A; font-weight: 500; }

#planyo_price_preview_parent {
    background-color: #f6f6f3;
    padding: 3rem;
    border-radius: 8px;
    /* Voeg hier de rest van je Claude ratebox styling toe */
}

.price_info_div .rate_err,
.planyo #pr_err,
#planyo_price_preview_parent .rate_err {
  background-color: transparent !important;
  font-size: 15px;
  font-weight: 600;
  color: #991B1B;
}

/* Make reservation button in price preview widget */
[id^="planyo_price_previewP"] a {
  display: block !important;
  font-family: 'Figtree', sans-serif !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  color: #FFFFFF !important;
  background-color: #1A1A1A !important;
  border-radius: 6px !important;
  padding: 11px 20px !important;
  text-decoration: none !important;
  text-align: center !important;
  width: 100% !important;
  box-sizing: border-box !important;
  margin-top: 14px !important;
  line-height: 1.4 !important;
  border: none !important;
  box-shadow: none !important;
}

[id^="planyo_price_previewP"] a:hover {
  background-color: #383838 !important;
}

/* ─── Price breakdown: CSS Grid (replaces broken float) ─ */
/*
  Original used dl-horizontal floats with margin-left: 0 !important
  which broke the layout at all sizes. CSS Grid pairs dt+dd naturally.
*/
.planyo .price_info_div dl,
.planyo #price_info dl,
.planyo #breakdown dl,
html .planyo .dl-horizontal {
  display: grid !important;
  grid-template-columns: 1fr auto !important;
  gap: 0 !important;
  margin: 0 !important;
  width: 100% !important;
  float: none !important;
}

.planyo .price_info_div dt,
.planyo .price_info_div dd,
html .planyo .dl-horizontal dt,
html .planyo .dl-horizontal dd,
.planyo #breakdown dt,
.planyo #breakdown dd {
  font-family: 'Figtree', sans-serif !important;
  font-size: 13px !important;
  font-weight: 400 !important;
  color: #6A6A6A !important;
  padding: 6px 0 !important;
  margin: 0 !important;
  border-bottom: 1px solid #ECEAE4 !important;
  line-height: 1.4 !important;
  float: none !important;
  min-width: unset !important;
  width: auto !important;
  clear: none !important;
}

html .planyo .dl-horizontal dt,
.planyo .price_info_div dt,
.planyo #breakdown dt {
  text-align: left !important;
  padding-right: 12px !important;
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow: hidden;
  font-weight: 400 !important;
}

html .planyo .dl-horizontal dd,
.planyo .price_info_div dd,
.planyo #breakdown dd {
  text-align: right !important;
  color: #1A1A1A !important;
  font-weight: 500 !important;
}

html .planyo dd { margin: 0 !important; }

/* Total row */
.planyo #breakdown .br_total dt,
.planyo #breakdown .br_total dd {
  font-size: 15px !important;
  font-weight: 600 !important;
  color: #1A1A1A !important;
  border-bottom: none !important;
  border-top: 1px solid #DDD9D0 !important;
  padding-top: 12px !important;
}

html .br_extra_info {
  grid-column: 1 / -1;
  width: 100%;
  font-size: 0.7em;
  color: #9E9E9E;
}

#nobreakdown { font-size: large; color: #1A1A1A; }
.planyo #breakdown .br_total { padding-top: 21px; }
#br_collapse, #br_expand { float: right; clear: both; margin-top: 10px; color: #6A6A6A; font-size: medium; }
#br_collapse:hover, #br_expand:hover { cursor: pointer; }
span.rettrip_label { display: block; clear: both; }

/* Waiting list */
.par_info.par_waitlist_info { margin: 10px 0; }
.par_waitlist_info span { color: #ff0033 !important; font-size: 14px !important; width: 100%; display: inline-block; margin-top: 10px; }
.par_waitlist_info a {
  font-weight: normal;
  margin: 0;
  padding: 6px 12px;
  text-align: center;
  white-space: nowrap;
  vertical-align: middle;
  color: #fff !important;
  background-color: #428bca;
  border-radius: 4px;
  background-image: none;
  line-height: 1.45em;
  border-width: 0;
  font-size: 14px !important;
}
.par_waitlist_info a:hover { border-color: #357ebd; background-color: #253340; cursor: pointer; }

/* ─── Date picker (calpicker / small month) ──────────── */
.planyo span.input-group-addon, .planyo span.input-group-append { background-color: white; }
/* Replace Planyo calendar icon with custom SVG */
html .planyo .planyo-cal-icon,
.planyo a.planyo-cal-icon {
  background-image: url('https://cdn.prod.website-files.com/6546634a5fd8fa6155a73ecf/69a77d9efd0429253c2e401e_calendar_month_24dp_1F1F1F_FILL0_wght400_GRAD0_opsz24.svg') !important;
  background-size: contain !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  width: 20px !important;
  height: 20px !important;
  display: inline-block !important;
}

html .calpicker caption { caption-side: top; }
.float-calpicker th, .calpicker th { text-align: center; border: 0; font-size: 12px; font-weight: 100; padding: 4px; background-color: white; }
html .calpicker { clear: both; border: 1px solid #c0c0c0; border-collapse: collapse; background-color: white; }
html table.calpicker { width: 239px; margin-top: 6px; font-size: 14px; text-align: left; list-style: none; background-color: #fff; -webkit-box-shadow: 0 6px 12px rgba(0,0,0,.175); box-shadow: 0 6px 12px rgba(0,0,0,.175); border: 0; }
.calpicker .no_start:hover { background: #f0f0f0; cursor: default; color: #616161; }
.calpicker .arrival_day { font-weight: bold; }
.calpicker td.morning_av, .calpicker td.morning_av:hover { background: url(https://www.planyo.com/images/diagonal2.png); background-repeat: no-repeat; }
.calpicker td.morning_av_nox, .calpicker td.morning_av_nox:hover { background: url(https://www.planyo.com/images/diagonal2nox.png); background-repeat: no-repeat; background-color: #f0c2c2; }
.calpicker td.morning_occ { background: url(https://www.planyo.com/images/diagonal1.png); background-repeat: no-repeat; }
.calpicker td.morning_occ_nox { background: url(https://www.planyo.com/images/diagonal1nox.png); background-repeat: no-repeat; background-color: #c2dfd0; }
.calpicker .active_day { background: #bbbbbb; color: white; }
.calpicker .reserved_nox_u { background: #e8e8e8; }
.calpicker .reserved_nox { background: #f0c2c2; }
.calpicker .reserved { color: red; font-weight: bold; }
.calpicker .reserved_u { color: red; font-weight: bold; }
.calpicker .reserved:hover { cursor: auto; background: white; color: red; }
.calpicker .reserved_u:hover { cursor: auto; background: white; }
.calpicker .reserved_nox:hover { cursor: auto; background: #f0c2c2; }
.calpicker .reserved_nox_u:hover { cursor: auto; background: #e8e8e8; }
.calpicker .cur_month_day_nox { background: #c2dfd0; }
.calpicker .active_day_nox { text-decoration: underline; background: #cfdfd0; }
.calpicker .ext_month_day_nox { background: #c2dfd0; color: #a0a0a0; }
.calpicker .ext_month_day_nox_u { background: #e8e8e8; color: #a0a0a0; }
.calpicker .ext_month_day_nox_r { background: #f0c2c2; color: #a0a0a0; }
.calpicker .cur_month_day { background: #f0f0f0; }
.calpicker .ext_month_day { background: #ffffff; color: #c5c5c5; }
.calpicker .ext_month_day:hover { cursor: auto; background: #ffffff; }
.calpicker .ext_month_day_nox_r:hover { cursor: auto; background: #f0c2c2; }
.calpicker .ext_month_day_nox_u:hover { cursor: auto; background: #e8e8e8; }
.calpicker .ext_month_day_nox:hover { cursor: auto; background: #c2dfd0; }
html .calpicker td:hover { background: #3D83A8; color: white; cursor: pointer; }
html .calpicker td { border: 1px solid #c0c0c0; vertical-align: top; font-size: 13px; min-width: 10px; text-align: center; padding: 3px 6px; }
html .calpicker caption { padding: 5px 8px; background-color: white; overflow: hidden; text-align: center; border: 1px solid rgba(0,0,0,.15); border-top-right-radius: 4px; border-bottom: 0; border-top-left-radius: 4px; margin-top: 3px; box-shadow: 0 6px 12px rgba(0,0,0,.175); margin-bottom: -3px; }
.calpicker caption .nav { float: left; padding-right: 1px; margin-bottom: 0; }
.calpicker caption .navleft { float: left; font-size: 14px; }
.calpicker caption .navright { float: right; font-size: 14px; }
html .calpicker thead { box-shadow: 0 6px 12px rgba(0,0,0,.175); border-left: 1px solid rgba(0,0,0,.15); border-right: 1px solid rgba(0,0,0,.15); }

/* ─── Reservation steps ──────────────────────────────── */
span.reservation_step, span.reservation_step_current {
  display: inline-block;
  margin-right: 25px;
  max-width: 80px;
  vertical-align: top;
}
.reservation_step .reservation_step_img,
.reservation_step_current .reservation_step_img {
  margin: 0 auto 5px;
  padding-top: 1px;
  width: 40px;
  height: 40px;
  text-align: center;
  border-radius: 20px;
  line-height: initial;
}
.reservation_step_current .reservation_step_name { color: #428bca; }
.reservation_step .reservation_step_name { color: #25334038; }
.reservation_step .reservation_step_img { background-color: #25334038; }
.reservation_step_current .reservation_step_img { background-color: #428bca; }
.reservation_step .reservation_step_name,
.reservation_step_current .reservation_step_name { font-family: sans-serif; font-size: 12px; font-weight: bold; text-align: center; margin-bottom: 8px; }
.reservation_step_current .reservation_step_img_text,
#steps-desktop .reservation_steps .reservation_step .reservation_step_img_text strong,
div.reservation_step_img_text { padding-top: 9px; font-size: 16px; color: #fff; text-align: center; }

html .with-status-border-error { border: 1px solid red !important; }

/* ─── Errors ─────────────────────────────────────────── */
#res_error_msg {
  padding: 10px 5px 1px 10px;
  display: none;
  margin: 2px 0 15px;
  color: white;
  border: 1px solid #ff0033;
  border-radius: 4px;
  background: #ff0033;
}
.bg-danger {
  background-color: #ff0033;
  padding: 10px 5px 10px 10px;
  margin: 2px 10px 10px 0;
  color: white !important;
  border-radius: 4px;
  font-weight: bold;
}

/* ─── Misc ───────────────────────────────────────────── */
.planyo .hourglass_img { margin: 20px; height: 24px; width: 24px; background: transparent url(https://www.planyo.com/Plugins/PlanyoFiles/hourglass.gif) no-repeat scroll 0 0; }
.planyo .poweredby { display: inline-block; float: right; margin-top: -60px; margin-bottom: 50px; }
.planyo .fc table { margin: initial; }

/* ─── Shopping cart ──────────────────────────────────── */
#shopping-cart .resource-contents h2 { margin-top: 0; }
#shopping_cart_items h3 { text-align: right; color: #428bca; font-weight: 500; font-size: medium; }
.planyo #shopping-cart .img-responsive { width: 100px; float: left; margin-right: 20px; border: 0; }
#shopping-cart .col-xs-8.resource-contents { padding-left: 0; }
.planyo .col-sm-1.resource-thumbnail { padding: 0; }
#shopping-cart h4 { color: #428bca; font-size: medium; }
.planyo #shopping-cart .list-group-item { border-left: 0; border-right: 0; position: initial; border-bottom-right-radius: 0; border-bottom-left-radius: 0; }
.planyo li.list-group-item.cart-item:first-child { border-top: 0; }
#shopping-cart .col-xs-5 h4 { float: left; }
#shopping-cart .col-xs-5 .action-buttons { float: right; }

/* ─── Resource details ───────────────────────────────── */
#resource-details .resource-img { width: 100%; }
#resource-details .carousel { position: relative; padding: 0; }
#resource-details .description { text-align: justify; padding-top: 30px; font-size: 16px; line-height: 1.7; width: 100%; }
#resource-details h1, .planyo #products-code h1, #resource-details .calendar-preview, #resource-details .resource-footer { text-align: center; }
#resource-details .resource-footer { margin-top: 30px; margin-bottom: 20px; }
#resource-details .custom_property { text-align: center; float: left; margin: 5px 10px; padding: 6px 10px 8px; border-radius: 4px; display: inline-block; font-weight: 500; line-height: 1.7; font-size: 15px; color: #333; }
.planyo #resource-details .custom_properties { margin: 0 0 0 -20px; }
.planyo #resource-details .custom_properties i.mdi { font-weight: 900; }
.planyo .custom_properties { width: 100%; display: inline-block; }
iframe.calprev_iframe.caltype_multi-month-responsive { max-width: 100%; display: inline-block; }

/* ─── Media queries ──────────────────────────────────── */
@media (max-width: 1024px) {
  .custom_ratebox_vanity { padding-left: 0; padding-right: 0; }
}

@media (max-width: 768px) {
  #reserve_form, .completed-code { padding: 2rem; }
  .ratebox-container { padding: 2rem; }
  .crr-checkout { flex-direction: column; padding: 1rem; gap: 1.5rem; }
  .crr-checkout__aside { order: -1; flex: 1 1 auto; width: 100%; position: static; }
  .crr-checkout__main { width: 100%; }
}

@media (max-width: 767px) {
  .planyo a.btn.btn-primary.btn-lg, .planyo a.btn.btn-primary, .planyo .btn-primary.btn-lg, input.cart_popup_button, input#add_cart_button { font-size: small !important; padding: 6px 7px !important; }
  html .reservation_steps { display: none; }
  .planyo .language { padding-right: 1em; margin-bottom: 5px; }
  .planyo #resource-details h1, .planyo #reservation-code h1, .planyo #payment-code h1, .planyo #completed_code h1, .planyo #details_code h1, .planyo #shopping_cart_items h1, .planyo #products-code h1 { margin-bottom: 10px; margin-top: 0; font-size: 27px; text-align: center; }
  #breakdown dt { float: left; width: 60%; }
  #breakdown dt, #breakdown dd { font-size: small; }
  .planyo #breakdown .br_total { font-weight: bold; }
  #reservation-code .col-md-6 { padding-right: 0; }
  .planyo #reserve_form label { display: block; float: none; width: 100%; }
  .phone-row .col-sm-5 { padding-right: 0; }
  #completion-code .left-content, #completion-code .right-content { width: 100%; }
  #completion-code .right-content { padding: 1rem; }
  #completion-code .completed-code { padding: 0; }
  #completion-code .ratebox-container { padding: 0; }
}

@media (max-width: 480px) {
  #reserve_form, .completed-code { padding: 1rem; }
  .planyo .row { display: flex; flex-wrap: wrap; margin-right: 0; margin-left: 0; }
  .left-content, .right-content { width: 100%; margin-bottom: 20px; }
  .right-content { background-color: #EDE9E1; padding: 1rem; }
  .ratebox-container { width: 100%; padding: 1rem; margin-top: 20px; }
  .custom_reserve_steps_div { flex-direction: column; text-align: center; gap: 0.5rem; }
  #stripe_checkout_submit.btn-primary { font-size: 14px; padding: 10px 16px; }
  #selplusbtn_27240, #selminusbtn_27240, .btn-group .btn-primary { padding: 2px 4px !important; font-size: 10px !important; min-width: 25px !important; }
}

@media (max-width: 991px) {
  .col-md-7.resource-contents, .col-xs-12.resource-description, #resources .resource-contents h2, .col-xs-12.custom_properties, .col-md-6.action-buttons { padding: 0; }
  #resources .resource-contents h2 { margin-top: 15px; }
  #reservation-code .col-md-8 { width: 100%; padding-right: 1rem; padding-left: 1rem; }
}

@media (min-width: 768px) {
  .planyo .pricebox { padding-right: 15px; }
  .planyo .language { padding-right: 30px; }
}

@media (min-width: 991px) {
  html .container-fluid { max-width: 1200px; }
}

@media (min-width: 1200px) {
  html .container-fluid { max-width: none; }
}
.planyo .poweredby,.poweredby {display:none;}
