@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: white;
}

.hm-banner-block-heading {
  text-align: left;
  text-shadow: 1px 2px 4px #000000;
  font-weight: bolder;
  color: yellow;
  font-size: clamp(2rem, 2vw + 1.5rem, 2.5rem);
}

.hm-banner-block-content {
  position: absolute;
  align-self: center;
  text-align: left;
  text-shadow: 1px 2px 4px #000000;
  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 - 65px - 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: #e3e3e3;
  background: linear-gradient(180deg, rgb(227, 227, 227) 0%, rgb(255, 255, 255) 50%, rgb(227, 227, 227) 100%);
}

.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;
}

/*#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-max-height {
  max-height: 70vh;
}

.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; /* Blue */
}

/*#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; /* light neutral border */
  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; /* your desired top padding */
  }
  .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;
  }
}
/*#endregion*/
/*#region ERROR NOT FOUND*/
.error-title-style {
  font-size: 30vh;
}

.error-content {
  opacity: 0.4;
}

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

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

.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: 35px;
}

.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.87rem;
  font-weight: normal;
}

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

.footer-card-content {
  color: #7f7f7f;
  font-size: 0.9rem;
  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: #aaa !important; /* dim text color */
  opacity: 0.6;
}

/*# sourceMappingURL=app.e7e46f8d.css.map*/