@import url(https://fonts.googleapis.com/css2?family=Roboto:wght@400&display=swap);
/*#region BANNER */
.hm-banner-block {
  position: relative;
  display: flex;
  text-align: center;
  color: #57616f;
  font-weight: 400;
}

.hm-banner-block-heading {
  text-align: left;
  font-weight: 600;
  color: #102a43;
  font-size: clamp(2rem, 2vw + 1.5rem, 2.5rem);
}

.hm-banner-heading-highlight {
  color: #b23850;
}

.hm-banner-block-content {
  position: absolute;
  align-self: center;
  text-align: left;
  width: 47%;
  padding-left: 5vw;
}

.hm-banner-block-button {
  font-size: clamp(1rem, 1vw + 0.5rem, 1.5rem); /* scales with screen size */
  padding: clamp(0.5rem, 0.8vw, 1rem) clamp(1rem, 2vw, 2rem); /* vertical & horizontal */
}

.hm-banner-block-content-text {
  font-size: clamp(1.25rem, 1vw + 1rem, 1.7rem);
}

.hm-banner-block-min-height {
  min-height: calc(100vh - 54px - 35px);
}

.page-banner-block {
  position: relative;
  display: flex;
  text-align: center;
  color: white;
}

.page-banner-block-heading {
  text-align: left;
  text-shadow: 2px 3px 3px #000000;
  font-weight: bolder;
  color: white;
  font-size: clamp(1.2rem, 5vw, 3.75rem);
}

.page-banner-block-content {
  position: absolute;
  align-self: end;
  text-align: left;
  text-shadow: 1px 2px 2px #000000;
  padding-left: 4vw;
  padding-bottom: 45px;
}

/*#endregion*/
/*#region HOMEPAGE SECTIONS*/
.section-bg-grey {
  background: #e6e8ee;
  background: linear-gradient(140deg, rgb(230, 232, 238) 0%, rgb(235, 237, 241) 70%);
}

.section-margin-left {
  margin-left: 3vw;
}

.section-img-fullheight {
  height: 100%;
}

/*#endregion*/
/*#region IMAGE FADING*/
.fade-right {
  position: relative;
  display: inline-block;
  width: 100%;
  /* Fade out from full opacity to transparent on the right */
  mask-image: linear-gradient(to right, black 60%, transparent 100%);
  mask-repeat: no-repeat;
  mask-size: 100% 100%;
}

.fade-bottom {
  display: block;
  width: 100%;
  height: auto;
  /* Apply fading mask */
  mask-image: linear-gradient(to bottom, black 70%, transparent 100%);
  mask-size: 100% 100%;
  mask-repeat: no-repeat;
}

/*#endregion*/
/*#region FORM FIELDS */
.form-required-asterisk {
  color: red;
  font-weight: 400;
}

.form-label-color {
  color: #0d47a1;
}

.form-max-width {
  max-width: 400px;
}

.form-label {
  font-size: clamp(1rem, 1.5vw, 1.125rem);
  color: #01579b;
}

.form-header {
  font-size: clamp(1rem, 5vw, 1.25rem);
  color: #01579b;
}

.form-sub-header {
  font-size: 1rem;
}

.form-content {
  font-size: clamp(1rem, 1.5vw, 1.125rem);
  color: #4a4a4a;
}

.form-content-small {
  font-size: clamp(0.8rem, 1.5vw, 0.9rem);
}

.form-button {
  font-size: clamp(0.75rem, 0.6vw + 0.4rem, 1rem);
  padding: clamp(0.2rem, 0.4vw, 0.3rem) clamp(1rem, 2.5vw, 1.5rem);
  min-width: 110px;
}

.form-input-content {
  font-size: 0.9rem;
  color: #4a4a4a;
}

/*#endregion */
/*#region CONTACT US */
.contact-iconstyle {
  font-size: 24px;
  padding-right: 5px;
  margin-top: 4px;
}

.contact-title {
  color: #01579b;
  font-size: 1.5rem;
}

.contact-section-title {
  font-size: 1.2rem;
  font-weight: 500;
  color: #01579b;
  text-transform: uppercase;
  margin-bottom: 12px;
}

.contact-content {
  font-size: 1rem;
}

.contact-info-row {
  display: flex;
  align-items: flex-start; /* important */
}

.contact-info-content .label {
  font-size: 1.1rem;
  font-weight: 600;
  color: #6b7280;
}

.contact-info-content .value {
  font-size: 1rem;
  color: #4a4a4a;
  margin-top: 2px;
  line-height: 1.5;
}

.link {
  color: #1d4ed8; /* blue instead of red for enterprise */
  text-decoration: none;
}

/*#endregion */
/*#region CARD */
.card-border-color {
  border: 1px solid #b8b8b8;
}

.rounded-card {
  border-radius: 10px;
}

.card-title {
  color: #b23850;
  font-size: clamp(1rem, 1.5vw, 1.2rem);
  font-weight: 500;
}

.card-subtitle {
  color: #784b4a;
  font-size: 1rem;
  font-weight: 500;
}

.card-description {
  font-size: 1rem;
  color: #4a4a4a;
}

.card-selected {
  background-color: #e1f5fe;
}

.card-disabled {
  background-color: #a9a9a9;
  color: #848484;
}

.summary-card {
  max-width: 500px;
  width: 100%;
  border-radius: 12px;
}

.meeting-card {
  width: 220px;
  text-align: center;
}

.qrpayment-card {
  width: 350px;
  text-align: center;
}

.dialog-card {
  width: 700px !important;
  max-width: 80vw !important;
}

.dialog-card-wide {
  width: 960px !important;
  max-width: 80vw !important;
  border-radius: 10px !important;
}

.dialog-max-height {
  max-height: 70vh;
}

.dialog-header {
  background: linear-gradient(135deg, #455a64, #607d8b);
  padding: 8px 12px;
}

.disabled-card {
  pointer-events: none;
  opacity: 0.5;
}

/*#endregion*/
/*#region SERVICE CARD*/
.service-card-min-height {
  min-height: 12vh;
}

.service-card-rate {
  color: #1e48a3;
  font-size: clamp(1rem, 1.5vw, 1.125rem);
  font-weight: 500;
}

.service-timeslot-selected {
  font-size: 1rem;
  color: #000000;
  background-color: #e1f5fe;
}

.service-timeslot-unselected {
  font-size: 1rem;
  background-color: #ffffff;
}

/*#endregion*/
/*#region Q-TABLE*/
.qtable-header {
  font-size: 1rem !important;
  color: #1e48a3 !important;
  background-color: #cfd8dc !important;
}

/* Body cells */
.q-table tbody tr td {
  font-size: 0.87rem;
}

.elevated-table {
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
}

/*#endregion*/
/*#region DASHBOARD */
.dashboard-banner-title {
  font-size: 1.5rem;
}

.dashboard-header {
  font-size: 1.25rem;
  font-weight: 400;
  letter-spacing: 0.0125em;
}

.dashboard-card-title {
  font-size: clamp(1rem, 1.5vw, 1.2rem);
  font-weight: 400;
  color: #686868;
}

.dashboard-card-content {
  font-size: clamp(0.95rem, 1.5vw, 1.1rem);
  color: #01579b;
}

.dashboard-card {
  border-radius: 10px;
  position: relative;
  overflow: hidden;
}

.dashboard-card::before {
  content: "";
  display: block;
  height: 6px;
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
}

.dashboard-topline::before {
  background-color: #01579b;
}

.dashboard-active-appt-card {
  width: 50vw;
  border-radius: 10px;
  position: relative;
  overflow: hidden;
}

.dashbord-active-appt-info-label {
  font-size: 14px;
  font-weight: 400;
  color: #686868;
  margin-bottom: 4px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.dashbord-active-appt-info-value {
  font-size: 15px;
  font-weight: 600;
  color: #111827;
}

.dashbord-active-appt-action-btn {
  background-color: #ec7a00;
  height: 40px;
  border-radius: 10px;
}

.dashbord-active-appt-active-avatar {
  background-color: #018e9b;
}

.dashbord-active-appt-active-label {
  color: #01808b;
  font-size: 1.25rem;
  font-weight: 400;
  letter-spacing: 0.0125em;
}

/*#endregion*/
/*#region TAB */
.tab-incactive {
  color: #696b70;
  background-color: #ffffff;
}

.tab-first-style {
  border-top: 1px solid #cccccc;
  border-left: 1px solid #cccccc;
  border-right: 1px solid #cccccc;
  background-color: #efefef;
  border-radius: 10px 10px 0px 0px;
}

.tab-style {
  border-top: 1px solid #cccccc;
  border-right: 1px solid #cccccc;
  background-color: #efefef;
  border-radius: 10px 10px 0px 0px;
}

.tab-last-style {
  border-top: 1px solid #cccccc;
  border-right: 1px solid #cccccc;
  background-color: #efefef;
  border-radius: 10px 10px 0px 0px;
}

.tabpanel-border {
  border-top: 1px solid #cccccc;
  border-bottom: 1px solid #cccccc;
  border-left: 1px solid #cccccc;
  border-right: 1px solid #cccccc;
  border-radius: 0px 10px 10px 10px;
}

/*#endregion*/
/*#region GENERAL */
.pagewidth {
  margin-left: 4vw;
  margin-right: 4vw;
}

.page-heading {
  line-height: 1.6;
  color: #b23850;
  font-size: clamp(1.2rem, 2vw, 2rem);
}

.page-sub-heading {
  line-height: 1.6;
  color: #783333;
  font-size: clamp(0.9rem, 1.4vw, 1.2rem);
}

.page-content {
  font-size: clamp(1rem, 1.5vw, 1.125rem);
  line-height: 1.6;
  color: #4a4a4a;
}

.page-content-button {
  font-size: clamp(0.875rem, 0.7vw + 0.5rem, 1.125rem); /* slightly smaller than content */
  padding: clamp(0.25rem, 0.5vw, 0.5rem) clamp(0.75rem, 1.5vw, 1.25rem);
}

.pagewidth-admin {
  margin-left: 2vw;
  margin-right: 2vw;
}

.staff-title-banner-padding {
  padding-left: 1.5vw;
}

.staff-logout-bar-margin {
  margin-right: 1.5vw;
}

.logo-margin {
  margin-left: 1.5vw;
}

.banner-header {
  font-size: clamp(1rem, 5vw, 1.15rem);
  padding-top: 3px;
  padding-bottom: 3px;
  margin-left: 1.5vw;
}

.text-underline {
  text-decoration: underline;
}

a {
  text-decoration: none;
  color: #0d47a1;
}

a:link {
  text-decoration: none;
}

a:visited {
  text-decoration: none;
}

a:hover {
  text-decoration: none;
}

a:active {
  text-decoration: none;
}

.round-corners {
  border-radius: 20px;
}

.q-stepper__title {
  font-size: clamp(0.85rem, 1.5vw, 0.95rem) !important;
}

.top-align-checkbox .q-checkbox__inner {
  align-self: flex-start;
}

.loading-overlay {
  background-color: rgba(0, 0, 0, 0.7);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  transition: background-color 0.3s ease;
}

.max-width-fit-content {
  max-width: -moz-fit-content;
  max-width: fit-content;
}

.width-450px {
  width: 450px;
}

.width-250px {
  width: 250px;
}

.hidden {
  display: none;
}

.full-width {
  width: 100%;
}

.dialog-question {
  font-size: 1rem;
  color: #042b64;
}

.dialog-label-textcolor {
  color: #042b64;
}

.tooltip {
  font-size: 12px;
}

.no-break-hyphen {
  white-space: nowrap;
}

/*#endregion*/
/*#region TERMS OF USE */
#terms li {
  margin: 15px 0;
}

.terms-content {
  line-height: 2rem;
  text-align: justify;
}

/*#endregion*/
/*#region HOME PAGE */
#homepage ol li {
  padding-left: 10px;
}

#homepage ul {
  list-style-type: disc;
}

#homepage ol > li {
  margin-top: 0.6rem;
}

#homepage ol ul {
  margin-top: 0;
  padding-top: 0;
}

.pricing-table {
  width: 80%;
  border-collapse: separate;
  border-spacing: 0;
  border: 1px solid #dddddd;
  border-radius: 8px;
  overflow: hidden;
}

.pricing-table thead th {
  background: #d3e3fd;
  color: #1e48a3;
  font-weight: 500;
  padding: 8px 12px;
  border-bottom: 1px solid #dddddd;
  text-align: left;
}

.pricing-table td {
  padding: 8px 12px;
  border-bottom: 1px solid #dddddd;
  color: #444;
}

.pricing-table tr:last-child td {
  border-bottom: none; /* remove last border */
}

.pricing-table .fee {
  text-align: center;
}

.pricing-table .service-hours {
  vertical-align: middle;
  border-left: 1px solid #dddddd;
  text-align: left;
  border-bottom: none;
}

/*#endregion*/
/*#region FOR MOBILE */
@media (max-width: 1023px) {
  .mobile-bottom-padding {
    padding-bottom: 10px;
  }
  .hm-banner-block-content {
    width: 85%;
    padding-left: 10vw;
    padding-bottom: 25vw;
  }
  .mobile-hide {
    display: none;
  }
  .mobile-top-padding {
    padding-top: 20px;
  }
  .pagewidth {
    margin-left: 0vw;
    margin-right: 0vw;
  }
  .mobile-side-padding {
    padding-left: 16px;
    padding-right: 16px;
  }
  .mobile-right-padding {
    padding-right: 16px;
  }
  .service-card-min-height {
    min-height: 8vh;
  }
  .dashboard-active-appt-card {
    width: 100vw;
    border-radius: 10px;
    position: relative;
    overflow: hidden;
  }
}
/*#endregion*/
/*#region ERROR NOT FOUND*/
.error-title-style {
  font-size: 30vh;
}

.error-content {
  opacity: 0.4;
}

/*#endregion*/
/*#region TIME EXTENSION CARD*/
.time-extension-info-card {
  background: #f8fafc;
  border-radius: 15px;
  padding: 20px;
}

.time-extension-time-option {
  border-radius: 15px;
  border: 2px solid #b8b8b8;
}

.time-extension-selected-card {
  border: 2px solid var(--q-primary);
  background: rgba(25, 118, 210, 0.05);
  box-shadow: 0 8px 20px rgba(25, 118, 210, 0.15);
}

/*#endregion*/
.main-portalName {
  font-size: 1.3rem;
  color: #b71c1c;
  text-transform: uppercase;
}

.menu-section-height {
  min-height: 54px;
}

.copyright {
  color: white;
  text-decoration: none;
}

.copyright-alignment {
  text-align: left;
}

.privacy-terms-alignment {
  text-align: right;
}

.snef-logo-width {
  width: 200px !important;
}

.snef-logo-height {
  max-height: 32px;
}

.q-tab__label {
  font-size: 1rem;
}

#hamburgermenu .q-item__section--avatar {
  min-width: 10px !important;
}

#menu-tab.q-tabs .q-tab__label {
  font-size: 1.05rem;
}

#menu-tab.q-tabs .q-tab__indicator {
  height: 4px !important; /* Adjust the value to your desired thickness */
}

#menu-tab.q-tabs .q-focus-helper {
  visibility: hidden;
}

.footer {
  background-color: #484743;
  padding: 1px 0px;
}

.footer-font {
  font-size: 0.8rem;
  font-weight: normal;
}

.footer-card-title {
  color: #b80048;
  font-size: 1rem;
  font-weight: bold;
  text-align: center;
  padding-top: 25px;
}

.footer-card-content {
  color: #7f7f7f;
  font-size: 0.8rem;
  text-align: justify;
}

.footer-card {
  padding-left: 10px;
  padding-right: 10px;
}

@media (max-width: 1025px) {
  .copyright-alignment {
    text-align: center;
  }
  .privacy-terms-alignment {
    text-align: center;
  }
}
/* Month title */
.fc .fc-toolbar-title {
  color: #1e48a3;
  font-weight: 400;
}

/* Prev/Next buttons */
.fc .fc-button {
  background-color: #1e48a3;
  color: white;
  border: none;
  border-radius: 4px;
}

/* Button hover effect */
.fc .fc-button:hover {
  background-color: #2f60ad;
}

.fc-button:focus {
  box-shadow: none !important;
}

/* Remove bottom margin of the header toolbar */
.fc .fc-header-toolbar {
  margin-bottom: 4px !important; /* default is ~1.5em, reduce it */
  padding-bottom: 0 !important;
}

/* Tighten overall calendar padding */
.fc .fc-view-harness {
  padding: 0 !important;
}

/* Calendar day numbers */
.fc .fc-daygrid-day-number {
  color: inherit !important; /* inherit text color */
}

/* Weekday headers (Mon, Tue, etc.) */
.fc .fc-col-header-cell-cushion {
  color: inherit !important;
  font-weight: 400;
}

/* General body text inside cells */
.fc .fc-daygrid-day {
  color: inherit !important;
}

.fc-event {
  cursor: pointer;
  padding-left: 5px;
}

.repeat-icon {
  margin-right: 4px;
  vertical-align: middle;
  font-size: 16px;
}

.fc-day-past {
  background-color: #f2f2f2 !important; /* light gray background */
  color: #999999 !important; /* dim text color */
  opacity: 0.7;
}

.fc-bg-event {
  filter: brightness(0.95);
}

.fc .fc-daygrid-day {
  border: 1px solid #d2d2d2 !important;
}
.rpt-export-btn {
  margin-left: auto;
  margin-right: 0;
}

.rpt-table-wrapper {
  overflow-x: auto;
}

.q-table thead th {
  position: sticky;
  top: 0;
  background: white;
  z-index: 3;
}

.q-table tbody td.sticky-col {
  position: sticky;
  background: white;
  z-index: 2;
}

.q-table thead th.sticky-col {
  position: sticky;
  top: 0;
  background: white;
  z-index: 4;
}

.col-1 {
  left: 0px;
  min-width: 145px;
}

.col-2 {
  left: 145px;
  min-width: 165px;
}

.col-3 {
  left: 310px;
  min-width: 165px;
}

.col-4 {
  left: 475px;
  min-width: 100px;
}

.col-5 {
  left: 575px;
  min-width: 120px;
}

.col-6 {
  left: 695px;
  min-width: 120px;
  box-shadow: 1px 0 1px rgba(0, 0, 0, 0.1);
}

.summary-clamp {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: normal;
}

.summary-tooltip {
  font-size: 14px;
  line-height: 1.6;
  padding: 12px;
  max-width: 500px;
}

.tooltip-content {
  white-space: pre-wrap;
}

.column-wrap {
  white-space: normal !important;
  word-break: break-word;
  overflow-wrap: anywhere;
}

.column-content {
  white-space: normal;
  word-break: break-word;
}

.content-align-top {
  vertical-align: top !important;
}

@media (max-width: 1023px) {
  .sticky-col {
    position: static !important;
    left: auto !important;
  }
}
/*#region QR PAYMENT*/
.payment-container {
  display: flex;
  justify-content: center;
}

.payment-card {
  width: 900px;
  border-radius: 14px;
  overflow: hidden;
}

.reference-box {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: #f5f5f5;
  border-radius: 8px;
  padding: 10px 14px;
  font-weight: 600;
  letter-spacing: 1px;
}

.qr-section {
  border-left: 1px solid #eee;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding-left: 40px;
  padding-right: 40px;
}

.qr-image-width {
  width: 100%;
  max-width: 280px;
}

.confirm-btn {
  margin-top: 20px;
  width: 100%;
}

/*#endregion*/
/*#region PAYMENT VERIFICATION*/
.pv-banner {
  background: #494aea;
  color: white;
  padding: 0px;
  border-radius: 12px 12px 0 0;
  font-weight: 600;
  font-size: 1.2rem;
  text-align: center;
}

.pv-container {
  max-width: 720px;
  margin: auto;
  padding: 30px 20px;
}

.pv-card-border-radius {
  border-radius: 0 0 12px 12px;
}

.pv-amount-card {
  background: #eef2ff;
  border-radius: 16px;
  padding: 20px;
  text-align: center;
}

.pv-amount-value {
  font-size: 1.2rem;
  font-weight: 700;
  color: #1e293b;
  margin-bottom: 6px;
}

.pv-amount-label {
  font-size: 0.8rem;
  color: #4b5563;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.pv-section-title {
  font-size: 1rem;
  font-weight: 500;
  columns: #000000;
}

.pv-section-content {
  font-size: 0.9rem;
  color: #263238;
}

.pv-button {
  background: #4f46e5;
  color: white;
  padding: 8px 18px;
  border-radius: 8px;
  font-size: 0.9rem;
}

/*#endregion*/

/*# sourceMappingURL=app.54cbaa5d.css.map*/