/* Scoped ONLY to appointment flow wrappers */
[data-appointment-flow]{
  /* do not set fonts/colors globally; rely on site/Bootstrap */
}

/* Wrapper safety */
[data-appointment-flow] .o_wappointment_wrap{ min-height: 1px; overflow-x: hidden; padding-top: 50px; padding-bottom: 50px; }
[data-appointment-flow] .oe_structure{ width: 100%; }

/* Truncation helpers used by templates */
[data-appointment-flow] .text-truncate{
  overflow:hidden; text-overflow:ellipsis; white-space:nowrap; max-width:100%;
}
[data-appointment-flow] .cursor-default{ cursor: default; }

/* Sidebar readability */
[data-appointment-flow] .o_appointment_details_column h4,
[data-appointment-flow] .o_appointment_details_column h5{ line-height: 1.25; }
[data-appointment-flow] .o_appointment_details_type{ gap: .5rem; }
[data-appointment-flow] .o_appointment_user_short_card .text-truncate{ max-width: 100%; }

/* Calendar: make day cells look like clickable tiles without overriding theme */
[data-appointment-flow] [data-appointment-calendar] a[data-cal-day]{
  display:block;
  border-radius:.5rem;
}

/* Avoid layout shift from icons */
[data-appointment-flow] .fa-fw{ width: 1.25em; text-align:center; }

/* Turnstile / iframes: prevent overflow on small screens */
[data-appointment-flow] .s_turnstile_container,
[data-appointment-flow] iframe,
[data-appointment-flow] img,
[data-appointment-flow] video{ max-width:100%; }
[data-appointment-flow] iframe{ display:block; }

/* Forms: avoid box sizing surprises */
[data-appointment-flow] .form-control{ box-sizing:border-box; }

.c2{
   padding: 0px !important;
   overflow: hidden;
   height: 100% !important;
   border-radius: 12px !important;
   border-bottom-right-radius: 9px !important;
    border-bottom-left-radius: 9px !important;
}

[data-appointment-flow] .o_appointment_list_columns {
  --bs-gutter-x: 0;  /* remove the left/right padding that creates the “space” */
}

/* optional: keep some spacing between cards without outer gutters */
[data-appointment-flow] .o_appointment_list_columns {
  --bs-gutter-y: 1rem;
}


.o_appointment_list_grid {
    display: grid;
    /* Gap between cards (equivalent to Bootstrap gutters) */
    gap: 3.5rem; 
    
    /* Default: 1 column (Mobile) */
    grid-template-columns: repeat(1, 1fr);
}

/* Medium devices (Tablets, 768px and up) -> 2 columns */
@media (min-width: 768px) {
    .o_appointment_list_grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* Large devices (Desktops, 992px and up) -> 3 columns */
@media (min-width: 992px) {
    .o_appointment_list_grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

/* Extra Large devices (Large Desktops, 1200px and up) -> 4 columns */
@media (min-width: 1200px) {
    .o_appointment_list_grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

/* Ensure the empty state spans the full width of the grid */
.o_appointment_grid_empty {
    grid-column: 1 / -1;
}

/* Optional: ensures all cards in a row have the same height */
.o_wappointment_card {
    height: 100%;
}
.o_not_editable{
  font-size: 16px !important;
}
.o_wappointment_message_intro{
  font-size: 11pt !important;
}


[data-appointment-flow] .card-title{
  font-size: 20px !important;
  line-height: 1.2 !important;
}
.o_wappointment_card_location{
  align-items: center !important;
  gap: 5px !important;
  font-size: 14px;
}
.o_wappointment_card_location span{
  font-size: 12px !important;
  font-weight: 500 !important;
}

.search-query{
  border-top-left-radius: 4px !important;
  border-bottom-left-radius: 4px !important;
  padding: 12px !important;
}

.search-query:focus{
  box-shadow: none !important;
  outline: none !important;
}

.slot-text{
  font-size: 12px !important;
  font-weight: 700 !important;
  width: calc(50% - 5px);

}
.slot-con{
  flex-wrap: wrap !important;
  max-width: 200px !important;
}.month-txt{
  font-size: 18px !important;
}

.dets-desc-title{
  font-size: 16px !important;
  font-weight: 600 !important;
  margin-bottom: 12px !important;
}
.dets-desc{
  font-size: 14px !important;
  line-height: 1.5 !important;
}
.o_wappointment_wrap{ min-height: 1px; overflow-x: hidden; padding-top: 50px; padding-bottom: 50px; }
.o_appointment_index {
  padding-bottom: 50px; 
  padding-top: 30px;
}

.appointment_submit_form input[type="text"], .appointment_submit_form input[type="email"]{
  font-size: 14px !important;
  height: 50px !important;
  padding-left: 15px;
  border-radius: 5px !important;
}

.appointment_submit_form button{
  font-size: 16px !important;
  height: 50px !important;
  border-radius: 5px !important;
}


.whoami label{
  margin-top: 4px !important;
}


.o_today::after {
    content: "";
    position: absolute;
    top: auto;
    left: 50%;
    bottom: auto;
    right: auto;
    width: 2.5em;
    height: .16em;
    bottom: 0.25rem;
    transform: translateX(-50%);
    background-color: var(--dynamic-highlight);
    border-radius: 50rem;
    transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}






























































/* ==========================================================================
   appointment-flow-bootstrap-bridge.css
   Scoped Bootstrap-like utilities for the appointment flow component only.
   This does NOT load Bootstrap globally.
   Scope: [data-appointment-flow]
   ========================================================================== */

[data-appointment-flow] {
  --bs-gutter-x: 1.5rem;
  --bs-gutter-y: 0;
  --bs-border-color: #dee2e6;
  --bs-border-radius: 0.375rem;
  --bs-border-radius-lg: 0.5rem;
  --bs-light: #f8f9fa;
  --bs-white: #ffffff;
  --bs-text-muted: #6c757d;
  --bs-body-color: #212529;
  --bs-body-bg: #fff;
  --bs-heading-color: inherit;
  --bs-link-color: inherit;
  --bs-link-hover-color: inherit;
  --bs-card-spacer-y: 1rem;
  --bs-card-spacer-x: 1rem;
  --bs-card-title-spacer-y: 0.5rem;
  --bs-card-border-width: 1px;
  --bs-card-border-color: var(--bs-border-color);
  --bs-card-border-radius: var(--bs-border-radius);
  --bs-card-bg: #fff;
  --bs-card-cap-bg: rgba(0, 0, 0, 0.03);
  --bs-card-height: auto;
  --bs-btn-padding-y: 0.375rem;
  --bs-btn-padding-x: 0.75rem;
  --bs-btn-font-size: 1rem;
  --bs-btn-line-height: 1.5;
  --bs-btn-border-radius: 0.375rem;
  --bs-btn-border-width: 1px;
  --bs-btn-border-color: transparent;
  --bs-btn-bg: transparent;
  --bs-btn-color: inherit;
  --bs-btn-hover-color: inherit;
  --bs-btn-hover-bg: transparent;
  --bs-btn-hover-border-color: transparent;
  --bs-btn-disabled-opacity: 0.65;
  --bs-font-sans-serif: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  color: var(--bs-body-color);
  font-family: var(--bs-font-sans-serif);
  box-sizing: border-box;
}

[data-appointment-flow] *,
[data-appointment-flow] *::before,
[data-appointment-flow] *::after {
  box-sizing: border-box;
}

/* ==========================================================================
   Layout
   ========================================================================== */

[data-appointment-flow] .container {
  width: 100%;
  padding-right: calc(var(--bs-gutter-x) * 0.5);
  padding-left: calc(var(--bs-gutter-x) * 0.5);
  margin-right: auto;
  margin-left: auto;
}

@media (min-width: 576px) {
  [data-appointment-flow] .container {
    max-width: 540px;
  }
}

@media (min-width: 768px) {
  [data-appointment-flow] .container {
    max-width: 720px;
  }
}

@media (min-width: 992px) {
  [data-appointment-flow] .container {
    max-width: 960px;
  }
}

@media (min-width: 1200px) {
  [data-appointment-flow] .container {
    max-width: 1140px;
  }
}

@media (min-width: 1400px) {
  [data-appointment-flow] .container {
    max-width: 1320px;
  }
}

[data-appointment-flow] .row {
  display: flex;
  flex-wrap: wrap;
  margin-right: calc(var(--bs-gutter-x) * -0.5);
  margin-left: calc(var(--bs-gutter-x) * -0.5);
}

[data-appointment-flow] .row > * {
  width: 100%;
  max-width: 100%;
  padding-right: calc(var(--bs-gutter-x) * 0.5);
  padding-left: calc(var(--bs-gutter-x) * 0.5);
  margin-top: var(--bs-gutter-y);
}

[data-appointment-flow] .col-md {
  position: relative;
  width: 100%;
  min-height: 1px;
}

@media (min-width: 768px) {
  [data-appointment-flow] .col-md {
    flex: 1 0 0%;
  }
}

/* ==========================================================================
   Display / Flex
   ========================================================================== */

[data-appointment-flow] .d-block {
  display: block !important;
}

[data-appointment-flow] .d-flex {
  display: flex !important;
}

[data-appointment-flow] .d-print-none {
  display: none !important;
}

@media screen {
  [data-appointment-flow] .d-print-none {
    display: inherit !important;
  }

  [data-appointment-flow] .d-flex.d-print-none {
    display: flex !important;
  }

  [data-appointment-flow] .d-block.d-print-none {
    display: block !important;
  }
}

[data-appointment-flow] .flex-column {
  flex-direction: column !important;
}

[data-appointment-flow] .flex-wrap {
  flex-wrap: wrap !important;
}

[data-appointment-flow] .flex-grow-1 {
  flex-grow: 1 !important;
}

[data-appointment-flow] .align-items-center {
  align-items: center !important;
}

[data-appointment-flow] .align-items-start {
  align-items: flex-start !important;
}

[data-appointment-flow] .justify-content-between {
  justify-content: space-between !important;
}

[data-appointment-flow] .gap-1 {
  gap: 0.25rem !important;
}

[data-appointment-flow] .gap-2 {
  gap: 0.5rem !important;
}

[data-appointment-flow] .gap-3 {
  gap: 1rem !important;
}

/* ==========================================================================
   Spacing
   ========================================================================== */

[data-appointment-flow] .m-0 {
  margin: 0 !important;
}

[data-appointment-flow] .mt-3 {
  margin-top: 1rem !important;
}

[data-appointment-flow] .mt-4 {
  margin-top: 1.5rem !important;
}

[data-appointment-flow] .mt-auto {
  margin-top: auto !important;
}

[data-appointment-flow] .mb-0 {
  margin-bottom: 0 !important;
}

[data-appointment-flow] .mb-2 {
  margin-bottom: 0.5rem !important;
}

[data-appointment-flow] .mb-3 {
  margin-bottom: 1rem !important;
}

[data-appointment-flow] .ms-auto {
  margin-left: auto !important;
}

[data-appointment-flow] .mt-n3 {
  margin-top: -1rem !important;
}

[data-appointment-flow] .p-4 {
  padding: 1.5rem !important;
}

[data-appointment-flow] .px-0 {
  padding-right: 0 !important;
  padding-left: 0 !important;
}

[data-appointment-flow] .py-3 {
  padding-top: 1rem !important;
  padding-bottom: 1rem !important;
}

/* ==========================================================================
   Width / Height / Overflow
   ========================================================================== */

[data-appointment-flow] .w-100 {
  width: 100% !important;
}

[data-appointment-flow] .w-auto {
  width: auto !important;
}

[data-appointment-flow] .h-100 {
  height: 100% !important;
}

[data-appointment-flow] .overflow-hidden {
  overflow: hidden !important;
}

[data-appointment-flow] .position-relative {
  position: relative !important;
}

[data-appointment-flow] .text-break {
  overflow-wrap: break-word !important;
  word-wrap: break-word !important;
  word-break: break-word !important;
}

/* Optional width helper used in template */
[data-appointment-flow] .w-fit {
  width: fit-content !important;
}

@media (min-width: 992px) {
  [data-appointment-flow] .w-lg-25 {
    width: 25% !important;
  }
}

/* ==========================================================================
   Typography
   ========================================================================== */

[data-appointment-flow] h1,
[data-appointment-flow] h2,
[data-appointment-flow] h3,
[data-appointment-flow] h4,
[data-appointment-flow] h5,
[data-appointment-flow] h6 {
  margin-top: 0;
  margin-bottom: 0.5rem;
  font-weight: 500;
  line-height: 1.2;
}

[data-appointment-flow] h1 {
  font-size: calc(1.375rem + 1.5vw);
}

@media (min-width: 1200px) {
  [data-appointment-flow] h1 {
    font-size: 2.5rem;
  }
}

[data-appointment-flow] h5,
[data-appointment-flow] .h5 {
  font-size: 1.25rem;
}

[data-appointment-flow] .h4 {
  font-size: calc(1.275rem + 0.3vw);
}

@media (min-width: 1200px) {
  [data-appointment-flow] .h4 {
    font-size: 1.5rem;
  }
}

[data-appointment-flow] p {
  margin-top: 0;
  margin-bottom: 1rem;
}

[data-appointment-flow] .fw-bold {
  font-weight: 700 !important;
}

[data-appointment-flow] .lh-base {
  line-height: 1.5 !important;
}

[data-appointment-flow] .small,
[data-appointment-flow] .smaller {
  font-size: 0.875em !important;
}

[data-appointment-flow] .text-muted {
  color: var(--bs-text-muted) !important;
}

/* ==========================================================================
   Links / Images
   ========================================================================== */

[data-appointment-flow] a {
  text-decoration: none;
}

[data-appointment-flow] a:hover {
  text-decoration: none;
}

[data-appointment-flow] img,
[data-appointment-flow] .img {
  max-width: 100%;
  height: auto;
  vertical-align: middle;
}

[data-appointment-flow] .img-fluid {
  max-width: 100%;
  height: auto;
}

/* ==========================================================================
   Card
   ========================================================================== */

[data-appointment-flow] .card {
  position: relative;
  display: flex;
  flex-direction: column;
  min-width: 0;
  height: var(--bs-card-height);
  color: inherit;
  word-wrap: break-word;
  background-color: var(--bs-card-bg);
  background-clip: border-box;
  border: var(--bs-card-border-width) solid var(--bs-card-border-color);
  border-radius: var(--bs-card-border-radius);
}

[data-appointment-flow] .card-img-top {
  width: 100%;
  border-top-left-radius: calc(var(--bs-card-border-radius) - 1px);
  border-top-right-radius: calc(var(--bs-card-border-radius) - 1px);
}

[data-appointment-flow] .card-body {
  flex: 1 1 auto;
  padding: var(--bs-card-spacer-y) var(--bs-card-spacer-x);
}

[data-appointment-flow] .card-title {
  margin-bottom: var(--bs-card-title-spacer-y);
}

[data-appointment-flow] .card-text:last-child {
  margin-bottom: 0;
}

/* ==========================================================================
   Buttons
   ========================================================================== */

[data-appointment-flow] .btn {
  display: block !important;
  font-weight: 400;
  line-height: var(--bs-btn-line-height);
 
  text-align: center;
  text-decoration: none;
  cursor: pointer;
  user-select: none;
  background-color: var(--bs-btn-bg);
  border: var(--bs-btn-border-width) solid var(--bs-btn-border-color);
  padding: var(--bs-btn-padding-y) var(--bs-btn-padding-x);
  font-size: var(--bs-btn-font-size);
  border-radius: var(--bs-btn-border-radius);
  transition:
    color 0.15s ease-in-out,
    background-color 0.15s ease-in-out,
    border-color 0.15s ease-in-out,
    box-shadow 0.15s ease-in-out;
}

[data-appointment-flow] .btn:not([data-appointment-flow2] .btn) {
  color: var(--bs-btn-color);
}

[data-appointment-flow] .btn:hover {
  color: var(--bs-btn-hover-color);
  background-color: var(--bs-btn-hover-bg);
  border-color: var(--bs-btn-hover-border-color);
  text-decoration: none;
}

[data-appointment-flow] .btn:disabled,
[data-appointment-flow] .btn.disabled,
[data-appointment-flow] [aria-disabled="true"] {
  pointer-events: none;
  opacity: var(--bs-btn-disabled-opacity);
}

[data-appointment-flow] .btn-light {
  --bs-btn-color: #212529;
  --bs-btn-bg: #f8f9fa;
  --bs-btn-border-color: #f8f9fa;
  --bs-btn-hover-color: #212529;
  --bs-btn-hover-bg: #dfe0e1;
  --bs-btn-hover-border-color: #d3d4d5;
}

/* ==========================================================================
   Forms / Input group
   ========================================================================== */

[data-appointment-flow] form {
  margin: 0;
}

[data-appointment-flow] .input-group {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  width: 100%;
}

[data-appointment-flow] .input-group > .form-control,
[data-appointment-flow] .input-group > .btn {
  position: relative;
}

[data-appointment-flow] .input-group > .form-control {
  flex: 1 1 auto;
  width: 1%;
  min-width: 0;
}

[data-appointment-flow] .input-group > .form-control:not(:last-child) {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}

[data-appointment-flow] .input-group > .btn:not(:first-child) {
  margin-left: -1px;
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}

[data-appointment-flow] .form-control {
  display: block;
  width: 100%;
  padding: 0.375rem 0.75rem;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.5;
  color: #212529;
  background-color: #fff;
  background-clip: padding-box;
  border: 1px solid #ced4da;
  appearance: none;
  border-radius: 0.375rem;
  transition:
    border-color 0.15s ease-in-out,
    box-shadow 0.15s ease-in-out;
}

[data-appointment-flow] .form-control:focus {
  color: #212529;
  background-color: #fff;
  border-color: #86b7fe;
  outline: 0;
  box-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.25);
}

[data-appointment-flow] .form-control::placeholder {
  color: #6c757d;
  opacity: 1;
}

[data-appointment-flow] .border-0 {
  border: 0 !important;
}

[data-appointment-flow] .bg-light {
  background-color: var(--bs-light) !important;
}

/* ==========================================================================
   Borders / Radius
   ========================================================================== */

[data-appointment-flow] .border {
  border: 1px solid var(--bs-border-color) !important;
}

[data-appointment-flow] .rounded-3 {
  border-radius: var(--bs-border-radius-lg) !important;
}

/* ==========================================================================
   Ratio / Object fit
   ========================================================================== */

[data-appointment-flow] .ratio {
  position: relative;
  width: 100%;
}

[data-appointment-flow] .ratio::before {
  display: block;
  content: "";
}

[data-appointment-flow] .ratio > * {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

[data-appointment-flow] .ratio-16x9::before {
  padding-top: 56.25%;
}

[data-appointment-flow] .object-fit-cover,
[data-appointment-flow] .object-fit-cover > img,
[data-appointment-flow] img.object-fit-cover {
  object-fit: cover;
}

/* ==========================================================================
   Component-specific helpers
   ========================================================================== */

[data-appointment-flow] .o_appointment_index {
  position: relative;
}

[data-appointment-flow] .o_appointment_list_grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}

@media (min-width: 768px) {
  [data-appointment-flow] .o_appointment_list_grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 1200px) {
  [data-appointment-flow] .o_appointment_list_grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

[data-appointment-flow] .o_appointment_grid_empty {
  grid-column: 1 / -1;
}

[data-appointment-flow] .o_wappointment_card {
  overflow: hidden;
}

[data-appointment-flow] .o_wappointment_message_intro > *:last-child {
  margin-bottom: 0;
}

[data-appointment-flow] .o_searchbar_form {
  width: 100%;
}

[data-appointment-flow] .oe_search_button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.75rem;
}

[data-appointment-flow] .o_not_editable {
  display: inline;
}

/* ==========================================================================
   Accessibility / utility polish
   ========================================================================== */

[data-appointment-flow] button,
[data-appointment-flow] input,
[data-appointment-flow] select,
[data-appointment-flow] textarea {
  font: inherit;
}

[data-appointment-flow] [hidden] {
  display: none !important;
}

/* ==========================================================================
   Print
   ========================================================================== */

@media print {
  [data-appointment-flow] .d-print-none {
    display: none !important;
  }
}























































/* ==========================================================================
   appointment-detail-bootstrap-bridge.css
   Scoped Bootstrap-like utilities for the appointment detail component only.
   Scope: [data-appointment-flow2]
   ========================================================================== */

[data-appointment-flow2] {
  --bs-gutter-x: 1.5rem;
  --bs-gutter-y: 0;
  --bs-border-color: #dee2e6;
  --bs-border-radius: 0.375rem;
  --bs-border-radius-sm: 0.25rem;
  --bs-border-radius-lg: 0.5rem;
  --bs-light: #f8f9fa;
  --bs-info-bg-subtle: #cff4fc;
  --bs-info-border-subtle: #b6effb;
  --bs-info-text: #055160;
  --bs-warning-bg-subtle: #fff3cd;
  --bs-warning-border-subtle: #ffecb5;
  --bs-warning-text: #664d03;
  --bs-body-color: #212529;
  --bs-body-bg: #fff;
  --bs-heading-color: inherit;
  --bs-font-sans-serif: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  color: var(--bs-body-color);
  font-family: var(--bs-font-sans-serif);
  box-sizing: border-box;
}

[data-appointment-flow2] *,
[data-appointment-flow2] *::before,
[data-appointment-flow2] *::after {
  box-sizing: border-box;
}

/* ==========================================================================
   Layout
   ========================================================================== */

[data-appointment-flow2] .container-lg,
[data-appointment-flow2] .container {
  width: 100%;
  padding-right: calc(var(--bs-gutter-x) * 0.5);
  padding-left: calc(var(--bs-gutter-x) * 0.5);
  margin-right: auto;
  margin-left: auto;
}

@media (min-width: 576px) {
  [data-appointment-flow2] .container-lg,
  [data-appointment-flow2] .container {
    max-width: 540px;
  }
}

@media (min-width: 768px) {
  [data-appointment-flow2] .container-lg,
  [data-appointment-flow2] .container {
    max-width: 720px;
  }
}

@media (min-width: 992px) {
  [data-appointment-flow2] .container-lg,
  [data-appointment-flow2] .container {
    max-width: 960px;
  }
}

@media (min-width: 1200px) {
  [data-appointment-flow2] .container-lg {
    max-width: 1140px;
  }
}

@media (min-width: 1400px) {
  [data-appointment-flow2] .container-lg {
    max-width: 1320px;
  }
}

[data-appointment-flow2] .row {
  display: flex;
  flex-wrap: wrap;
  margin-top: calc(-1 * var(--bs-gutter-y));
  margin-right: calc(-0.5 * var(--bs-gutter-x));
  margin-left: calc(-0.5 * var(--bs-gutter-x));
}

[data-appointment-flow2] .row > * {
  flex-shrink: 0;
  width: 100%;
  max-width: 100%;
  padding-right: calc(var(--bs-gutter-x) * 0.5);
  padding-left: calc(var(--bs-gutter-x) * 0.5);
  margin-top: var(--bs-gutter-y);
}

[data-appointment-flow2] .g-4 {
  --bs-gutter-x: 1.5rem;
  --bs-gutter-y: 1.5rem;
}

[data-appointment-flow2] .col-12 {
  flex: 0 0 auto;
  width: 100%;
}

@media (min-width: 768px) {
  [data-appointment-flow2] .col-md-4 {
    flex: 0 0 auto;
    width: 33.33333333%;
  }

  [data-appointment-flow2] .col-md-8 {
    flex: 0 0 auto;
    width: 66.66666667%;
  }

  [data-appointment-flow2] .d-md-none {
    display: none !important;
  }
}

@media (min-width: 992px) {
  [data-appointment-flow2] .col-lg-3 {
    flex: 0 0 auto;
    width: 25%;
  }

  [data-appointment-flow2] .col-lg-6 {
    flex: 0 0 auto;
    width: 50%;
  }

  [data-appointment-flow2] .offset-lg-1 {
    margin-left: 8.33333333%;
  }

  [data-appointment-flow2] .d-lg-flex {
    display: flex !important;
  }

  [data-appointment-flow2] .mb-lg-0 {
    margin-bottom: 0 !important;
  }
}

/* ==========================================================================
   Display / Flex / Grid
   ========================================================================== */

[data-appointment-flow2] .d-none {
  display: none !important;
}

[data-appointment-flow2] .d-flex {
  display: flex !important;
}

[data-appointment-flow2] .d-inline {
  display: inline !important;
}

[data-appointment-flow2] .d-grid {
  display: grid !important;
}

[data-appointment-flow2] .d-print-none {
  display: none !important;
}

@media screen {
  [data-appointment-flow2] .d-print-none {
    display: inherit !important;
  }

  [data-appointment-flow2] .d-flex.d-print-none {
    display: flex !important;
  }
}

[data-appointment-flow2] .flex-column {
  flex-direction: column !important;
}

[data-appointment-flow2] .align-items-center {
  align-items: center !important;
}

[data-appointment-flow2] .justify-content-between {
  justify-content: space-between !important;
}

[data-appointment-flow2] .text-center {
  text-align: center !important;
}

[data-appointment-flow2] .text-start {
  text-align: left !important;
}

[data-appointment-flow2] .text-truncate {
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

[data-appointment-flow2] .gap-1 {
  gap: 0.25rem !important;
}

[data-appointment-flow2] .gap-2 {
  gap: 0.5rem !important;
}

[data-appointment-flow2] .overflow-hidden,
[data-appointment-flow2] .overflow-x-hidden {
  overflow: hidden !important;
}

[data-appointment-flow2] .overflow-x-hidden {
  overflow-x: hidden !important;
}

[data-appointment-flow2] .position-relative,
[data-appointment-flow2] .relative {
  position: relative !important;
}

[data-appointment-flow2] .w-auto {
  width: auto !important;
}

/* ==========================================================================
   Spacing
   ========================================================================== */

[data-appointment-flow2] .m-0 {
  margin: 0 !important;
}

[data-appointment-flow2] .my-4 {
  margin-top: 1.5rem !important;
  margin-bottom: 1.5rem !important;
}

[data-appointment-flow2] .mt-1 {
  margin-top: 0.25rem !important;
}

[data-appointment-flow2] .mt-2 {
  margin-top: 0.5rem !important;
}

[data-appointment-flow2] .mt-3 {
  margin-top: 1rem !important;
}

[data-appointment-flow2] .mt-4 {
  margin-top: 1.5rem !important;
}

[data-appointment-flow2] .mt-5 {
  margin-top: 3rem !important;
}

[data-appointment-flow2] .mb-0 {
  margin-bottom: 0 !important;
}

[data-appointment-flow2] .mb-1 {
  margin-bottom: 0.25rem !important;
}

[data-appointment-flow2] .mb-2 {
  margin-bottom: 0.5rem !important;
}

[data-appointment-flow2] .mb-3 {
  margin-bottom: 1rem !important;
}

[data-appointment-flow2] .mb-4 {
  margin-bottom: 1.5rem !important;
}

[data-appointment-flow2] .me-2 {
  margin-right: 0.5rem !important;
}

[data-appointment-flow2] .me-3 {
  margin-right: 1rem !important;
}

[data-appointment-flow2] .ms-2 {
  margin-left: 0.5rem !important;
}

[data-appointment-flow2] .ms-3 {
  margin-left: 1rem !important;
}

[data-appointment-flow2] .p-3 {
  padding: 1rem !important;
}

[data-appointment-flow2] .py-1 {
  padding-top: 0.25rem !important;
  padding-bottom: 0.25rem !important;
}

[data-appointment-flow2] .py-2 {
  padding-top: 0.5rem !important;
  padding-bottom: 0.5rem !important;
}

[data-appointment-flow2] .py-3 {
  padding-top: 10px !important;
  padding-bottom: 10px !important;
}

[data-appointment-flow2] .py-4 {
  padding-top: 15px !important;
  padding-bottom: 15px !important;
}

[data-appointment-flow2] .px-0 {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

[data-appointment-flow2] .pb-4 {
  padding-bottom: 1.5rem !important;
}

[data-appointment-flow2] .pt-3 {
  padding-top: 1rem !important;
}

/* ==========================================================================
   Typography
   ========================================================================== */

[data-appointment-flow2] h3,
[data-appointment-flow2] h4,
[data-appointment-flow2] h5,
[data-appointment-flow2] p,
[data-appointment-flow2] ul {
  margin-top: 0;
}

[data-appointment-flow2] h3 {
  font-size: calc(1.3rem + 0.6vw);
  line-height: 1.2;
  margin-bottom: 0.5rem;
}

[data-appointment-flow2] h4 {
  font-size: calc(1.275rem + 0.3vw);
  line-height: 1.2;
  margin-bottom: 0.5rem;
}

[data-appointment-flow2] h5 {
  font-size: 1.25rem;
  line-height: 1.2;
  margin-bottom: 0.5rem;
}

[data-appointment-flow2] .fw-bold {
  font-weight: 700 !important;
}

[data-appointment-flow2] .small,
[data-appointment-flow2] small {
  font-size: 0.875em !important;
}

[data-appointment-flow2] .text-uppercase {
  text-transform: uppercase !important;
}

/* ==========================================================================
   Lists
   ========================================================================== */

[data-appointment-flow2] .list-unstyled {
  padding-left: 0;
  list-style: none;
}

/* ==========================================================================
   Borders / Radius / Background
   ========================================================================== */

[data-appointment-flow2] .border {
  border: 1px solid var(--bs-border-color) !important;
}

[data-appointment-flow2] .border-0 {
  border: 0 !important;
}

[data-appointment-flow2] .border-top {
  border-top: 1px solid var(--bs-border-color) !important;
}

[data-appointment-flow2] .rounded-2 {
  border-radius: var(--bs-border-radius-sm) !important;
}

[data-appointment-flow2] .rounded-3 {
  border-radius: var(--bs-border-radius-lg) !important;
}

[data-appointment-flow2] .bg-transparent {
  background-color: transparent !important;
}

/* ==========================================================================
   Alerts
   ========================================================================== */

[data-appointment-flow2] .alert {
  position: relative;
  padding: 1rem;
  margin-bottom: 1rem;
  border: 1px solid transparent;
  border-radius: var(--bs-border-radius);
}

[data-appointment-flow2] .alert-warning {
  color: var(--bs-warning-text);
  background-color: var(--bs-warning-bg-subtle);
  border-color: var(--bs-warning-border-subtle);
}

[data-appointment-flow2] .alert-info {
  color: var(--bs-info-text);
  background-color: var(--bs-info-bg-subtle);
  border-color: var(--bs-info-border-subtle);
}

/* ==========================================================================
   Buttons
   ========================================================================== */

[data-appointment-flow2] .btn {
  display: inline-block;
  padding: 0.375rem 0.75rem;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.5;
  text-align: center;
  text-decoration: none;
  vertical-align: middle;
  cursor: pointer;
  user-select: none;
  border: 1px solid transparent;
  border-radius: var(--bs-border-radius);
  background: transparent;
  transition:
    color 0.15s ease-in-out,
    background-color 0.15s ease-in-out,
    border-color 0.15s ease-in-out,
    box-shadow 0.15s ease-in-out;
}

[data-appointment-flow2] .btn:hover {
  text-decoration: none;
}

[data-appointment-flow2] .btn-sm {
  padding: 0.25rem 0.5rem !important;
  font-size: 0.875rem;
  border-radius: 0.25rem;
}

[data-appointment-flow2] .btn-outline-secondary {
  color: #6c757d;
  border-color: #6c757d;
  background-color: transparent;
}

[data-appointment-flow2] .btn-outline-secondary:hover {
  color: #fff;
  background-color: #6c757d;
  border-color: #6c757d;
}

/* ==========================================================================
   Forms
   ========================================================================== */

[data-appointment-flow2] form {
  margin: 0;
  max-width: calc(100% - 150px);
}

[data-appointment-flow2] .form-select {
  display: block !important;
  width: 100% !important;
  min-width: 0;
  padding: 0.375rem 2.25rem 0.375rem 0.75rem;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.5;
  color: inherit;
  background-color: #fff;
  background-image:
    linear-gradient(45deg, transparent 50%, currentColor 50%),
    linear-gradient(135deg, currentColor 50%, transparent 50%);
  background-position:
    calc(100% - 16px) calc(50% - 3px),
    calc(100% - 11px) calc(50% - 3px);
  background-size: 5px 5px, 5px 5px;
  background-repeat: no-repeat;
  border: 1px solid #ced4da;
  border-radius: var(--bs-border-radius);
  appearance: none;
}

[data-appointment-flow2] .form-select:focus {
  border-color: #86b7fe;
  outline: 0;
  box-shadow: 0 0 0 0.2rem rgba(13, 110, 253, 0.2);
}

[data-appointment-flow2] .form-select-lg {
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
  font-size: 1.1rem;
}

/* ==========================================================================
   Links
   ========================================================================== */

[data-appointment-flow2] a {
  text-decoration: none;
}

[data-appointment-flow2] .text-decoration-none {
  text-decoration: none !important;
}

/* ==========================================================================
   Component helpers
   ========================================================================== */

[data-appointment-flow2] .cursor-default {
  cursor: default;
}


[data-appointment-flow2] .fullspan {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  display: inline-block; /* or block */
  max-width: 200px; /* optional limit */
}


[data-appointment-flow2] [data-appointment-breadcrumb] a:hover {
  opacity: 0.9;
}

[data-appointment-flow2] .month-txt {
  font-size: 1rem;
  line-height: 1.2;
}

[data-appointment-flow2] .cday {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition:
    background-color 0.15s ease,
    color 0.15s ease,
    opacity 0.15s ease,
    border-color 0.15s ease;
}

[data-appointment-flow2] .opacity-50 {
  opacity: 0.5 !important;
}

[data-appointment-flow2] .o_today::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0.45rem;
  transform: translateX(-50%);
  height: 0.35rem;
  border-radius: 999px;
  background: var(--dynamic-highlight, currentColor);
}

[data-appointment-flow2] .o_appointment_details_column {
  word-break: break-word;
}

[data-appointment-flow2] .o_appointment_user_short_card strong {
  display: inline-block;
}

[data-appointment-flow2] .dets-desc > *:last-child,
[data-appointment-flow2] .o_appointment_description > *:last-child {
  margin-bottom: 0;
}

/* simple flex aliases because your template mixes Tailwind-like names */
[data-appointment-flow2] .flex {
  display: flex !important;
}

[data-appointment-flow2] .items-center {
  align-items: center !important;
}

/* ==========================================================================
   Print
   ========================================================================== */

@media print {
  [data-appointment-flow2] .d-print-none {
    display: none !important;
  }
}



















[data-hero-with-text],
[data-hero-with-text] *,
[data-hero-with-text] *::before,
[data-hero-with-text] *::after {
  box-sizing: border-box;
}

[data-hero-with-text] img,
[data-hero-with-text] video,
[data-hero-with-text] svg {
  display: block;
  vertical-align: middle;
}

[data-hero-with-text] img,
[data-hero-with-text] video {
  max-width: 100%;
  height: auto;
}

/* utility classes used by this component */
[data-hero-with-text] .mx-auto {
  margin-left: auto;
  margin-right: auto;
}

[data-hero-with-text] .mb-4 {
  margin-bottom: 1rem;
}

[data-hero-with-text] .mb-16 {
  margin-bottom: 4rem;
}

[data-hero-with-text] .block {
  display: block;
}

[data-hero-with-text] .flex {
  display: flex;
}

[data-hero-with-text] .w-fit {
  width: fit-content;
}

[data-hero-with-text] .size-full {
  width: 100%;
  height: 100%;
}

[data-hero-with-text] .w-full {
  width: 100%;
}

[data-hero-with-text] .max-w-screen-2xl {
  max-width: 1536px;
}

[data-hero-with-text] .max-h-\[522px\] {
  max-height: 522px;
}

[data-hero-with-text] .overflow-clip {
  overflow: clip;
}

[data-hero-with-text] .relative {
  position: relative;
}

[data-hero-with-text] .rounded-2xl {
  border-radius: 1rem;
}

[data-hero-with-text] .space-y-5 > :not([hidden]) ~ :not([hidden]) {
  margin-top: 1.25rem;
}

[data-hero-with-text] .gap-2 {
  gap: 0.5rem;
}

[data-hero-with-text] .p-2 {
  padding: 0.5rem;
}

[data-hero-with-text] .px-4 {
  padding-left: 1rem;
  padding-right: 1rem;
}

[data-hero-with-text] .py-16 {
  padding-top: 4rem;
  padding-bottom: 4rem;
}

[data-hero-with-text] .text-center {
  text-align: center;
}

[data-hero-with-text] .text-sm {
  font-size: 0.875rem;
  line-height: 1.25rem;
}

[data-hero-with-text] .text-2xl {
  font-size: 1.5rem;
  line-height: 2rem;
}

[data-hero-with-text] .font-medium {
  font-weight: 400;
}

[data-hero-with-text] .font-semibold {
  font-weight: 450;
}

[data-hero-with-text] .leading-tight {
  line-height: 1.25;
}

[data-hero-with-text] .tracking-tighter {
  letter-spacing: -0.05em;
}

[data-hero-with-text] .object-cover {
  object-fit: cover;
}

/* responsive utilities used by this component */
@media (min-width: 1024px) {
  [data-hero-with-text] .lg\:px-8 {
    padding-left: 2rem;
    padding-right: 2rem;
  }

  [data-hero-with-text] .lg\:text-base {
    font-size: 1rem;
    line-height: 1.5rem;
  }

  [data-hero-with-text] .lg\:text-5xl {
    font-size: 3rem;
    line-height: 1;
  }

  [data-hero-with-text] .lg\:py-\[100px\] {
    padding-top: 100px;
    padding-bottom: 100px;
  }
}

/* custom utility/helper classes used in this component */
[data-hero-with-text] .pt100 {
  padding-top: 100px;
}

[data-hero-with-text] .desk {
  display: block;
}

[data-hero-with-text] .mob {
  display: none;
}

@media screen and (max-width: 768px) {
  [data-hero-with-text] .desk {
    display: none !important;
  }

  [data-hero-with-text] .mob {
    display: block !important;
  }
}

/* hero-specific custom classes */
[data-hero-with-text] .hero_review {
  display: flex;
}

[data-hero-with-text] .rating_text {
  font-size: 25px;
  font-weight: 500;
  line-height: 0.9;
  margin-top: 5px;
}

[data-hero-with-text] .rating_text2 {
  font-size: 12px;
  line-height: 1.3;
}

[data-hero-with-text] .banner-title {
  font-size: 36px;
  line-height: 1.2;
  font-weight: 600;
  margin-bottom: 15px;
}

@media (max-width: 1200px) {
  [data-hero-with-text] .banner-title {
    font-size: 28px;
  }
}

@media (max-width: 768px) {
  [data-hero-with-text] .banner-title {
    font-size: 20px;
  }

  [data-hero-with-text] .logoimg {
    height: 40px !important;
  }

  [data-hero-with-text] .stardiv div svg {
    width: 15px !important;
    height: auto !important;
  }
}

@media screen and (max-width: 375px) {
  [data-hero-with-text] .banner-title {
    font-size: 14px !important;
  }

  [data-hero-with-text] .logoimg {
    height: 25px !important;
  }
}

/* alignment helper classes found in your stylesheet */
[data-hero-with-text] .justify-right {
  justify-content: end;
}

[data-hero-with-text] .justify-center {
  justify-content: center;
}

[data-hero-with-text] .justify-left {
  justify-content: start;
}

[data-hero-with-text] .text-right {
  text-align: right;
}

[data-hero-with-text] .text-left {
  text-align: left;
}

[data-hero-with-text] .flex-end {
  align-items: end;
}

[data-hero-with-text] .flex-center {
  align-items: center;
}

[data-hero-with-text] .flex-start {
  align-items: start;
}

/* image/video helpers */
[data-hero-with-text] .hero-image,
[data-hero-with-text] .hero-image2 {
  width: 100%;
}

[data-hero-with-text] .hero-image-2 {
  aspect-ratio: 16/11 !important;
}

/* theme/background helpers used directly in the markup */
[data-hero-with-text] .bg-white {
  background-color: #fff !important;
}

[data-hero-with-text] .bg-black {
  background-color: #000 !important;
}

[data-hero-with-text] .bg-dark-mystique {
  background-color: #2a2927 !important;
}

[data-hero-with-text] .bg-midnight-elegance {
  background-color: #0c2a44 !important;
}

[data-hero-with-text] .bg-vintage-cashmare {
  background-color: #aea797 !important;
}

[data-hero-with-text] .bg-soft-beige {
  background-color: #f1eae0 !important;
}

[data-hero-with-text] .bg-gold\/20 {
  background-color: #cfc8b7 !important;
}

/* dynamic text system used by the component */
[data-hero-with-text] .bg-white .dynamic {
  color: rgb(42, 41, 39) !important;
  fill: rgb(42, 41, 39) !important;
}

[data-hero-with-text] .bg-white .dynamic-2 {
  color: rgba(42, 41, 39, 0.7) !important;
}

[data-hero-with-text] .bg-soft-beige .dynamic {
  color: #2a2927 !important;
  fill: #2a2927 !important;
}

[data-hero-with-text] .bg-soft-beige .dynamic-2 {
  color: #7e7e7e !important;
}

[data-hero-with-text] .bg-vintage-cashmare .dynamic {
  color: #fcfcfc !important;
  fill: #fcfcfc !important;
}

[data-hero-with-text] .bg-vintage-cashmare .dynamic-2 {
  color: #dddad4 !important;
}

[data-hero-with-text] .bg-black .dynamic,
[data-hero-with-text] .bg-dark-mystique .dynamic,
[data-hero-with-text] .bg-midnight-elegance .dynamic {
  color: #fcfcfc !important;
  fill: #fcfcfc !important;
}

[data-hero-with-text] .bg-black .dynamic-2,
[data-hero-with-text] .bg-dark-mystique .dynamic-2 {
  color: #a8a8a7 !important;
}

[data-hero-with-text] .bg-midnight-elegance .dynamic-2 {
  color: #9ca8b2 !important;
}

/* text color helpers that may be injected by instance fields */
[data-hero-with-text] .text-dark\/60 {
  color: rgb(42 41 39 / 0.6) !important;
}

/* reveal hook kept scoped */
[data-hero-with-text] .reveal-on-scroll {
  /* hook only; animation JS/CSS can be added here if needed */
}
[data-hero-with-text] .hero-sub-image {
  position: absolute;
  z-index: 1;
  width: auto;
  height: auto;
  max-width: 50%;
  max-height: 80%;
}

[data-hero-with-text] .hero_banner {
  position: absolute;
  height: 100%;
  width: 100%;
  top: 0;
  left: 0;
  right: 0;
  margin: 0 auto;
  display: flex;
  align-items: center;
}

[data-hero-with-text] .hero_banner_content {
  padding: 100px;
  z-index: 2;
}

@media screen and (max-width: 768px) {
  [data-hero-with-text] .hero_banner_content {
    padding: 50px;
  }
}

@media screen and (max-width: 400px) {
  [data-hero-with-text] .hero_banner_content {
    padding: 20px;
  }
}

[data-hero-with-text] .hero_banner_content2 {
  padding: 150px;
  z-index: 2;
}

@media screen and (max-width: 768px) {
  [data-hero-with-text] .hero_banner_content2 {
    padding: 70px;
  }
}

@media screen and (max-width: 400px) {
  [data-hero-with-text] .hero_banner_content2 {
    padding: 40px;
  }
}

[data-hero-with-text] .banner-review-link {
  display: flex;
  align-items: center;
  margin-top: 10px;
  gap: 20px;
}

@media screen and (max-width: 768px) {
  [data-hero-with-text] .banner-review-link {
    gap: 10px;
  }
}

[data-hero-with-text] .logoimg {
  height: 55px !important;
}

@media screen and (max-width: 768px) {
  [data-hero-with-text] .logoimg {
    height: 40px !important;
  }

  [data-hero-with-text] .stardiv div svg {
    width: 15px !important;
    height: auto !important;
  }
}

@media screen and (max-width: 420px) {
  [data-hero-with-text] .rating_text {
    font-size: 18px !important;
  }

  [data-hero-with-text] .hero-image-2 {
    aspect-ratio: 16/11 !important;
  }
}

@media screen and (max-width: 375px) {
  [data-hero-with-text] .banner-title {
    font-size: 14px !important;
  }

  [data-hero-with-text] .logoimg {
    height: 25px !important;
  }

  [data-hero-with-text] .banner-review-link {
    display: flex;
    flex-direction: column;
    width: 100%;
  }

  [data-hero-with-text] .banner-review-link > *:first-child {
    align-self: flex-start !important;
  }

  [data-hero-with-text] .banner-review-link > *:nth-child(2) {
    align-self: flex-end !important;
  }
}

@media screen and (max-width: 365px) {
  [data-hero-with-text] .hero-image-2 {
    aspect-ratio: 16/13 !important;
  }
}

@media screen and (max-width: 311px) {
  [data-hero-with-text] .banner-title {
    font-size: 15px !important;
  }
}

@media screen and (max-width: 300px) {
  [data-hero-with-text] .hero-image-2 {
    aspect-ratio: 16/16 !important;
  }
}