.mdi {
  /* font-size: 1.2em; */
}

.nav-link:has(.mdi) {
  display: flex;
  align-items: center;
}

*.hide {
  display: none !important;
}

.loader-overlay {
  --loader-width: 15rem;
  --gear-color: #000;
  --gear-bg-color: #fff;
    top: 0;
    left: 0;
    position: fixed;
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    background: var(--gear-bg-color);
    z-index: 1100;
}

.loader {
  width: calc(1.5 * var(--loader-width));
  height: var(--loader-width);
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
}

.loader::before {
  content: '';  
  left: 0;
  top: 0;
  position: absolute;
  width: calc(0.9 * var(--loader-width));
  height: calc(0.9 * var(--loader-width));
  border-radius: 50%;
  background-color: var(--gear-color);
  background-image:
    radial-gradient(circle calc(0.2 * var(--loader-width)) at calc(0.45 * var(--loader-width)) calc(0.45 * var(--loader-width)), var(--gear-bg-color) 100%, transparent 0),
    radial-gradient(circle calc(0.1 * var(--loader-width)) at calc(0.45 * var(--loader-width)) 0px, var(--gear-bg-color) 100%, transparent 0),
    radial-gradient(circle calc(0.1 * var(--loader-width)) at 0px calc(0.45 * var(--loader-width)), var(--gear-bg-color) 100%, transparent 0),
    radial-gradient(circle calc(0.1 * var(--loader-width)) at calc(0.9 * var(--loader-width)) calc(0.45 * var(--loader-width)), var(--gear-bg-color) 100%, transparent 0),
    radial-gradient(circle calc(0.1 * var(--loader-width)) at calc(0.45 * var(--loader-width)) calc(0.9 * var(--loader-width)), var(--gear-bg-color) 100%, transparent 0),
    radial-gradient(circle calc(0.1 * var(--loader-width)) at calc(0.75 * var(--loader-width)) calc(0.125 * var(--loader-width)), var(--gear-bg-color) 100%, transparent 0),
    radial-gradient(circle calc(0.1 * var(--loader-width)) at calc(0.75 * var(--loader-width)) calc(0.125 * var(--loader-width)), var(--gear-bg-color) 100%, transparent 0),
    radial-gradient(circle calc(0.1 * var(--loader-width)) at calc(0.75 * var(--loader-width)) calc(0.75 * var(--loader-width)), var(--gear-bg-color) 100%, transparent 0),
    radial-gradient(circle calc(0.1 * var(--loader-width)) at calc(0.125 * var(--loader-width)) calc(0.75 * var(--loader-width)), var(--gear-bg-color) 100%, transparent 0),
    radial-gradient(circle calc(0.1 * var(--loader-width)) at calc(0.125 * var(--loader-width)) calc(0.125 * var(--loader-width)), var(--gear-bg-color) 100%, transparent 0);
  background-repeat: no-repeat;
  box-sizing: border-box;
  animation: rotationBack 2s linear infinite;
}

.loader::after {
  content: '';  
  left: calc(0.875 * var(--loader-width));
  top: calc(0.375 * var(--loader-width));
  position: absolute;
  width: calc(0.6 * var(--loader-width));
  height: calc(0.6 * var(--loader-width));
  border-radius: 50%;
  background-color: var(--gear-color);
  background-image:
    radial-gradient(circle calc(0.125 * var(--loader-width)) at calc(0.3 * var(--loader-width)) calc(0.3 * var(--loader-width)), var(--gear-bg-color) 100%, transparent 0),
    radial-gradient(circle calc(0.0625 * var(--loader-width)) at calc(0.3 * var(--loader-width)) 0px, var(--gear-bg-color) 100%, transparent 0),
    radial-gradient(circle calc(0.0625 * var(--loader-width)) at 0px calc(0.3 * var(--loader-width)), var(--gear-bg-color) 100%, transparent 0),
    radial-gradient(circle calc(0.0625 * var(--loader-width)) at calc(0.6 * var(--loader-width)) calc(0.3 * var(--loader-width)), var(--gear-bg-color) 100%, transparent 0),
    radial-gradient(circle calc(0.0625 * var(--loader-width)) at calc(0.3 * var(--loader-width)) calc(0.6 * var(--loader-width)), var(--gear-bg-color) 100%, transparent 0),
    radial-gradient(circle calc(0.0625 * var(--loader-width)) at calc(0.5 * var(--loader-width)) calc(0.075 * var(--loader-width)), var(--gear-bg-color) 100%, transparent 0),
    radial-gradient(circle calc(0.0625 * var(--loader-width)) at calc(0.5 * var(--loader-width)) calc(0.075 * var(--loader-width)), var(--gear-bg-color) 100%, transparent 0),
    radial-gradient(circle calc(0.0625 * var(--loader-width)) at calc(0.5 * var(--loader-width)) calc(0.5 * var(--loader-width)), var(--gear-bg-color) 100%, transparent 0),
    radial-gradient(circle calc(0.0625 * var(--loader-width)) at calc(0.075 * var(--loader-width)) calc(0.5 * var(--loader-width)), var(--gear-bg-color) 100%, transparent 0),
    radial-gradient(circle calc(0.0625 * var(--loader-width)) at calc(0.075 * var(--loader-width)) calc(0.075 * var(--loader-width)), var(--gear-bg-color) 100%, transparent 0);
  background-repeat: no-repeat;
  box-sizing: border-box;
  animation: rotationBack 3s linear infinite reverse;
}

@keyframes rotationBack {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(-360deg);
  }
}

.login-page .app-footer {
  position: absolute;
  bottom: 0.5rem;
  width: 100%;
  text-align: center;
  background: transparent;
  border: 0;
}

@media (max-height: 600px) {
  .login-page .app-footer {
    position: static;
  }
}

.text-left {
  text-align: left !important;
}

.flex-column {
  display: flex;
}
*.float-right {
  float: right !important;
}

th.is-orderable {
  position: relative;
  cursor: pointer;
}

th.is-orderable::before,
th.is-orderable::after {
  font: normal normal normal 24px / 1 "Material Design Icons";
  font-size: inherit;
  text-rendering: auto;
  line-height: inherit;
  -webkit-font-smoothing: antialiased;
  /* font-size: 0.7em; */
  line-height: 1;
  text-rendering: auto;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 1.5em;
  opacity: 0.5;
}

th.is-orderable::before {
  content: "\F19B2";
}

th.is-orderable::after {
  content: "\F19B3";
  right: 0.7em;
}

th.is-orderable.is-ordered-asc::before, th.is-orderable.is-ordered-desc::after {
  opacity: 1;
}

*.inline-form-control {
  display: inline-block !important;
  width: unset !important;
}

.td-action {
  text-align: center;
}

dd {
  margin-left: revert !important;
  margin-bottom: revert !important;
}


.required-field label::after {
  content: '*';
  user-select: none;
  color: #f00;
  margin-left: 0.5em;
}

.text-right {
  text-align: right;
}

.page-title {
  font-weight: bold;
  font-size: 1.2em;
  display: flex;
  justify-content: center;
  align-items: center;
}

.flex-space-between {
  display: flex;
  justify-content: space-between;
}

.flex-valign-center {
  align-items: center;
}

.btn-rounded {
  border-radius: 2em;
}

.fs-small {
  font-size: 0.9em;
}

.fs-large {
  font-size: 1.2em;
}

.nav-icon {
  font-size: 1.5em;
}

.vertical-tab-container {
  --vertical-tab-border-width: 1px;
  --vertical-tab-border-color: #dee2e6;
  display: flex;
  overflow-x: auto;
}

.vertical-tab-container .tab {
  width: 15%;
  display: flex;
  flex-direction: column;
}

.vertical-tab-container .tab-link {
  display: block;
  width: 100%;
  padding: 1.5em 1em;
  text-decoration: none;
  border: var(--vertical-tab-border-width) solid transparent;
  border-right-color: var(--vertical-tab-border-color);
}

.vertical-tab-container .tab-link.active {
  color: inherit;
  border-left-color: var(--vertical-tab-border-color);
  border-top-color: var(--vertical-tab-border-color);
  border-bottom-color: var(--vertical-tab-border-color);
  border-right-color: transparent;
}

.vertical-tab-container .tab-content {
  flex-grow: 1;
  border: var(--vertical-tab-border-width) solid var(--vertical-tab-border-color);
  border-left-color: transparent;
}

table.align-middle th,
table.align-middle td {
  vertical-align: middle;
}

table.sip-data-table tbody tr.bonus-month td {
  --bs-text-opacity: 1;
  color: rgba(var(--bs-success-rgb), var(--bs-text-opacity)) !important;
  font-weight: bold;
  background-color: var(--bs-success-bg-subtle);
}

table.sip-data-table tbody tr.crash-month td:not(td[data-fund-type="debt"]) {
  --bs-text-opacity: 1;
  color: rgba(var(--bs-danger-rgb), var(--bs-text-opacity)) !important;
  font-weight: bold;
  background-color: var(--bs-danger-bg-subtle);
}

table.sip-data-table th[data-fund-type="debt"],
table.sip-data-table td[data-fund-type="debt"] {
  background-color: var(--bs-info-bg-subtle);
}

table.sip-data-table th[data-fund-type="equity"],
table.sip-data-table td[data-fund-type="equity"] {
  background-color: var(--bs-success-bg-subtle);
}

@media (max-width: 768px) {
  .vertical-tab-container .tab-link .hide-on-mobile {
    display: none !important;
  }

  .vertical-tab-container .tab-link {
    white-space: nowrap !important;
  }

  .vertical-tab-container .tab {
    width: 25%;
  }
}
