/*
* demo.css
* File include item demo only specific css only
******************************************************************************/

.light-style .menu .app-brand.demo {
    height: 90px;
  }
  
  .dark-style .menu .app-brand.demo {
    height: 90px;
  }
  
  .app-brand-logo.demo svg {
    width: 38px;
    height: 20px;
  }
  
  .app-brand-text.demo {
    font-size: 1.25rem;
    letter-spacing: 0.15px;
  }
  
  /* ! For .layout-navbar-fixed added fix padding top tpo .layout-page */
  .layout-navbar-fixed .layout-wrapper:not(.layout-without-menu) .layout-page {
    padding-top: 90px !important;
  }
  
  /* Navbar page z-index issue solution */
  .content-wrapper .navbar {
    z-index: auto;
  }
  
  /*
  * Content
  ******************************************************************************/
  
  .demo-blocks > * {
    display: block !important;
  }
  
  .demo-inline-spacing > * {
    margin: 1rem 0.375rem 0 0 !important;
  }
  
  /* ? .demo-vertical-spacing class is used to have vertical margins between elements. To remove margin-top from the first-child, use .demo-only-element class with .demo-vertical-spacing class. For example, we have used this class in forms-input-groups.html file. */
  .demo-vertical-spacing > * {
    margin-top: 1.25rem !important;
    margin-bottom: 0 !important;
  }
  .demo-vertical-spacing.demo-only-element > :first-child {
    margin-top: 0 !important;
  }
  
  .demo-vertical-spacing-lg > * {
    margin-top: 1.875rem !important;
    margin-bottom: 0 !important;
  }
  .demo-vertical-spacing-lg.demo-only-element > :first-child {
    margin-top: 0 !important;
  }
  
  .demo-vertical-spacing-xl > * {
    margin-top: 5rem !important;
    margin-bottom: 0 !important;
  }
  .demo-vertical-spacing-xl.demo-only-element > :first-child {
    margin-top: 0 !important;
  }
  
  .rtl-only {
    display: none !important;
    text-align: left !important;
    direction: ltr !important;
  }
  
  [dir='rtl'] .rtl-only {
    display: block !important;
  }
  
  /* Dropdown buttons going out of small screens */
  @media (max-width: 576px) {
    #dropdown-variation-demo .btn-group .text-truncate {
      width: 300px;
      position: relative;
    }
    #dropdown-variation-demo .btn-group .text-truncate::after {
      position: absolute;
      top: 45%;
      right: 0.65rem;
    }
  }
  /*
  * Layout demo
  ******************************************************************************/
  
  .layout-demo-wrapper {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-direction: column;
    flex-direction: column;
    margin-top: 1.25rem;
  }
  .layout-demo-placeholder img {
    width: 900px;
  }
  .layout-demo-info {
    text-align: center;
    margin-top: 1.25rem;
  }
  .authentication-wrapper {
    display: flex;
    flex-basis: 100%;
    min-height: 100vh;
    width: 100%;
  }
  .authentication-wrapper .authentication-inner {
    width: 100%;
  }
  .authentication-wrapper.authentication-basic {
    align-items: center;
    justify-content: center;
  }
  .authentication-wrapper .auth-cover-illustration {
    z-index: 1;
    max-inline-size: 38rem;
  }
  .authentication-wrapper .authentication-image {
    z-index: -1;
    inline-size: 100%;
    inset-block-end: 7%;
    position: absolute;
    inset-inline-start: 0;
  }
  .authentication-wrapper.authentication-cover {
    align-items: flex-start;
  }
  .authentication-wrapper.authentication-cover .authentication-inner {
    min-height: 100vh;
    position: relative;
  }
  .authentication-wrapper.authentication-cover .authentication-image {
    inline-size: 70%;
  }
  html:not([dir=rtl]) .authentication-wrapper.authentication-cover .authentication-image {
    inset-inline-start: unset;
  }
  .authentication-wrapper.authentication-basic .authentication-inner {
    max-width: 450px;
  }
  .authentication-wrapper .auth-input-wrapper .auth-input {
    max-width: 50px;
    padding-left: 0.4rem;
    padding-right: 0.4rem;
    font-size: 150%;
  }
  .authentication-wrapper .divider .divider-text {
    font-size: 0.9375rem;
  }
  
  @media (max-width: 575.98px) {
    .authentication-wrapper .auth-input-wrapper .auth-input {
      font-size: 1.125rem;
    }
  }
  @media (max-width: 1199.98px) {
    .authentication-cover .authentication-image {
      inset-block-end: 9%;
    }
    [dir=rtl] .authentication-cover .authentication-image {
      inline-size: 65%;
    }
  }
  #twoStepsForm .fv-plugins-bootstrap5-row-invalid .form-control {
    border-color: #ff4d49;
  }
  
  @media (max-width: 575.98px) {
    .numeral-mask-wrapper .numeral-mask {
      padding: 0 !important;
    }
    .numeral-mask {
      margin-inline: 1px !important;
    }
  }
  .light-style .authentication-wrapper .authentication-bg {
    background-color: #fff;
  }
  .light-style .authentication-wrapper .divider .divider-text {
    color: #3b4056;
  }
  
  .dark-style .authentication-wrapper .authentication-bg {
    background-color: #30334e;
  }
  .dark-style .authentication-wrapper .divider .divider-text {
    color: #d7d8ed;
  }
  .hero-counter {
    flex: 0 0 auto;          /* NÃO cresce nem encolhe */
    border-radius: .75rem;
    padding: 0.75rem 1rem;
    gap: 1rem;               /* espaçamento entre label e número */
    align-items: baseline;   /* alinha label ao topo do número */
  }
  
  .hero-label {
    color: #ccc;
    white-space: nowrap;
  }
  
  .hero-number {
    font-family: 'Share Tech Mono', monospace;
    font-size: clamp(3rem, 8vw, 6rem);
    color: #39ff14;
    line-height: 1;
  }

/* Custom styles for disabled form elements */
input:disabled,
textarea:disabled,
select:disabled,
.form-control:disabled,
.form-select:disabled {
  background-color: #f2f2f2 !important;
  cursor: not-allowed !important;
  opacity: 0.7 !important;
}
  