body {
  display: flex;
  flex-direction: column;
  max-width: 100vw;
  min-height: 100vh;
  font-family: "Helvetica Neue", sans-serif;
  font-size: 1.075rem;
  color: #838383;
  background-color: white;
}

html[lang="ar"] body,
[lang="ar"] {
  font-family: "Tajawal", sans-serif;
}

[lang="ar"] {
  direction: rtl;
}

[lang="en"] {
  font-family: "Helvetica Neue", sans-serif;
  direction: ltr;
}

a:focus-visible {
  border: none;
  outline: none;
  box-shadow: none;
}

body.blocked {
  pointer-events: none;
  user-select: none;
}

.icofont,
.mdi {
  font-size: 1.25em;
}

.icofont {
  display: inline-block;
  line-height: normal;
  transform: translateY(1px);
}

[lang="ar"] .icofont {
  transform: translateY(2px);
}

header {
  position: sticky;
  top: -0.01px;
  background-color: #d8f0fd;
  z-index: 5;
  transition: background-color 0.2s linear;
}

header:has(.main-menu) {
  box-shadow: 0 0 1rem gainsboro;
}

header.stuck {
  background-color: transparent;
}

.topbar,
.topbar-info {
  display: flex;
  align-items: center;
}

.topbar {
  --blur: 1rem;
  position: relative;
  padding: 0.5rem 2rem;
  background-color: #d8f0fd80;
  font-size: 1rem;
  backdrop-filter: blur(var(--blur));
  -webkit-backdrop-filter: blur(var(--blur));
}

.topbar button[name="toggleTopBar"] {
  display: none;
  margin-inline-end: 2rem;
  padding: 0;
}

.topbar p {
  display: flex;
  align-items: baseline;
  margin-bottom: 0;
  margin-inline-end: 4rem;
  text-align: center;
}

header:has(.main-menu) .topbar p {
  color: #000a88;
}

.topbar p:last-child {
  margin-inline-end: 0;
}

.topbar p > span {
  display: flex;
  align-items: center;
}

.topbar p > span:not(:last-child) {
  margin-inline-end: 1rem;
}

.topbar p .icon .hollow {
  color: #3fae2a;
}

.topbar span span:not(:last-child) {
  padding-inline-end: 0.5rem;
}

.topbar .far-half {
  display: flex;
  align-items: center;
  margin-inline-start: auto;
}

.topbar .far-half > :not(:last-child) {
  margin-inline-end: 3rem;
}

.topbar .profile button,
.topbar button[name="lang"] {
  border-radius: 0;
}

.topbar .profile button {
  padding: 0.3rem;
}

.bidi {
  unicode-bidi: bidi-override;
}

.navbar {
  --bs-navbar-padding-x: 2rem;
  --bs-navbar-padding-y: 1rem;
  --bs-navbar-color: white;
  --bs-navbar-hover-color: gainsboro;
  --bs-navbar-disabled-color: #ffffff99;
  --bs-navbar-active-color: gainsboro;
  --bs-navbar-brand-padding-y: 0;
  --bs-navbar-brand-margin-end: 3rem;
  --bs-navbar-nav-link-padding-x: 0.5rem;
  background-color: #000a88;
}

.navbar::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  background-image: url("../Images/leaf.png");
  background-repeat: no-repeat;
  background-position-x: 100%;
  background-position-y: 50%;
  background-size: 25%;
  opacity: 0.8;
}

[lang="ar"] .navbar::after {
  background-position-x: 0;
}

.navbar .container-fluid,
.navbar .navbar-collapse,
.navbar .navbar-nav .nav-item {
  align-items: stretch;
}

.navbar .container-fluid {
  z-index: 10;
}

.navbar .navbar-brand {
  display: flex;
  align-items: center;
  justify-content: center;
}

.navbar .navbar-brand img {
  height: 4rem;
}

.navbar .navbar-nav {
  flex-wrap: wrap;
  justify-content: center;
}

.navbar .navbar-nav li {
  margin-bottom: 0;
  font-weight: 500;
}

.navbar .navbar-nav li::before {
  display: none;
}

.navbar-toggler {
  padding: 0.5rem !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

.navbar .navbar-nav .nav-item {
  display: flex;
  flex: 0 0 auto;
  padding: 0.65rem 0;
}

.navbar .navbar-nav .nav-item:not(:last-child) {
  margin-inline-end: 0.5rem;
}

.navbar .navbar-nav .nav-item:not(:first-child) {
  margin-inline-start: 0.5rem;
}

.navbar .navbar-nav .nav-item .nav-link {
  display: flex;
  align-items: center;
  padding: 0;
  box-shadow: none;
  transition: color 0.2s linear;
}

.navbar .navbar-nav .nav-item:hover .nav-link {
  color: gainsboro;
}

.navbar .navbar-nav .nav-item .nav-link span {
  position: relative;
  display: flex;
  align-items: center;
  padding: 0.5rem var(--bs-navbar-nav-link-padding-x);
}

.navbar .navbar-nav .nav-item .nav-link span::after {
  content: "";
  position: absolute;
  bottom: -3px;
  left: 0;
  width: 0;
  border-bottom: 3px solid #95d600;
  transition: width 0.2s linear;
}

[lang="ar"] .navbar .navbar-nav .nav-item .nav-link span::after {
  left: auto;
  right: 0;
}

.navbar .navbar-nav .nav-item.current-page .nav-link span::after,
.navbar .navbar-nav .nav-item:hover .nav-link span::after {
  width: 100%;
}

.navbar .navbar-nav .nav-item.current-page .nav-link {
  color: white;
  pointer-events: none;
}

.navbar .dropdown-menu {
  margin-top: -1px;
}

[lang="ar"] .dropdown-menu {
  left: auto;
  right: 0;
}

.dropdown-menu {
  text-align: inherit;
  --bs-dropdown-border-color: #3fae2a;
  --bs-dropdown-link-hover-bg: #f3f5f9;
  --bs-dropdown-link-active-bg: #f3f5f9;
  --bs-dropdown-link-color: #838383;
  --bs-dropdown-link-hover-color: #838383;
  --bs-dropdown-link-active-color: #3fae2a;
  --bs-dropdown-link-disabled-color: gainsboro;
  --bs-dropdown-divider-bg: gainsboro;
}

.settings .dropdown-menu li,
.dropdown .dropdown-menu li {
  margin-bottom: 0;
}

.dropdown-menu li::before {
  display: none;
}

.dropdown-menu li:not(:first-child):not(.divider):not(.divider + li) {
  margin-top: 0.5rem;
}

.dropdown-menu .dropdown-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  transition:
    background-color 0.2s linear,
    color 0.2s linear;
}

.dropdown-menu .current-page {
  color: #3fae2a !important;
  font-weight: 500;
  pointer-events: none;
}

.dropdown-menu .logout-item {
  display: flex;
  align-items: center;
}

.dropdown-menu .logout-item .spinner-border {
  display: none;
  margin-inline-start: auto;
}

.topbar .logged-in-user {
  display: flex;
  align-items: center;
}

.topbar .logged-in-user span:first-child {
  margin-inline-end: 0.5rem;
}

.topbar button[name="user"] {
  display: none;
  margin-bottom: 0 !important;
  padding: 0.25rem 1rem;
}

.user-popover.popover {
  border-color: #838383;
  --bs-popover-arrow-border: #838383;
}

.user-popover.popover .popover-body,
.user-popover.popover .popover-body .logged-in-user {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.user-popover.popover .popover-body {
  color: #838383;
}

.topbar button[name="lang"] {
  padding: 0;
  font-weight: bold;
}

.topbar button[name="lang"] .lang-icon {
  display: none;
}

.page-content {
  --bs-gutter-x: 0;
  flex: 1 0 auto;
}

.page-content:not(:has(> .sidebar)):has(> .message-container) {
  background-image: linear-gradient(transparent, #f3f5f9, transparent);
}

textarea {
  resize: none;
}

input[type="tel"] {
  appearance: textfield;
}

[lang="ar"] input[type="tel"] {
  direction: rtl;
}

input[type="tel"]::-webkit-outer-spin-button,
input[type="tel"]::-webkit-inner-spin-button {
  appearance: none;
  margin: 0;
}

.form-control,
.form-select,
.input-group-text {
  font-size: inherit;
}

.form-floating > textarea.form-control {
  height: 8rem;
}

.form-floating > textarea.form-control,
.form-floating > textarea.form-control:focus,
.form-floating > textarea.form-control:not(:placeholder-shown) {
  padding: 0 0.75rem;
}

.form-check {
  display: flex;
  align-items: center;
  margin-bottom: 0;
  padding-left: 0;
}

.form-check .form-check-input {
  flex-shrink: 0;
  margin-inline-end: 1rem !important;
  margin-top: 0;
  margin-left: 0;
}

.form-check-input:checked {
  background-color: #00833e;
  border-color: #00833e;
}

.form-check-input:focus {
  border-color: #3fae2a;
  box-shadow: 0 0 0 0.25rem rgba(63, 174, 42, 0.25);
}

.form-switch .form-check-input:focus {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='%2300833e80'/%3e%3c/svg%3e");
}

.form-switch .form-check-input:checked {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='%23ffffff'/%3e%3c/svg%3e");
}

.link-mgc {
  text-decoration: none;
  font-weight: bold;
}

.btn-mgc {
  display: flex;
  align-items: center;
  justify-content: center;
  border: none;
  outline: none;
  background-color: #3fae2a;
  color: white;
  padding: 0.35rem 2rem;
  border-radius: 10rem;
  font-weight: 500;
  font-size: 1.05em;
  text-decoration: none;
  transition: background-color 0.2s linear;
}

.btn-mgc:hover {
  background-color: #95d600;
  color: white;
}

.btn-mgc:active {
  background-color: #00833e;
  color: white;
}

.btn-mgc:disabled,
.btn-mgc.disabled {
  opacity: 0.6;
  pointer-events: none;
}

.btn-mgc.placeholder:disabled,
.btn-mgc.placeholder.disabled {
  color: transparent;
}

.btn-mgc-light {
  background-color: #95d600;
}

.btn-mgc-light:hover {
  background-color: #c4d600;
}

.btn-mgc-light:active {
  background-color: #3fae2a;
}

.btn-mgc-yellow {
  background-color: #c4d600;
}

.btn-mgc-yellow:hover {
  background-color: #e0e67e;
}

.btn-mgc-yellow:active {
  background-color: #95d600;
}

.btn-mgc-blue {
  background-color: #000a88;
}

.btn-mgc-blue:hover {
  background-color: #5258a6;
}

.btn-mgc-blue:active {
  background-color: #1a206f;
}

.btn-mgc-dark {
  background-color: #00833e;
}

.btn-mgc-dark:hover {
  background-color: #3fae2a;
}

.btn-mgc-dark:active {
  background-color: #093b20;
}

.btn-mgc-white {
  background-color: white;
}

.btn-mgc-white:not(.backgroundless) {
  color: #838383 !important;
}

.btn-mgc-white:hover {
  background-color: gainsboro;
}

.btn-mgc-white:active {
  background-color: silver;
}

.link-mgc,
.btn-mgc.backgroundless,
.btn-mgc .i .hollow {
  background: none;
  color: #3fae2a;
  transition: color 0.2s linear;
}

.link-mgc:hover,
.btn-mgc.backgroundless:hover,
.btn-mgc:hover .i .hollow {
  color: #95d600;
}

.link-mgc:active,
.btn-mgc.backgroundless:active,
.btn-mgc:active .i .hollow {
  color: #00833e;
}

.link-mgc.link-mgc-light,
.btn-mgc.backgroundless.btn-mgc-light,
.btn-mgc-light .i .hollow {
  color: #95d600;
}

.link-mgc.link-mgc-light:hover,
.btn-mgc.backgroundless.btn-mgc-light:hover,
.btn-mgc-light:hover .i .hollow {
  color: #c4d600;
}

.link-mgc.link-mgc-light:active,
.btn-mgc.backgroundless.btn-mgc-light:active,
.btn-mgc-light:active .i .hollow {
  color: #3fae2a;
}

.link-mgc.link-mgc-yellow,
.btn-mgc.backgroundless.btn-mgc-yellow,
.btn-mgc-yellow .i .hollow {
  color: #c4d600;
}

.link-mgc.link-mgc-yellow:hover,
.btn-mgc.backgroundless.btn-mgc-yellow:hover,
.btn-mgc-yellow:hover .i .hollow {
  color: #e0e67e;
}

.link-mgc.link-mgc-yellow:active,
.btn-mgc.backgroundless.btn-mgc-yellow:active,
.btn-mgc-yellow:active .i .hollow {
  color: #95d600;
}

.link-mgc.link-mgc-blue,
.btn-mgc.backgroundless.btn-mgc-blue,
.btn-mgc-blue .i .hollow {
  color: #000a88;
}

.link-mgc.link-mgc-blue:hover,
.btn-mgc.backgroundless.btn-mgc-blue:hover,
.btn-mgc-blue:hover .i .hollow {
  color: #6f73ad;
}

.link-mgc.link-mgc-blue:active,
.btn-mgc.backgroundless.btn-mgc-blue:active,
.btn-mgc-blue:active .i .hollow {
  color: #1b1e50;
}

.link-mgc.link-mgc-dark,
.btn-mgc.backgroundless.btn-mgc-dark,
.btn-mgc-dark .i .hollow {
  color: #00833e;
}

.link-mgc.link-mgc-dark:hover,
.btn-mgc.backgroundless.btn-mgc-dark:hover,
.btn-mgc-dark:hover .i .hollow {
  color: #3fae2a;
}

.link-mgc.link-mgc-dark:active,
.btn-mgc.backgroundless.btn-mgc-dark:active,
.btn-mgc-dark:active .i .hollow {
  color: #093b20;
}

.link-mgc.link-mgc-white,
.btn-mgc.backgroundless.btn-mgc-white,
.btn-mgc-white .i .hollow {
  color: white;
}

.link-mgc.link-mgc-white:hover,
.btn-mgc.backgroundless.btn-mgc-white:hover,
.btn-mgc-white:hover .i .hollow {
  color: gainsboro;
}

.link-mgc.link-mgc-white:active,
.btn-mgc.backgroundless.btn-mgc-white:active,
.btn-mgc-white:active .i .hollow {
  color: silver;
}

.btn-mgc.backgroundless .i .hollow {
  color: white;
}

.btn-mgc.circle {
  aspect-ratio: 1/1;
  border-radius: 100%;
}

.btn-mgc span {
  flex: 0 0 auto;
}

.btn-mgc .spinner-border {
  margin-inline-start: 1rem;
  display: none;
}

.btn-mgc.icon-btn .spinner-border {
  margin-inline-start: 0;
}

.spinner-border-sm {
  --bs-spinner-border-width: 0.25rem;
}

.form-check .btn-mgc {
  align-self: center;
  height: 3rem;
}

.modal {
  --bs-modal-header-padding: 1rem 2.5rem;
  --bs-modal-padding: 2.5rem;
  --bs-modal-border-radius: 2rem;
  --bs-modal-header-border-color: gainsboro;
  --bs-modal-width: 35rem;
  --bs-modal-color: #838383;
}

.modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.modal .modal-header:has(button[name="close"]:only-child) {
  justify-content: end;
  border-bottom: none;
}

.modal-header .modal-title {
  color: #00833e;
  font-weight: bold;
  font-size: 1.75rem;
}

.modal .modal-header button[name="close"] {
  flex-shrink: 0;
  width: 2.5rem;
  aspect-ratio: 1/1;
  margin-inline-start: 1rem;
  padding: 0;
  font-size: 1.75rem;
}

form .buttons {
  display: flex;
  align-items: center;
  justify-content: space-evenly;
  margin-top: 4rem;
}

form .buttons button,
form .buttons a {
  width: 100%;
}

form .buttons button:only-child,
form .buttons a:only-child {
  width: 50%;
}

form .buttons button:first-child,
form .buttons a:first-child {
  margin-inline-end: 0.5rem;
}

form .buttons button:last-child,
form .buttons a:last-child {
  margin-inline-start: 0.5rem;
}

form > .input-group:not(:last-child),
.select-group .select-row:not(:last-child),
.select-group:not(:last-child) .select-row:last-child {
  margin-bottom: 1.5rem;
}

.input-group {
  background-color: white;
  z-index: 0;
}

.input-group:has(.iti) {
  z-index: 1;
}

.input-group.is-invalid,
.input-group.date-group:has(.is-invalid),
.date-input-group .date-input.is-invalid {
  border: 2px solid #dc3545 !important;
}

.input-group.disabled {
  opacity: 0.5;
}

.input-group.parent > .input-group {
  position: relative;
  width: 100%;
  flex: 1 1 0%;
  min-width: 0;
  padding: 0;
}

[lang="ar"] .input-group > .input-group:first-child {
  border-top-right-radius: 10rem !important;
  border-bottom-right-radius: 10rem !important;
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}

[lang="ar"] .input-group > .input-group:last-child {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
  border-top-left-radius: 10rem !important;
  border-bottom-left-radius: 10rem !important;
}

.input-group > .input-group:first-child .form-control,
.input-group > .input-group:first-child .form-select,
.input-group > .input-group:first-child .input-group-text {
  padding-inline-start: 2rem;
}

.input-group > .input-group:last-child .form-control,
.input-group > .input-group:last-child .form-select,
.input-group > .input-group:last-child .input-group-text {
  padding-inline-end: 2rem;
}

.input-group.date-input input {
  text-align: center;
}

.input-group.file-input .form-floating,
.input-group.file-input .input-group-text {
  cursor: pointer;
}

.input-group.file-input.disabled .form-floating,
.input-group.file-input.disabled .input-group-text {
  cursor: default;
}

.input-group.file-input input[type="file"] {
  opacity: 0;
}

.input-group.file-input .form-floating::before,
.input-group.file-input .form-floating::after {
  z-index: 1;
}

.input-group.file-input label.input-group-text,
.input-group.date-group label.input-group-text {
  color: #3fae2a;
}

.input-group.file-input .file-btn {
  padding: 0.25rem 0.75rem;
}

.date-input-group,
.range-input-group {
  width: 100%;
}

.date-input-group:not(:last-child),
.range-input-group:not(:last-child) {
  margin-bottom: 2rem;
}

.date-input-group .date-input-label,
.range-input-group .range-input-label {
  color: #3fae2a;
  font-weight: bold;
}

.date-input-group .input,
.range-input-group .input {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  margin-inline-start: 1.5rem;
}

.date-input-group .input:not(:last-child),
.range-input-group .input:not(:last-child) {
  margin-bottom: 1rem;
}

.date-input-group .input label,
.range-input-group .input label {
  flex: 0 0 20%;
  color: #000a88;
  font-weight: 500;
}

.date-input-group .date-input,
.range-input-group .range-input {
  flex: 1 0 0%;
}

.date-input-group .date-input.is-invalid {
  border-radius: 10rem;
}

.select-group .select-row {
  display: flex;
  align-items: center;
}

.select-group .select-row .add-select {
  width: 2.5rem;
  margin-inline-start: 1rem;
  padding: 0;
  font-size: 1rem;
}

.form-check.is-invalid label {
  color: #dc3545;
}

.media-container {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  aspect-ratio: 16/9;
  background-color: #f3f5f9;
  border: 2px solid #3fae2a;
}

.edit-form .media-container:not(:has(+ .buttons)) {
  margin-bottom: 1.5rem;
}

.media-container video,
.media-container img,
.media-container .svg-wrapper {
  width: 100%;
  height: 100%;
}

.media-container img,
.media-container .svg-wrapper {
  padding: 1rem;
}

.media-container img[src=""],
.media-container img:not([src]) {
  opacity: 0;
}

.media-container video,
.media-container img {
  object-fit: scale-down;
}

.media-container .spinner-border {
  position: absolute;
  display: none;
  width: 4rem;
  height: 4rem;
  color: #3fae2a;
}

.media-container .svg-wrapper {
  color: #00833e;
}

.popover {
  --bs-popover-arrow-border: #dc3545;
  --bs-popover-border-color: #dc3545;
  --bs-popover-body-color: #dc3545;
}

.toast {
  background-color: white;
}

.toast-container {
  top: 3rem;
  right: 3rem;
  position: fixed;
}

[lang="ar"] .toast-container {
  right: auto;
  left: 3rem;
}

.toast {
  border-width: 1px;
  border-style: solid;
  --bs-toast-font-size: 1rem;
}

.toast.success-toast {
  border-color: #3fae2a;
}

.toast.error-toast {
  border-color: #dc3545;
}

.toast .toast-header i {
  font-size: 1rem;
  margin-inline-end: 0.5rem;
  margin-bottom: -1px;
}

.toast.success-toast .toast-header,
.toast.success-toast button:hover {
  color: #3fae2a;
}

.toast.error-toast .toast-header,
.toast.error-toast button:hover {
  color: #dc3545;
}

.toast button {
  background: none;
  border: none;
  outline: none;
  margin-inline-start: auto;
  color: #838383;
  transition: color 0.2s linear;
}

p.none {
  margin-bottom: 0;
  color: #a6a9aa;
  font-style: italic;
  text-align: center;
}

.mgc-card {
  width: 100%;
  background-color: #f3f5f9;
  border: 2px solid #3fae2a;
  border-radius: 1.5rem;
  padding: 1rem;
  margin-inline-start: auto;
  margin-inline-end: auto;
}

.mgc-card:not(:last-child) {
  margin-bottom: 1.5rem;
}

.mgc-card .icon,
.mgc-card .buttons {
  display: flex;
  align-items: center;
  justify-content: center;
}

.mgc-card .icon {
  margin-inline-end: 4rem;
  color: #00833e;
  font-size: 3rem;
}

.mgc-card .card-title {
  margin-bottom: 1rem;
  font-weight: bold;
  color: #3fae2a;
}

.mgc-card .card-row {
  display: flex;
  align-items: baseline;
  margin-bottom: 0;
}

.mgc-card .card-row .key,
.mgc-card .card-row .value {
  max-width: 100%;
}

.mgc-card .card-row .key {
  flex-shrink: 0;
  color: #000a88;
  font-weight: 500;
  margin-inline-end: 1rem;
}

.mgc-card .card-row .key .icon {
  display: inline;
  margin-inline-end: 0.5rem;
  font-size: inherit;
}

.mgc-card .card-row .value,
.accordion-header .detail-item .value,
.accordion-collapse .detail-item .value {
  max-width: 100%;
  white-space: pre-line;
}

.mgc-card .buttons.text-buttons {
  flex-direction: column;
}

.mgc-card .buttons .popover-container,
.mgc-card .buttons button,
.mgc-card .buttons a {
  width: 100%;
  flex-shrink: 0;
}

.mgc-card .buttons:not(.text-buttons) button,
.mgc-card .buttons:not(.text-buttons) a {
  width: 3rem;
  padding: 0;
  font-size: 1.25rem;
}

.mgc-card .buttons button:not(:last-child),
.mgc-card .buttons a:not(:last-child),
.mgc-card .buttons .popover-container:not(:last-child),
.accordion-header .header-btn:not(:last-child) {
  margin-inline-end: 1rem;
}

.mgc-card .buttons.text-buttons .popover-container:not(:last-child),
.mgc-card .buttons.text-buttons button:not(:last-child),
.mgc-card .buttons.text-buttons a:not(:last-child) {
  margin-inline-end: 0;
  margin-bottom: 1rem;
}

.input-group:not(.parent) {
  --x-pad: 2rem;
  padding: 0 var(--x-pad);
  border: 2px solid gainsboro;
  border-radius: 10rem;
}

.input-group.textarea-group,
.input-group.editor-group,
.input-group.list-input-group,
.input-group.radio-input-group,
.input-group.checkbox-input-group {
  border-radius: 2rem;
}

.form-floating {
  position: relative;
  display: flex;
  align-items: center;
}

.form-floating::before {
  content: "";
  position: absolute;
  bottom: 0.5rem;
  left: 0.75rem;
  width: calc(100% - 1.5rem);
  border-bottom: 2px solid gainsboro;
}

.form-floating::after {
  content: "";
  position: absolute;
  bottom: 0.5rem;
  left: 0.75rem;
  width: 0;
  border-bottom: 2px solid #3fae2a;
  transition: width 0.2s ease-in;
}

.form-floating:focus-within::after {
  width: calc(100% - 1.5rem);
}

[lang="ar"] .form-floating::before,
[lang="ar"] .form-floating::after {
  left: auto;
  right: 0.75rem;
}

.input-group.textarea-group .form-floating {
  padding-top: 1.625rem;
  padding-bottom: 1rem;
}

.input-group.editor-group,
.input-group.list-input-group {
  padding: 1rem;
}

.input-group.editor-group label,
.input-group.list-input-group label {
  margin-bottom: 1rem;
}

.input-group .form-control,
.input-group .form-control:focus,
.input-group .form-control:disabled,
.input-group .form-select,
.input-group .form-select:focus,
.input-group .form-select:disabled,
.input-group .input-group-text:not(.action-btn),
.input-group button.pass-btn,
.input-group button.file-btn,
.input-group:not(.button-input-group) button:not(.action-btn) {
  background-color: white;
  border: none;
  outline: none;
  box-shadow: none;
  border-radius: 0;
}

.input-group .input-group-text:not(.action-btn),
.input-group button.pass-btn,
.input-group:not(.button-input-group) button:not(.action-btn) {
  background: none !important;
}

.input-group .form-control:-webkit-autofill,
.input-group .form-control:-internal-autofill-selected,
.input-group .form-select:-webkit-autofill {
  background-color: transparent !important;
  -webkit-text-fill-color: #838383;
  transition: background-color 5000s ease-in-out 0s;
}

.input-group .form-select,
.input-group .form-select:focus {
  background-repeat: no-repeat !important;
  background-position: right 0.75rem center !important;
  background-size: 16px 12px !important;
}

.input-group .form-select {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23838383' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e") !important;
}

[lang="ar"] .input-group .form-select {
  background-position: left 0.75rem center !important;
}

.input-group .form-select:focus {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%233fae2a' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e") !important;
}

.input-group.parent > .form-control,
.input-group.parent > .form-control:focus,
.input-group.parent > .form-control:disabled,
.input-group.parent > .form-control:-webkit-autofill,
.input-group.parent > .form-select,
.input-group.parent > .form-select:focus,
.input-group.parent > .form-select:disabled,
.input-group.parent > .form-select:-webkit-autofill,
.input-group.parent > .input-group-text,
.input-group.parent > button,
.input-group .form-control,
.input-group .form-control:focus,
.input-group .form-control:disabled,
.input-group .form-select,
.input-group .form-select:focus,
.input-group .form-select:disabled,
.input-group .input-group-text:not(.action-btn),
.input-group:not(.button-input-group) button:not(.action-btn) {
  background-color: transparent;
  color: #838383;
  -webkit-text-fill-color: #838383;
}

.date-group .date-input,
.date-group .date-input .form-control,
.date-group .date-input .input-group-text {
  height: calc(3.5rem + 2px);
}

.input-group .form-control::placeholder {
  -webkit-text-fill-color: transparent;
}

.input-group.date-group > .form-floating::before,
.input-group.date-group > .form-floating::after {
  display: none;
}

.input-group.date-group .date-input .input-group {
  border: none !important;
  border-radius: 0;
}

.input-group > .input-group .form-control::placeholder {
  -webkit-text-fill-color: #838383;
}

.input-group.date-group .date-input .form-control {
  padding-inline-start: 0;
  padding-inline-end: 0;
}

.input-group.date-group .date-input .is-invalid .form-control::placeholder {
  -webkit-text-fill-color: #dc3545;
}

.form-floating .form-control:focus,
.form-floating .form-control:not(:placeholder-shown) {
  padding-bottom: 1rem;
}

.form-floating .form-select {
  padding-bottom: 0.75rem;
  padding-inline-start: 0.75rem;
}

.input-group .form-select option {
  color: #3fae2a;
}

.form-floating label,
.input-group.checkbox label {
  height: auto;
  color: #838383;
  padding-top: 0;
  padding-bottom: 0;
  top: auto;
}

[lang="ar"] .form-floating label {
  left: auto;
  right: 0;
  transform-origin: 100% 0;
}

.form-floating .form-control:focus ~ label,
.form-floating .form-control:not(:placeholder-shown) ~ label,
.form-floating .form-select ~ label,
.editor-group label.focused,
.list-input-group label.focused,
.date-group label {
  color: #3fae2a;
  opacity: 1;
}

.form-floating .form-control:focus ~ label,
.form-floating .form-control:not(:placeholder-shown) ~ label,
.form-floating .form-select ~ label,
.date-group .form-floating label {
  transform: scale(0.75) translateY(-1rem) translateX(0.15rem);
}

[lang="ar"] .form-floating .form-control:focus ~ label,
[lang="ar"] .form-floating .form-control:not(:placeholder-shown) ~ label,
[lang="ar"] .form-floating .form-select ~ label,
[lang="ar"] .date-group .form-floating label {
  transform: scale(0.75) translateY(-1rem) translateX(-0.15rem);
}

.textarea-group label {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  transition:
    opacity 0.1s ease-in-out,
    transform 0.1s ease-in-out,
    top 0.1s ease-in-out;
}

.textarea-group textarea:focus ~ label,
.textarea-group .form-floating textarea:not(:placeholder-shown) ~ label,
[lang="ar"] .textarea-group textarea:focus ~ label,
[lang="ar"] .textarea-group .form-floating textarea:not(:placeholder-shown) ~ label {
  top: 0.25rem;
  transform: scale(0.75) !important;
}

.textarea-group textarea:focus ~ label,
.textarea-group .form-floating textarea:not(:placeholder-shown) ~ label {
  left: 0.15rem;
  right: auto;
}

[lang="ar"] .textarea-group textarea:focus ~ label,
[lang="ar"] .textarea-group .form-floating textarea:not(:placeholder-shown) ~ label {
  left: auto;
  right: 0.15rem;
}

.textarea-group textarea:disabled ~ label::after {
  display: none;
}

.date-group .date-input .form-control,
.date-group .date-input .input-group-text {
  padding: 1.625rem 0.75rem 1rem;
}

.input-group.date-group {
  z-index: 0;
}

.date-group input[type="date"] {
  position: absolute;
  top: 0;
  bottom: 0;
  width: calc(100% - calc(var(--x-pad) * 2));
  opacity: 0;
}

.date-group .form-floating {
  z-index: 1;
}

.list-input-group .list-input {
  height: 12rem;
  background-color: #f3f5f9;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: flex-start;
  border: 2px solid gainsboro;
  background-clip: padding-box;
  overflow: auto;
}

.list-input-group .list-input tr {
  display: flex;
}

.list-input-group .list-input th,
.list-input-group .list-input td {
  display: flex;
  flex: 1 0 0%;
  width: 100%;
  max-width: 100%;
  border: 1px solid transparent;
}

.list-input-group .list-input th {
  justify-content: center;
  padding: 0.15rem 0.5rem;
  background-color: #f3f5f9;
  font-size: 1rem;
  color: #000a88;
}

.list-input-group .list-input td {
  padding: 0;
  text-align: start;
  transition: border-color 0.2s linear;
}

.list-input-group .list-input td .list-input-row {
  width: 100%;
  margin-bottom: 0;
  padding: 0 0.5rem;
  background-color: white;
  border: none;
  outline: none;
  color: #838383;
  font-size: 1rem;
  word-wrap: anywhere;
  white-space: pre-line;
  hyphens: auto;
}

.list-input-group .list-input td.is-invalid {
  border-color: #dc3545;
  z-index: 1;
}

.list-input-group .list-input td:not(.is-invalid):focus-within {
  border-color: #3fae2a;
}

.list-input-group .list-input tr:not(:last-child):not(:focus-within) td:not(.is-invalid) {
  border-bottom-color: #ced4da;
}

.radio-group,
.checkbox-input-group {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
}

.radio-input-group .form-floating::before,
.radio-input-group .form-floating::after,
.checkbox-input-group .form-floating::before,
.checkbox-input-group .form-floating::after {
  display: none;
}

.radio-input-group .form-control.radio-group,
.checkbox-input-group .form-control.checkbox-group {
  height: auto;
  min-height: calc(3.5rem + 2px);
  padding-bottom: 0.25rem;
}

.radio-input-group .radio-group ~ label,
.checkbox-input-group .checkbox-group ~ label {
  top: 0.2rem;
  transform: scale(0.75) translateX(0.15rem) !important;
}

.input-group.checkbox:not(:has(.checkbox-group)) {
  border-color: transparent;
}

.input-group.checkbox .form-check {
  height: calc(3.5rem + calc(var(--bs-border-width) * 2));
  margin-bottom: 0;
  padding: 0 0.75rem;
}

.input-group.checkbox:not(.checkbox-input-group) .form-check {
  width: 100%;
}

.input-group .spinner-container {
  display: none;
}

.input-group button.pass-btn {
  width: 2.5rem;
  font-size: 1.25rem;
  padding: 0 0.5rem;
}

.modal#alert-modal .icon-wrapper {
  margin: 0 auto 4rem;
}

.modal#alert-modal p {
  font-weight: 500;
  font-size: 1.5rem;
  text-align: center;
  margin-bottom: 4rem;
  color: #838383;
}

.modal#alert-modal .buttons span {
  display: flex;
  align-items: center;
  justify-content: center;
}

.modal#alert-modal .buttons button {
  width: 100%;
}

.modal#alert-modal .buttons span:only-child button {
  width: 50%;
}

.modal#pass-reqs-modal .instructions {
  margin-bottom: 1.5rem;
  color: #3fae2a;
  font-size: 1.15rem;
  font-weight: 500;
}

.modal#pass-reqs-modal ul {
  padding: 0;
}

.error {
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: #a6a9aa;
}

.error .svg-wrapper.icon,
.error img.icon {
  width: 8rem;
}

.error .msg {
  text-align: center;
  margin-top: 2rem;
}

#otp-modal .otp-form {
  display: flex;
  flex-direction: column;
  align-items: center;
  color: #838383;
}

#alert-modal .icon-wrapper,
#otp-modal .icon-wrapper {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 12rem;
  aspect-ratio: 1/1;
  margin-bottom: 4rem;
  border-radius: 100%;
  border: 12px solid #000a88;
  color: #3fae2a;
  overflow: hidden;
}

#otp-modal .icon-wrapper .svg-wrapper {
  width: 100%;
  height: 100%;
}

#alert-modal .icon-wrapper path,
#otp-modal .icon-wrapper .svg-wrapper path {
  --duration: 1s;
  --easing: ease-in-out;
  --delay: 0.15s;
  fill: transparent;
  stroke: currentColor;
  stroke-width: 8px;
  transition: fill var(--duration) var(--easing) var(--delay);
}

#alert-modal.show .icon-wrapper .svg-wrapper path,
#otp-modal.show .icon-wrapper .svg-wrapper path {
  fill: #95d600;
  stroke-dasharray: var(--dash);
  stroke-dashoffset: var(--dash);
  animation: draw-strokes var(--duration) forwards var(--easing) var(--delay);
}

#otp-modal .instructions {
  margin-bottom: 3rem;
  font-size: 1.25rem;
  text-align: center;
}

#otp-modal .otp {
  width: 100%;
}

#otp-modal .otp:has(.timer-reset) {
  width: 75%;
}

#otp-modal .otp .otp-input {
  display: flex;
  justify-content: space-between;
}

#otp-modal .otp .otp-input .digit-wrapper {
  position: relative;
}

#otp-modal .otp .otp-input .digit-cover {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
}

#otp-modal .otp .otp-input .digit-cover:not(:has(+ .digit:disabled)) {
  display: none;
}

#otp-modal .otp .otp-input .digit {
  width: 4.5rem;
  aspect-ratio: 1/1;
  color: #838383;
  background-color: #f3f5f9;
  border: 2px solid transparent;
  outline: none;
  text-align: center;
  font-size: 2.25rem;
  border-radius: 1rem;
  transition: border-color 0.2s linear;
}

#otp-modal .otp .otp-input .digit:focus {
  border-color: #3fae2a;
}

#otp-modal .otp .timer-reset {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 3rem 1.5rem;
}

#otp-modal .otp .timer-reset::before,
#otp-modal .otp .timer-reset::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  display: block;
  width: 100%;
  border-bottom: 4px solid;
}

[lang="ar"] #otp-modal .otp .timer-reset::before,
[lang="ar"] #otp-modal .otp .timer-reset::after {
  left: auto;
  right: 0;
}

#otp-modal .otp .timer-reset::before {
  border-color: gainsboro;
}

#otp-modal .otp .timer-reset::after {
  border-color: #00833e;
}

#otp-modal .otp .timer-reset.started::after {
  width: 0;
  transition: width var(--period) linear;
}

#otp-modal .otp .timer-reset .timer {
  color: #000a88;
  font-size: 3rem;
  font-weight: bold;
  text-align: center;
}

#otp-modal .otp .timer-reset .reset {
  --move: 0.5s;
  display: flex;
  align-items: center;
  width: 0;
  overflow: hidden;
  transition: width var(--move) linear;
}

#otp-modal .otp .timer-reset.started .reset {
  --w-delay: calc(var(--period) + 0.35s);
  width: 100%;
  transition-delay: var(--w-delay);
}

#otp-modal .otp .timer-reset button[name="resendOTP"] {
  --duration: 0.2s;
  width: 100%;
  border-radius: 0;
  opacity: 0;
  visibility: hidden;
  transition:
    color 0.2s linear,
    opacity var(--duration) linear,
    visibility var(--duration) linear;
}

#otp-modal .otp .timer-reset.started button[name="resendOTP"] {
  --delay: calc(var(--w-delay) + var(--move));
  opacity: 1;
  visibility: visible;
  transition-delay: 0s, var(--delay), var(--delay);
}

#otp-modal .otp-form .buttons {
  width: 100%;
}

ul,
ol {
  list-style: none;
  padding-left: 0;
  padding-right: 0;
  padding-inline-start: 2rem;
}

ul li,
ol li {
  display: flex;
  align-items: baseline;
}

ul li:not(:last-child),
ol li:not(:last-child) {
  margin-bottom: 0.5rem;
}

ul li::before {
  content: "";
  flex-shrink: 0;
  height: 16px;
  aspect-ratio: 1/1;
  background-image: url("../Images/leaf_icon.ico");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  transform: translateY(0.1em);
}

ol {
  counter-reset: counter;
}

ol > li {
  counter-increment: counter;
}

ul li::before,
ol li::before {
  margin-inline-end: 1rem;
}

ol li::before {
  content: counter(counter);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  height: 1.25rem;
  aspect-ratio: 1/1;
  font-size: 0.75rem;
  color: #00833e;
  border: 2px solid #00833e;
  border-radius: 100%;
  transform: translateY(-0.15em);
}

[lang="ar"] ol li::before {
  content: counter(counter, arabic-indic);
}

:where(article h1, aside h1, nav h1, section h1) {
  margin-block: 0.83em;
  font-size: 1.5em;
}

h1 {
  color: #00833e;
  font-weight: bold;
  text-align: center;
  text-transform: uppercase;
}

.nav-tabs.nav-pills {
  flex-wrap: nowrap;
  width: 100%;
  background-color: #f3f5f9;
  padding: 1rem;
  margin-bottom: 6rem;
  border: none;
  border-radius: 1rem;
  box-shadow: 0 0 0.25rem gainsboro;
  overflow: auto;
}

.nav-pills.invisible-tabs {
  display: none;
}

.nav-tabs.nav-pills .nav-item {
  position: relative;
  display: flex;
  justify-content: center;
  flex-shrink: 0;
  border-bottom: 3px solid transparent;
  margin: 0 1.5rem;
  text-align: center;
}

.nav-tabs.nav-pills .nav-item::before {
  background: none;
  width: auto;
  height: auto;
  margin-inline-end: 0;
}

.nav-tabs.nav-pills .nav-item:hover {
  border-color: gainsboro;
}

.nav-tabs.nav-pills .nav-item::after {
  content: "";
  position: absolute;
  bottom: -3px;
  height: 3px;
  width: 0;
  background-color: #3fae2a;
  transition: width 0.1s linear;
}

.nav-tabs.nav-pills .current-tab::after {
  width: 100%;
}

.nav-tabs.nav-pills .current-tab:hover::after {
  width: calc(100% + 1rem);
}

.nav-tabs.nav-pills .nav-link {
  background: none;
  border-radius: 0;
  color: #838383;
  transition: none;
  padding: 0.25rem 0;
}

.nav-tabs.nav-pills .nav-link.active {
  border-color: transparent;
  font-weight: bold;
}

.nav-tabs.nav-pills .current-tab .nav-link {
  pointer-events: none;
}

.accordion {
  --bs-accordion-btn-icon: none;
  --bs-accordion-btn-active-icon: none;
  --bs-accordion-bg: white;
  --bs-accordion-btn-bg: #f3f5f9;
  --bs-accordion-border-color: gainsboro;
  --bs-accordion-btn-color: #838383;
  --bs-accordion-active-color: white;
  --bs-accordion-active-bg: #000a88;
  --bs-accordion-border-radius: 0.5rem;
  --bs-accordion-inner-border-radius: calc(0.5rem - 1px);
  --bs-accordion-btn-focus-border-color: gainsboro;
  --bs-accordion-btn-focus-box-shadow: none;
  --bs-accordion-color: #838383;
}

.accordion-button {
  font-size: 1.075rem;
  z-index: 0 !important;
}

.accordion-button::after {
  display: none;
}

.accordion-button .btn-mgc {
  transition:
    background-color 0.2s linear,
    color 0.2s linear;
}

.accordion-header {
  display: flex;
  align-items: center;
}

.accordion-header:hover {
  z-index: 0;
}

.accordion-header .header-main {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
}

.accordion-header .header-main .details,
.accordion-header .header-main .buttons {
  flex: 1 0 50%;
}

.accordion-header .details {
  width: 100%;
  margin-inline-end: 1.5rem;
}

.accordion-header .header-main .details {
  margin-inline-end: 0;
  padding-inline-end: 1.5rem;
}

.accordion-header .detail-item {
  margin-bottom: 0;
}

.accordion-header .detail-item .key {
  transition: color 0.15s ease-in-out;
}

.accordion-header .detail-item .key,
.accordion-header .indicator,
.accordion-collapse .detail-item .key {
  color: #000a88;
}

.accordion-header .detail-item .key,
.accordion-collapse .detail-item .key {
  font-weight: 500;
  margin-inline-end: 1rem;
}

.accordion-header:not(.collapsed) .detail-item .key,
.accordion-header:not(.collapsed) .detail-icons,
.accordion-header:not(.collapsed) .indicator {
  color: #95d600;
}

.accordion-header .buttons {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.accordion-header .header-main .buttons {
  justify-content: flex-start;
}

.accordion-header button,
.accordion-header a {
  width: 2.5rem;
  padding: 0;
  font-size: 1.25rem;
}

.accordion-header:not(.collapsed) .detail-icons .hollow {
  color: #000a88;
}

.accordion-header .indicator {
  padding: 0 1rem;
  transition:
    transform 0.2s linear,
    color 0.15s ease-in-out;
}

.accordion-header:not(.collapsed) .indicator {
  transform: rotate(180deg);
}

.accordion-item .detail-item,
.accordion-item .detail-item:last-child {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}

.accordion-collapse .detail-item {
  margin-bottom: 0.25rem;
}

.accordion-collapse .detail-item:last-child {
  margin-bottom: 0;
}

.accordion-collapse .detail-item > * {
  flex-shrink: 0;
}

.message-container {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 6rem 0;
}

.page-content:not(:has(> .sidebar)) .message-container {
  width: 75%;
  margin: 4rem auto 0;
  padding: 6rem;
  border-radius: 4rem;
  box-shadow: 0 1.25rem 3.75rem #00000019;
}

.message-container .code {
  font-size: 10rem;
  margin-bottom: 4rem;
}

.message-container .msg {
  margin-bottom: 0;
  font-size: 2.5rem;
  font-weight: bold;
  text-align: center;
}

.message-container .sub-msg {
  margin-top: 4rem;
  margin-bottom: 0;
  font-size: 1.35rem;
  text-align: center;
  color: #000a88;
}

h6 {
  font-size: inherit;
}

h5 {
  font-size: 1.8rem;
}

hr {
  border-color: #00833e;
  border-width: 2px;
  opacity: 1;
}

footer.main-footer {
  margin-top: 4rem;
}

.footer-wrapper {
  display: grid;
  background-color: #000a88;
}

.footer-wrapper .footer-strip,
.footer-wrapper .footer-content {
  grid-row: 1;
  grid-column: 1;
}

.footer-wrapper .footer-strip {
  width: 100%;
  transform: scale(-1);
}

[lang="ar"] .footer-wrapper .footer-strip {
  transform: scaleY(-1);
}

.footer-wrapper .footer-content {
  display: flex;
  flex-direction: column;
  justify-content: end;
  z-index: 0;
}

.footer-links {
  --footer-gap-y: 1rem;
  display: flex;
  justify-content: space-around;
  flex-wrap: wrap;
  margin-top: calc(var(--footer-gap-y) * -1);
  padding: 0 20rem;
}

.footer-section {
  margin-top: var(--footer-gap-y);
  padding: 0 0.5rem;
}

.footer-section-wrapper {
  display: flex;
  align-items: flex-start;
}

.footer-links .footer-section-icon {
  width: 3.5rem;
  color: white;
  flex-shrink: 0;
}

.footer-links .svg-wrapper,
.footer-links img {
  display: block;
  width: 100%;
}

.footer-links .links-list {
  margin-inline-start: 1.5rem;
}

.footer-links .links-list span {
  display: block;
  margin-bottom: 0.5rem;
  color: white;
  font-size: 1.5rem;
  font-weight: bold;
}

.footer-links ul {
  margin-bottom: 0;
  padding-inline-start: 1.5rem;
}

.footer-links ul li {
  margin-bottom: 0;
}

.footer-links ul li::before {
  display: none;
}

.footer-contact {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem 2rem;
}

.footer-contact p {
  display: flex;
  align-items: center;
  margin-bottom: 0;
  color: #95d600;
  font-weight: bold;
  font-size: 1.15rem;
}

.footer-contact p:not(:last-child) {
  margin-inline-end: 1.5rem;
}

.footer-contact p > span:not(:last-child),
.footer-contact p > a:not(:last-child) {
  margin-inline-end: 0.75rem;
}

.footer-contact p > span {
  display: flex;
  align-items: center;
}

.footer-contact p > span span:not(:last-child) {
  margin-inline-end: 0.25rem;
}

.footer-contact .social-media-platform {
  width: 2.25rem;
  padding: 0;
}

.mobile-app-fab,
button[name="toTop"] {
  position: fixed;
  padding: 0;
}

button[name="toTop"] {
  display: none;
  right: 4rem;
  width: 3rem;
  opacity: 0.4;
}

[lang="ar"] button[name="toTop"] {
  right: auto;
  left: 4rem;
}

.floating-button.mobile-app-fab {
  --w: 5rem;
  bottom: 2rem;
  left: 2rem;
}

[lang="ar"] .mobile-app-fab {
  left: auto;
  right: 2rem;
}

.mobile-app-fab .toggle-button,
.mobile-app-fab:not(.floating-button),
.mobile-app-fab .fb-child {
  box-shadow: 0 0 0.75rem silver;
}

.floating-button.mobile-app-fab .toggle-button {
  padding: 0.5rem;
  background-color: #f3f5f9;
  border: 8px solid currentColor;
  transition: all 0.2s linear;
}

.floating-button.mobile-app-fab input#toggle:checked ~ .toggle-button {
  transform: none;
}

.mobile-app-fab .toggle-button .mobile-app-logo {
  width: 100%;
  height: 100%;
}

.mobile-app-fab .icon-btn.fb-child .i {
  font-size: 1.25rem;
  transform: none;
}

.mobile-app-fab .icon-btn:not(.fb-child) .i {
  font-size: 2.5rem;
}

.note-container {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  width: 100%;
  margin-bottom: 2rem;
}

.note {
  color: #000a88;
  font-weight: bold;
  text-decoration: underline;
  margin-inline-end: 0.5rem;
}

.go-back-row {
  margin-bottom: 4rem;
}

.go-back-row .icon {
  margin-inline-end: 1rem;
}

[lang="ar"] .go-back-row .icon {
  transform: scaleX(-1);
}

.go-back-row button {
  padding: 0;
  border-radius: 0;
}

.pagination-list {
  margin-top: 4rem;
}

.pagination-list .pagination-row {
  display: flex;
  justify-content: space-around;
  margin-bottom: 3rem;
}

.pagination-list .pagination-row:has(> :only-child) {
  justify-content: center;
}

.pagination-list .pagination {
  --bs-pagination-border-color: gainsboro;
  --bs-pagination-hover-border-color: #3fae2a;
  --bs-pagination-active-border-color: #3fae2a;
  --bs-pagination-disabled-border-color: gainsboro;
  --bs-pagination-bg: #f3f5f9;
  --bs-pagination-hover-bg: #f3f5f9;
  --bs-pagination-active-bg: #3fae2a;
  --bs-pagination-focus-bg: #f3f5f9;
  --bs-pagination-disabled-bg: #f3f5f9;
  --bs-pagination-color: #838383;
  --bs-pagination-hover-color: #3fae2a;
  --bs-pagination-active-color: white;
  --bs-pagination-focus-color: #838383;
  --bs-pagination-disabled-color: silver;
  --bs-pagination-focus-box-shadow: none;
  justify-content: center;
  flex-wrap: wrap;
}

.pagination-list .pagination .page-link {
  --size: 2.5rem;
  display: inline-block;
  min-width: var(--size);
  height: var(--size);
  transition:
    color 0.2s linear,
    border-color 0.2s linear,
    opacity 0.2s linear;
}

.pagination-list .pagination .arrow {
  font-size: 0.65rem;
}

.pagination-list .pagination .page-link.selected {
  border-color: #3fae2a;
  color: #3fae2a;
  z-index: 10;
}

.pagination-list .pagination .page-link:disabled {
  opacity: 0.6;
  pointer-events: none;
}

.pagination-list .pagination .page-item.active {
  pointer-events: none;
}

.pagination-popover {
  border-color: #3fae2a;
  --bs-popover-arrow-border: #3fae2a;
  --bs-popover-body-padding-x: 0.75rem;
  --bs-popover-body-padding-y: 0.75rem;
}

.pagination-popover input,
.pagination-popover input:focus,
.pagination-popover input:disabled {
  outline: none;
  border-color: gainsboro;
  background-color: transparent;
  color: #838383;
  text-align: center;
}

.pagination-popover input:disabled {
  opacity: 0.5;
}

.pagination-popover input {
  width: 3rem;
}

.pagination-popover input:focus {
  border-color: #95d600;
  outline-color: #95d600;
  box-shadow: 0 0 3px 2px #95d6007f;
}

.pagination-list .filters {
  display: flex;
}

.pagination-list .filters .form-check {
  flex-shrink: 0;
}

.pagination-list .filters .form-check:not(:last-child) {
  margin-inline-end: 2rem;
}

.pagination-list .results-count {
  display: flex;
  align-items: center;
  margin-bottom: 1.5rem;
  color: #000a88;
  font-style: italic;
  font-weight: 500;
}

.pagination-list .results-count p {
  margin-bottom: 0;
}

.pagination-list .results-count p:not(:last-child) {
  margin-inline-end: 4rem;
}

.pagination-list .items,
.pagination-list .items-list {
  width: 100%;
}

.pagination-list .items {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.pagination-list .wait .spinner-border {
  width: 6rem;
  height: 6rem;
}

.pagination-list .wait {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem 0;
  color: #00833e;
}

.table-wrapper {
  width: 100%;
  max-width: 100%;
  overflow: auto;
}

table {
  width: 100%;
  border: 1px solid gainsboro;
}

table tr {
  border-width: 1px;
}

table th,
table td {
  padding: 0.5rem 1rem;
  text-align: center;
  border-width: 0 1px;
  border-color: gainsboro;
}

table th {
  background-color: #3fae2a;
  color: white;
}

table td {
  background-color: #f3f5f9;
}

table .buttons {
  display: flex;
  align-items: center;
  justify-content: center;
}

table .buttons button,
table .buttons a[role="button"] {
  width: 2.75rem;
  padding: 0;
  font-size: 1rem;
}

table .buttons > *:not(:last-child) {
  margin-inline-end: 1rem;
}

.fab-wrapper {
  display: flex;
  justify-content: flex-end;
  flex-wrap: wrap;
  height: 100%;
  width: 100%;
}

.fab-wrapper > :first-child {
  width: 100%;
  margin-bottom: 2rem;
}

.fab-wrapper .floating-button {
  position: sticky;
  bottom: 3rem;
  align-self: flex-end;
  border-radius: 100%;
  box-shadow: 0 0 0.75rem silver;
}

.floating-button {
  --w: 3.5rem;
}

.floating-button .toggle-button {
  width: var(--w);
  aspect-ratio: 1/1;
  font-size: 1.75rem;
  transition:
    background-color 0.2s linear,
    transform 0.2s linear;
}

.floating-button input#toggle:checked ~ .toggle-button {
  transform: rotate(45deg);
}

.floating-button input#toggle {
  display: none;
}

.floating-button .fb-child {
  --child-w: 3rem;
  --radius: calc(var(--w) + calc(var(--child-w) / 2));
  --base-deg: 90deg;
  --deg: calc(var(--base-deg) / (var(--num-btns) - 1));
  --index: calc(var(--num-btns) - var(--i) - 1);
  --factor: 0deg;
  --angle: calc((var(--index) * var(--deg)) + var(--factor));
  --dx: calc(calc(cos(var(--angle)) * var(--radius) * -1));
  --dy: calc(sin(var(--angle)) * var(--radius) * -1);
  position: absolute;
  bottom: 0;
  right: 0;
  width: var(--child-w);
  padding: 0;
  font-size: 1.25rem;
  z-index: -1;
  pointer-events: none;
  transform: rotateZ(90deg);
  transition:
    background-color 0.2s linear,
    opacity 0.35s cubic-bezier(0.175, 0.885, 0.32, 1.275),
    transform 0.35s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

[lang="ar"] .floating-button .fb-child,
.floating-button.start .fb-child {
  --base-deg: -90deg;
  --dx: calc(calc(cos(var(--angle)) * var(--radius) * 1));
  --dy: calc(sin(var(--angle)) * var(--radius) * 1);
  right: auto;
  left: 0;
}

.floating-button .fb-child:not(:disabled) {
  opacity: 0;
}

.floating-button:not(:has(.fb-child + .fb-child + .fb-child)) .fb-child {
  --factor: calc((var(--base-deg) / (2 * var(--num-btns))) * (1 - (2 * var(--index))));
}

.floating-button .fb-child:nth-child(1 of .fb-child):nth-last-child(1 of .fb-child) {
  --deg: calc(var(--base-deg) / var(--num-btns));
  --index: calc(var(--num-btns) - var(--i));
}

.floating-button input#toggle:checked ~ .fb-child {
  pointer-events: all;
  transform: translate(var(--dx), var(--dy));
  transition-delay: calc(0.1s * var(--i));
}

.floating-button input#toggle:checked ~ .fb-child:not(:disabled) {
  opacity: 1;
}

.floating-button .fb-child .mdi {
  font-size: 1.5rem;
}

.login-form {
  align-self: center;
  width: 50%;
  margin: auto 0;
}

.page-content:not(:has(> .sidebar)) .login-form {
  width: 75%;
  margin: 0 auto;
  padding: 6rem;
  border-radius: 4rem;
  background-color: white;
  box-shadow: 0 1.25rem 3.75rem #00000019;
}

.login-form .login-icon {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 9rem;
  height: 9rem;
  margin: 0 auto 4rem auto;
  padding: 1.75rem;
  border: 4px solid #3fae2a;
  border-radius: 50%;
  color: #3fae2a;
  overflow: hidden;
}

.login-form .login-icon::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  border: 10px solid #95d600;
  border-radius: 50%;
}

.login-form .login-icon .svg-wrapper {
  width: 100%;
  height: 100%;
}

.login-form .login-input-icon {
  font-size: 1.25rem;
}

.login-form .login-input-icon .i:first-child {
  color: #3fae2a;
}

.login-form .forgot-pass {
  margin-top: 4rem;
  margin-bottom: 0;
  text-align: center;
  font-size: 1.25rem;
}

.login-form .forgot-pass span {
  margin-inline-end: 0.5rem;
}

.payment-init-form {
  display: none;
}

.breadcrumbs {
  display: flex;
  align-items: baseline;
  margin: 8rem 18rem 4rem;
  padding: 0 4rem;
}

.page-content:not(:has(> .sidebar)):has(> .message-container) .breadcrumbs {
  width: 75%;
  margin: 8rem auto 4rem;
  padding: 0 6rem;
}

.breadcrumbs .divider {
  margin: 0 0.75rem;
  font-size: 1rem;
}

.data-row {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}

.data-row .key {
  margin-inline-end: 1rem;
  font-weight: bold;
  color: #000a88;
}

.article-wrapper .article-section:not(:last-child) {
  margin-bottom: 3.5rem;
}

.article-wrapper .article-title {
  margin-bottom: 2rem;
  color: #00833e;
  font-weight: bold;
}

.article-wrapper .article-date {
  margin-bottom: 1rem;
  color: #3fae2a;
  font-size: 1.15rem;
  text-transform: uppercase;
}

.article-wrapper .views-tags-row {
  display: flex;
  align-items: start;
}

.article-wrapper .article-views,
.article-wrapper .article-tags {
  display: flex;
  align-items: center;
  color: #000a88;
  font-weight: bold;
}

.article-wrapper .article-views {
  margin-inline-end: 4rem;
}

.article-wrapper .article-views .views-icon {
  margin-inline-end: 1rem;
}

.article-wrapper .article-tags {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}

.article-wrapper .article-tags span:not(:last-child) {
  margin-inline-end: 1rem;
}

.article-wrapper .media-container {
  background-color: transparent;
  border: none;
}

.article-wrapper .article-section img {
  padding: 0;
}

.article-wrapper .content-section video,
.article-wrapper .content-section img {
  max-width: 100%;
}

.article-wrapper a {
  font-weight: 500;
  color: #3fae2a;
  text-decoration: none;
  transition: color 0.2s linear;
}

.article-wrapper a:hover {
  color: #95d600;
}

.article-wrapper a:active {
  color: #00833e;
}

.vacancy-wrapper {
  --bs-gutter-x: 2rem;
}

.vacancy-wrapper .key-val {
  display: flex;
  flex-direction: column;
  align-items: start;
}

.vacancy-wrapper .long-col-wrapper .key-val {
  margin-bottom: 3rem;
}

.vacancy-wrapper .key {
  margin-bottom: 0.5rem;
  color: #000a88;
  font-size: 1.25rem;
  font-weight: bold;
}

.vacancy-wrapper .value {
  padding-inline-start: 1rem;
}

.vacancy-wrapper .value.position {
  font-size: 2rem;
}

.vacancy-wrapper .value ul {
  padding-inline-start: 0;
}

.vacancy-wrapper .short-col-wrapper {
  display: grid;
  padding: 1.5rem;
  border: 2px solid #95d600;
  border-radius: 1.5rem;
}

.vacancy-wrapper .short-col-wrapper .logo {
  width: 100%;
  margin-bottom: 5rem;
}

.vacancy-wrapper .cats-row {
  --bs-gutter-x: 0.75rem;
  --bs-gutter-y: 0.75rem;
  padding: 0.5rem 0;
}

.vacancy-wrapper .short-col-wrapper .category {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.5rem 1.5rem;
  border: 2px solid currentColor;
  border-radius: 2rem;
}

.vacancy-wrapper .short-col-wrapper .buttons,
.vacancy-wrapper .short-col-wrapper .buttons button {
  width: 100%;
}

.vacancy-wrapper .short-col-wrapper .buttons {
  margin-top: 3rem;
}

.svg-wrapper svg {
  width: 100%;
  height: 100%;
  fill: currentColor;
}

.pie-chart {
  display: flex;
  justify-content: center;
  width: 100%;
}

.pie-chart.inactive,
.pie-chart.inactive .data,
.pie-chart.inactive .total {
  pointer-events: none;
}

.pie-chart .items {
  --items-w: 30%;
  flex: 1 0 var(--items-w);
  width: var(--items-w);
  margin-bottom: 0;
  padding-inline-start: 0;
  padding-inline-end: 2rem;
}

.pie-chart .items li:not(:last-child) {
  margin-bottom: 2rem;
}

.pie-chart .items li::before {
  display: none;
}

.pie-chart .items li .item-wrapper {
  display: flex;
  flex-direction: column;
  width: 100%;
  margin-bottom: 0;
  padding-top: 0.5rem;
  border-top: 0.75rem solid var(--item-color);
}

.pie-chart .items li .label {
  font-weight: bold;
  color: var(--item-color);
}

.pie-chart .svg-wrapper {
  --chart-w: 70%;
  flex: 1 0 var(--chart-w);
  width: var(--chart-w);
  aspect-ratio: 1/1;
}

.pie-chart .svg-wrapper svg {
  fill: transparent;
}

.pie-chart .svg-wrapper svg g {
  rotate: -90deg;
  transform-origin: center;
}

.pie-chart .data,
.pie-chart .total {
  stroke: var(--stroke);
  stroke-width: var(--stroke-width);
  pointer-events: stroke;
  cursor: pointer;
}

.pie-chart .shadow {
  fill: black;
  opacity: 0.4;
  pointer-events: none;
}

.pie-chart .percentage {
  text-anchor: middle;
  font-size: var(--font-size);
  cursor: default;
}

.iti {
  --iti-path-flags-1x: url("./Images/flags.webp");
  --iti-path-flags-2x: url("./Images/flags@2x.webp");
  --iti-path-globe-1x: url("./Images/globe.webp");
  --iti-path-globe-2x: url("./Images/globe@2x.webp");
}

.iti.form-control {
  display: flex;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  direction: ltr;
}

.iti--allow-dropdown .iti__country-container,
.iti__tel-input.form-control {
  padding-top: 1.625rem;
  padding-bottom: 1rem;
}

.iti--allow-dropdown .iti__country-container {
  position: relative;
  margin-inline-end: 0.75rem;
  cursor: auto !important;
}

.iti__tel-input.form-control {
  height: calc(3.5rem + 2px);
  padding-left: 0 !important;
  padding-right: 0 !important;
}

[lang="ar"] .iti__tel-input.form-control {
  direction: rtl;
}

.iti__selected-country {
  display: flex;
}

.iti__selected-country-primary,
.iti__selected-dial-code {
  padding-top: 0.5rem !important;
  padding-bottom: 0.5rem !important;
  transition:
    color 0.2s linear,
    -webkit-text-fill-color 0.2s linear;
}

.iti__selected-country:hover .iti__arrow,
.iti__selected-country:hover .iti__selected-dial-code {
  color: #3fae2a;
  -webkit-text-fill-color: #3fae2a;
  border-top-color: #3fae2a;
}

.iti__selected-country:disabled {
  pointer-events: none;
}

.iti__selected-country-primary {
  margin-inline-end: 0.5rem;
  padding: 0;
  background: none !important;
}

.iti__selected-dial-code {
  transition:
    color 0.2s linear,
    -webkit-text-fill-color 0.2s linear;
}

.iti__arrow {
  margin-inline-start: 0.35rem !important;
  transition: border-top-color 0.2s linear;
}

.iti ul li {
  cursor: default;
}

.iti ul li::before {
  display: none;
}

.iti__country-list .iti__flag-box {
  margin-inline-end: 1rem;
}

.iti__country-list .iti__country {
  transition: background-color 0.2s linear;
}

[lang="ar"] .iti__dropdown-content {
  direction: rtl;
}

.iti__country-list .iti__country .iti__country-name,
.iti__country-list .iti__country .iti__dial-code {
  transition:
    color 0.2s linear,
    -webkit-text-fill-color 0.2s linear;
}

.iti__country-list .iti__country.iti__highlight {
  background-color: #f3f5f9;
  color: #3fae2a;
}

.iti__country-list .iti__country.iti__highlight .iti__country-name,
.iti__country-list .iti__country.iti__highlight .iti__dial-code {
  -webkit-text-fill-color: #3fae2a;
}

.iti__country-list .iti__country .iti__dial-code {
  direction: ltr;
}

.iti__search-input {
  box-shadow: none;
  border: 1px solid transparent;
  outline: 1px solid transparent;
}

.iti__search-input:focus,
.iti__search-input:focus-visible {
  border-color: #95d600;
  outline-color: #95d600;
  box-shadow: 0 0 3px 2px #95d6007f;
}

.google-map {
  width: 100%;
  aspect-ratio: 16/9;
  border: 2px solid #3fae2a;
}

.google-map iframe + div[style] {
  display: none;
}

.google-map .svg-wrapper {
  display: inline-block;
}

.mgc-section {
  padding: 8rem 18rem;
}

.breadcrumbs + .mgc-section {
  padding-top: 0;
}

section:not(:last-child) {
  margin-bottom: 6rem;
}

.mgc-section .text-content-wrapper,
.mgc-section .img-col .img-wrapper {
  display: flex;
  flex-direction: column;
  justify-content: center;
  height: 100%;
  padding: 3rem;
}

.mgc-section .img-col .img-wrapper {
  align-items: center;
}

.mgc-section .mgc-section-title {
  width: 100%;
  margin-bottom: 1rem;
  text-align: start;
}

.mgc-section .mgc-section-subtitle {
  margin-bottom: 3rem;
  color: #3fae2a;
  font-size: 1.5rem;
  font-weight: bold;
}

.mgc-section .mgc-section-text {
  margin-bottom: 0;
  font-size: 1.25rem;
}

.mgc-section .mgc-section-text:not(:last-child) {
  margin-bottom: 4rem;
}

.mgc-section .mgc-section-action a {
  width: 50%;
}

.mgc-section .img-col img,
.mgc-section .img-col .svg-wrapper {
  width: 100%;
  object-fit: contain;
}

.book-cover {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  transition: transform 0.2s linear;
}

.book-cover:hover {
  transform: scale(1.1);
}

.book-cover.loading {
  pointer-events: none;
  cursor: default;
}

.book-cover::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  box-shadow: inset 0 0 10px #666;
}

.book-cover img {
  width: 100%;
}

.book-cover .init-load,
.book-loading {
  font-size: 1.5rem;
  color: silver;
}

.book-cover .init-load {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 3.5rem;
  height: 3.5rem;
  aspect-ratio: 1/1;
  background-color: #f3f5f9;
  border-radius: 0.5rem;
}

.book-viewer {
  --bs-modal-width: 100%;
  --bs-modal-border-radius: 0;
  --bs-modal-border-width: 0;
  --bs-modal-bg: transparent;
  overflow-y: hidden;
}

.book-viewer.show {
  display: block;
}

.book-viewer .modal-dialog {
  height: calc(100% - var(--bs-modal-margin) * 2);
}

.book-viewer .modal-content {
  height: 100%;
}

.book-viewer .modal-body,
.book-controls {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.book-wrapper {
  height: 100%;
  margin-bottom: 3rem;
}

.book-viewer .page {
  background-color: #f3f5f9;
}

.book-loading {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.book-controls .book-slider {
  height: 0.5rem;
  width: 100%;
  background-color: #f3f5f9;
  border-radius: 0.5rem;
  margin-bottom: 3rem;
  outline: none;
  appearance: none;
}

.book-controls .book-slider::-moz-range-thumb {
  height: 0.5rem;
  width: 5rem;
  background-color: #3fae2a;
  border: none;
}

.book-controls .book-slider::-webkit-slider-thumb {
  height: 0.5rem;
  width: 5rem;
  border: none;
  border-radius: 0.5rem;
  background: #3fae2a;
  -webkit-appearance: none;
}

.book-controls .book-slider::-ms-thumb {
  height: 0.5rem;
  width: 5rem;
  border: none;
  border-radius: 0.5rem;
  background: #3fae2a;
}

.book-controls .buttons,
.book-controls .buttons .move-btns,
.book-controls .buttons .page-counter,
.book-controls .buttons .control-btns {
  display: flex;
}

.book-controls .buttons {
  justify-content: space-between;
  width: 50rem;
  padding: 0.5rem 4rem;
  background-color: #efefef;
  border-radius: 2rem;
}

.book-controls .buttons button,
.book-controls .buttons a {
  padding: 0 0.25rem;
  border-radius: 0;
}

.book-controls button:not(:last-child),
.book-controls a:not(:last-child) {
  margin-inline-end: 2rem;
}

.book-controls .buttons p {
  margin-bottom: 0;
  margin-inline-start: 2rem;
  margin-inline-end: 4rem;
  font-size: 1.1rem;
  color: #3fae2a;
  user-select: none;
}

.book-controls .buttons p .current-page {
  color: #838383;
}

.book-controls .buttons p .slash {
  margin-inline-start: 1rem;
  margin-inline-end: 1rem;
}

.banner {
  --banner-height: 25rem;
  --img-size: 60%;
  display: grid;
  height: var(--banner-height);
  overflow: hidden;
}

.banner > * {
  grid-row: 1;
  grid-column: 1;
}

.banner .banner-img {
  justify-self: end;
  width: var(--img-size);
  height: var(--banner-height);
  object-fit: cover;
}

.banner .banner-text-content {
  background-image: linear-gradient(to right, #000a88 40%, transparent);
}

[lang="ar"] .banner .banner-text-content {
  background-image: linear-gradient(to left, #000a88 40%, transparent);
}

.banner .banner-text-content .text-wrapper {
  --text-col-size: calc(100% - var(--img-size));
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: var(--text-col-size);
  max-width: var(--text-col-size);
  height: 100%;
  padding: 2rem 6rem;
}

.banner .banner-text-content .page-name,
.banner .banner-text-content .banner-text {
  color: white;
}

.banner .banner-text-content .page-name {
  margin-bottom: 2rem;
  text-transform: none;
  font-size: 3rem;
}

.banner .banner-text-content .banner-text {
  font-size: 1.5rem;
  text-align: center;
  margin-bottom: 0;
}

.banner .svg-wrapper {
  align-self: end;
  display: flex;
  align-items: center;
  justify-content: center;
}

.slick-slider {
  user-select: auto;
}

.overflow-parent {
  display: grid;
  overflow: auto;
}

.overflow-parent .overflow-wrapper,
.overflow-parent .overflow-toggle {
  grid-row: 1;
  grid-column: 1;
}

.overflow-parent .overflow-wrapper {
  overflow: hidden;
}

.overflow-parent:not(.init) .overflow-wrapper,
.overflow-parent.overflowing .overflow-wrapper {
  overflow: visible;
}

.overflow-parent.overflowing .overflow-wrapper {
  padding-bottom: 4rem;
}

.overflow-parent .overflow-wrapper p:last-child {
  margin-bottom: 0;
}

.overflow-parent .overflow-toggle {
  --gradient-color: #f3f5f9;
  align-self: end;
  padding: 0.5rem 2rem;
  border-radius: 0;
  border: 2px solid;
  border-top: none;
  border-image: linear-gradient(to top, var(--gradient-color), transparent) 1;
  background-image: linear-gradient(to top, var(--gradient-color) 25%, transparent);
  z-index: 0;
}

.overflow-parent:not(.init) .overflow-toggle {
  visibility: hidden;
}

/* ANCHOR Animations */

@keyframes draw-strokes {
  to {
    stroke-dashoffset: 0;
  }
}

/* ANCHOR Safari only */
@supports (hanging-punctuation: first) and (font: -apple-system-body) and (-webkit-appearance: none) {
  .mobile-app-fab .toggle-button .mobile-app-logo {
    height: 3rem;
  }

  .textarea-group textarea:focus ~ label,
  .textarea-group .form-floating textarea:not(:placeholder-shown) ~ label {
    will-change: transform, opacity;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
  }
}

/* ANCHOR Tablet size */

@media (max-width: 991px) {
  .page-content:not(:has(> .sidebar)) {
    padding: 0;
  }

  .topbar {
    align-items: stretch;
    font-size: 0.85rem;
  }

  .topbar button[name="toggleTopBar"] {
    display: flex;
  }

  .topbar-info {
    display: grid;
    grid-template-columns: repeat(4, 0fr);
    width: 100%;
  }

  .topbar-info.expanded {
    grid-template-columns: 1fr;
  }

  .topbar-info p {
    margin-inline-end: 0.5rem;
    view-transition-name: var(--transition-name);
  }

  .topbar-info p:last-child {
    margin-inline-end: 0;
  }

  .topbar-info.expanded p {
    text-align: start;
  }

  .topbar-info.expanded p:not(:last-child) {
    margin-bottom: 0.25rem;
    margin-inline-end: 0;
  }

  .topbar .topbar-info:not(.expanded) p > span:not(.icon),
  .topbar .topbar-info:not(.expanded) p > a:not(.icon) {
    display: none;
  }

  .topbar-info.expanded + .far-half {
    flex-direction: column-reverse;
    align-items: end;
    justify-content: center;
  }

  .topbar-info.expanded + .far-half .logged-in-user,
  .topbar-info.expanded + .far-half button[name="user"] {
    margin-top: 0.5rem;
    margin-inline-end: 0;
  }

  .navbar::after {
    background-position-y: -1rem;
  }

  .page-content {
    padding: 2rem 3rem;
  }

  .navbar .navbar-nav {
    padding-top: 2rem;
  }

  .navbar .navbar-nav .nav-item {
    flex-direction: column;
    margin: 0 !important;
  }

  .navbar-nav .dropdown-menu .dropdown-item {
    white-space: normal;
  }

  .nav-tabs.nav-pills {
    margin-bottom: 4rem;
  }

  .fab-wrapper > :first-child {
    margin-bottom: 4rem;
  }

  .footer-wrapper {
    flex-direction: column;
  }

  .footer-wrapper .footer-content {
    grid-row: 2;
    min-width: 0;
  }

  .footer-links {
    padding: 0 2rem;
  }

  .footer-links .footer-section-icon {
    width: 2.5rem;
  }

  .footer-links .links-list span {
    font-size: 1.1rem;
  }

  .footer-links ul {
    font-size: 0.9rem;
  }

  .footer-contact {
    padding: 2rem 2rem 1rem;
  }

  .footer-contact p:not(:last-child),
  .footer-contact p:not(:last-child) span,
  .footer-contact p > span:not(:last-child),
  .footer-contact p > a:not(:last-child) {
    margin-inline-end: 0;
  }

  .footer-contact p {
    font-size: 0.825rem;
  }

  .footer-contact p:first-child,
  .footer-contact p:last-child {
    flex-direction: column;
  }

  .footer-contact p:has(.social-media-platform) {
    --sm-gap-x: 1rem;
    --sm-gap-y: 0.25rem;
    margin-top: calc(var(--sm-gap-y) * -1);
    margin-left: calc(var(--sm-gap-x) / -2);
    margin-right: calc(var(--sm-gap-x) / -2);
    padding: 0 1.5rem;
  }

  .footer-contact p > span {
    text-align: center;
  }

  .footer-contact .social-media-platform {
    margin-top: var(--sm-gap-y);
    margin-left: calc(var(--sm-gap-x) / 2) !important;
    margin-right: calc(var(--sm-gap-x) / 2) !important;
  }

  button[name="toTop"] {
    bottom: 3rem;
    right: 3rem;
  }

  [lang="ar"] button[name="toTop"] {
    left: 3rem;
  }

  .mgc-card .details:has(> .row) {
    display: flex;
    align-items: center;
  }

  .mgc-card .details .row {
    flex: 1 0 0%;
  }

  .book-viewer .modal-body {
    justify-content: center;
  }

  .book-wrapper {
    height: auto;
  }

  .book-controls,
  .book-controls .buttons {
    width: 100%;
  }

  .book-controls .buttons {
    padding: 0.5rem 3rem;
  }

  .book-controls button:not(:last-child) {
    margin-inline-end: 1.5rem;
  }

  .book-controls .buttons p {
    margin-inline-start: 1.5rem;
    margin-inline-end: 3rem;
  }

  .book-controls .buttons p .slash {
    margin-inline-start: 0.75rem;
    margin-inline-end: 0.75rem;
  }

  .banner {
    --banner-height: 18rem;
  }

  .banner .banner-text-content .text-wrapper {
    --text-col-size: calc(100% - var(--img-size) + 10%);
    padding: 2rem;
  }

  .banner .banner-text-content .page-name {
    margin-bottom: 1.5rem;
    font-size: 2.5rem;
  }

  .banner .banner-text-content .banner-text {
    font-size: 1.25rem;
  }

  .mgc-section {
    padding: 4rem;
  }

  .mgc-section .mgc-section-title,
  .mgc-section .mgc-section-subtitle,
  .mgc-section .mgc-section-text {
    text-align: center;
  }

  .mgc-section .mgc-section-action a {
    margin: 0 auto;
  }

  .page-content:not(:has(> .sidebar)):has(> .message-container) .breadcrumbs {
    width: calc(100% - 8rem);
    padding: 0 4rem;
  }

  .page-content:not(:has(> .sidebar)) .message-container {
    width: calc(100% - 8rem);
    padding: 4rem;
  }

  .page-content:not(:has(> .sidebar)) .login-form {
    width: 100%;
    margin: 0;
  }

  .mgc-card .icon {
    margin-inline-end: 2rem;
  }

  .breadcrumbs {
    margin: 4rem !important;
  }

  .pie-chart .items {
    --items-w: 35%;
  }

  .pie-chart .svg-wrapper {
    --chart-w: 55%;
  }

  .vacancy-wrapper .long-col-wrapper .key-val:last-child {
    margin-bottom: 6rem;
  }

  .vacancy-wrapper .short-col-wrapper {
    grid-template-columns: repeat(auto-fit, minmax(calc(100% / 3), 1fr));
  }

  .vacancy-wrapper .short-col-wrapper .logo,
  .vacancy-wrapper .key-val:has(.cats-row),
  .vacancy-wrapper .short-col-wrapper .buttons {
    grid-column: 1 / -1;
  }

  .vacancy-wrapper .short-col-wrapper .logo {
    width: 50%;
    justify-self: center;
  }

  .vacancy-wrapper .short-col-wrapper .key-val:not(:has(.cats-row)) {
    margin-bottom: 1.5rem;
  }

  .accordion-header .header-main .buttons {
    flex: 0 0 auto;
    padding-inline-end: 1.5rem;
  }

  .range-input-group .input-group > .input-group .form-control::placeholder,
  .date-input-group .input-group > .input-group .form-control::placeholder {
    font-size: 0.85rem;
  }

  .date-input-group .input-group.date-input .form-control {
    padding: 0.375rem 0.5rem;
  }

  .date-input-group .input-group.date-input .input-group:first-child .form-control {
    padding-inline-start: 1.25rem;
  }

  .date-input-group .input-group.date-input .input-group:last-child .form-control {
    padding-inline-end: 1.25rem;
  }

  .pagination-list .pagination-row,
  .pagination-list .filters {
    flex-wrap: wrap;
  }

  .pagination-list .pagination-row {
    --gap-y: 2rem;
    margin-top: calc(var(--gap-y) * -1);
  }

  .pagination-list .pagination,
  .pagination-list .filters {
    margin-top: var(--gap-y);
  }

  .pagination-list .filters {
    --f-gap-x: 2rem;
    justify-content: center;
    margin-inline-start: calc(var(--f-gap-x) / -2);
    margin-inline-end: calc(var(--f-gap-x) / -2);
  }

  .pagination-list .filters .form-check {
    margin-inline-start: calc(var(--f-gap-x) / 2) !important;
    margin-inline-end: calc(var(--f-gap-x) / 2) !important;
  }
}

/* ANCHOR Large phone size */

@media (max-width: 650px) {
  body {
    font-size: 1.025rem;
  }

  h1 {
    font-size: calc(1.325rem + 1.5vw);
  }

  .page-content {
    padding: 1.5rem;
  }

  .topbar {
    padding: 0.5rem 1.5rem;
  }

  .topbar button[name="toggleTopBar"] {
    margin-inline-end: 1rem;
  }

  body:not(:has(.sidebar)) .topbar-info:not(.expanded) p {
    margin-inline-end: 0;
  }

  .topbar p > span:not(:last-child) {
    margin-inline-end: 0.75rem;
  }

  .topbar .topbar-info.expanded + .far-half .logged-in-user span:first-child {
    display: none;
  }

  .topbar .far-half > :not(:last-child) {
    margin-inline-end: 2rem;
  }

  .navbar {
    --bs-navbar-padding-x: 1.5rem;
  }

  .navbar::after {
    background-size: 50%;
    background-position-y: -1.5rem;
  }

  .navbar .navbar-brand img {
    height: 3rem;
  }

  .nav-tabs.nav-pills .nav-item {
    margin: 0 1rem;
  }

  .mgc-card .details:not(:last-child) {
    margin-bottom: 2rem;
  }

  .mgc-card .card-row {
    flex-wrap: wrap;
  }

  .mgc-card .card-row span {
    flex-shrink: 0;
  }

  .footer-links {
    --footer-gap-y: 2rem;
  }

  .footer-links .footer-section-icon {
    width: 3rem;
  }

  .footer-links .links-list span {
    font-size: 1.15rem;
  }

  .footer-links ul {
    font-size: 0.85rem;
  }

  .footer-contact p {
    flex-wrap: wrap;
    justify-content: center;
    text-align: center;
  }

  .book-controls .buttons {
    padding: 0.5rem 2rem;
  }

  .banner .banner-text-content .page-name {
    margin-bottom: 1rem;
    font-size: 2rem;
  }

  .banner .banner-text-content .banner-text {
    font-size: 1rem;
  }

  .mgc-section {
    padding: 2rem;
  }

  .mgc-section .mgc-section-text {
    font-size: 1.15rem;
  }

  .mgc-section .mgc-section-subtitle {
    margin-bottom: 2rem;
  }

  .mgc-card .icon {
    margin-inline-end: 1rem;
  }

  .page-content:not(:has(> .sidebar)) .login-form {
    padding: 4rem;
  }

  .breadcrumbs {
    margin: 4rem 2rem !important;
    font-size: 1rem;
  }

  .breadcrumbs .divider {
    margin: 0 0.5rem;
  }

  .login-form .login-icon {
    width: 8rem;
    height: 8rem;
  }

  .accordion-header .header-main {
    flex-direction: column;
    align-items: start;
  }

  .accordion-header .header-main .details,
  .accordion-header .header-main .buttons {
    padding-inline-end: 0;
  }

  .accordion-header .header-main .details:not(:last-child) {
    margin-bottom: 1rem;
  }

  .vacancy-wrapper .key {
    font-size: 1.15rem;
  }

  .vacancy-wrapper .value {
    font-size: 1rem;
  }

  .vacancy-wrapper .value.position {
    font-size: 1.5rem;
  }

  .vacancy-wrapper .value p {
    margin-bottom: 0;
  }

  .vacancy-wrapper .value p:not(:last-child) {
    margin-bottom: 0.5rem;
  }

  .vacancy-wrapper .short-col-wrapper {
    grid-template-columns: repeat(auto-fit, minmax(calc(100% / 2), 1fr));
  }

  .vacancy-wrapper .short-col-wrapper .category {
    padding: 0.25rem 1.25rem;
    font-size: 0.95rem;
  }
}

/* ANCHOR Phone size */

@media (max-width: 510px) {
  .topbar {
    padding: 0.25rem 0.75rem;
  }

  .topbar .topbar-info {
    padding-inline-end: 0.5rem;
  }

  .topbar p .icon {
    margin-inline-end: 0.5rem;
  }

  .topbar p > span {
    text-align: start;
  }

  .topbar .far-half {
    padding-inline-start: 0.5rem;
  }

  .topbar .logged-in-user {
    display: none;
  }

  .topbar button[name="user"] {
    display: flex;
    font-size: 1.25em;
  }

  .topbar-info.expanded + .far-half button[name="user"] {
    width: 100%;
    padding: 0.35rem 0;
    border-radius: 0;
  }

  .topbar .far-half > :not(:first-child) {
    margin-bottom: 0;
  }

  .topbar button[name="lang"] .lang-icon {
    display: inline;
    font-size: 1.15rem;
    line-height: initial;
    translate: 0 1px;
  }

  .topbar button[name="lang"] .lang-text {
    display: none;
  }

  .topbar .profile .profile-popup {
    top: -1rem;
    right: calc(100% + 1rem);
  }

  [lang="ar"] .topbar .profile .profile-popup {
    right: auto;
    left: calc(100% + 1rem);
  }

  .topbar .profile .profile-popup::before {
    right: -0.75rem;
    top: 1rem;
    border-color: transparent #3fae2a;
    border-width: 0.75rem 0 0.75rem 0.75rem;
  }

  [lang="ar"] .topbar .profile .profile-popup::before {
    right: auto;
    left: 1rem;
  }

  .topbar .profile .profile-popup::after {
    right: calc(2px - 0.75rem);
    top: calc(1rem + 2px);
    border-color: transparent transparent transparent #e6e6e6;
    border-width: calc(0.75rem - 2px) 0 calc(0.75rem - 2px) calc(0.75rem - 2px);
  }

  [lang="ar"] .topbar .profile .profile-popup::after {
    right: auto;
    left: calc(1rem + 2px);
  }

  .navbar {
    --bs-navbar-padding-x: 1rem;
  }

  .navbar .navbar-brand img {
    height: 2.25rem;
  }

  .navbar .navbar-nav .nav-item {
    padding: 0;
  }

  .page-content {
    padding: 1rem;
  }

  .content-wrapper.no-menu {
    padding: 0;
  }

  .content {
    padding: 1.5rem 1rem;
  }

  .nav-tabs.nav-pills {
    margin-bottom: 3rem;
  }

  .toast-container {
    right: 2rem;
  }

  [lang="ar"] .toast-container {
    right: auto;
    left: 2rem;
  }

  .toast {
    --bs-toast-max-width: calc(100vw - 4rem);
  }

  .input-group:not(.parent) {
    padding: 0 1.5rem;
  }

  .input-group > .input-group:first-child .form-control,
  .input-group > .input-group:first-child .form-select,
  .input-group > .input-group:first-child .input-group-text {
    padding-inline-start: 1rem;
  }

  .input-group > .input-group:last-child .form-control,
  .input-group > .input-group:last-child .form-select,
  .input-group > .input-group:last-child .input-group-text {
    padding-inline-end: 1rem;
  }

  .form-switch .form-check-input {
    width: 2.5rem;
    height: 1.25rem;
  }

  .modal {
    --bs-modal-header-padding: 1rem 1.5rem;
    --bs-modal-padding: 1.5rem;
  }

  .modal-header .modal-title {
    font-size: 1.75rem;
  }

  .modal .modal-header button[name="close"] {
    width: 2.5rem;
    height: 2.5rem;
    font-size: 1.75rem;
  }

  .modal .modal-body form .buttons button:only-child {
    width: 100%;
  }

  .footer-wrapper .footer-content {
    padding: 0 2rem;
  }

  .footer-links {
    --footer-gap-y: 1.5rem;
    --footer-gap-x: 1.5rem;
    justify-content: center;
    margin-inline-start: calc(var(--footer-gap-x) / -2);
    margin-inline-end: calc(var(--footer-gap-x) / -2);
    padding: 0;
  }

  .footer-section {
    flex: 0 0 auto;
    width: 50%;
    padding-inline-start: calc(var(--footer-gap-x) / 2);
    padding-inline-end: calc(var(--footer-gap-x) / 2);
  }

  .footer-links .footer-section-icon {
    width: 2rem;
  }

  .footer-links .links-list {
    margin-inline-start: 1rem;
  }

  .footer-links .links-list span {
    font-size: 1rem;
  }

  .footer-links ul {
    padding-inline-start: 1rem;
    font-size: 0.8rem;
  }

  .footer-contact {
    flex-direction: column;
    padding: 2rem 0 1rem;
  }

  .footer-contact p:not(:last-child) {
    margin-bottom: 0.5rem;
  }

  button[name="toTop"] {
    bottom: 2rem;
    right: 2rem;
  }

  [lang="ar"] button[name="toTop"] {
    left: 2rem;
  }

  .book-controls .buttons {
    flex-direction: column;
    padding: 0.5rem 1.25rem;
  }

  .book-controls button,
  .book-controls .buttons p {
    font-size: 1rem;
  }

  .book-controls button:not(:last-child) {
    margin-inline-end: 1rem;
  }

  .book-controls .buttons .move-btns {
    margin-bottom: 1rem;
  }

  .book-controls .buttons p {
    margin-inline-start: 1rem;
    margin-inline-end: 2rem;
  }

  .book-controls .buttons p .slash {
    margin-inline-start: 0.25rem;
    margin-inline-end: 0.25rem;
  }

  .banner .banner-text-content .text-wrapper {
    padding: 1.5rem;
  }

  .banner .banner-text-content .page-name {
    font-size: 1.5rem;
  }

  .banner .banner-text-content .banner-text {
    font-size: 0.9rem;
  }

  .mgc-section .mgc-section-text {
    font-size: 1.05rem;
  }
}
