:root {
    --form-loader-dim: 62px;
    --form-loader-margin: 13px;
    --form-loader-col: #333;
}

[data-theme="dark"] {
    --form-loader-col: #CCC;
}

.loader-alert-icon {

    scale:0.7;

    width: 80px;
    height: 80px;
    border: 4px solid gray;
    -webkit-border-radius: 40px;
    border-radius: 40px;
    border-radius: 50%;
    margin: 0px auto;
    padding: 0;
    position: relative;
    box-sizing: content-box;
  }
  
  .loader-alert-icon.loader-alert-success {
    border-color: #4CAF50;
  }
  .loader-alert-icon.loader-alert-success .loader-alert-line {
    background-color: #4CAF50;
  }
  .loader-alert-icon.loader-alert-success .loader-alert-placeholder {
    border-color: rgba(76, 175, 80, 0.5);
  }
  
  .loader-alert-icon.loader-alert-error {
    border-color: #f3375c;
  }
  .loader-alert-icon.loader-alert-error .loader-alert-line {
    background-color: #f3375c;
  }
  
  .loader-alert-icon.loader-alert-error .loader-alert-placeholder {
    border-color: rgba(241, 41, 41, 0.5);
  }
  
  .loader-alert-icon::before,
  .loader-alert-icon::after {
    content: '';
    -webkit-border-radius: 40px;
    border-radius: 40px;
    border-radius: 50%;
    position: absolute;
    width: 60px;
    height: 120px;
    background: inherit;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
  }
  
  .loader-alert-icon::before {
    -webkit-border-radius: 120px 0 0 120px;
    border-radius: 120px 0 0 120px;
    top: -7px;
    left: -33px;
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
    -webkit-transform-origin: 60px 60px;
    transform-origin: 60px 60px;
  }
  
  .loader-alert-icon::after {
    -webkit-border-radius: 0 120px 120px 0;
    border-radius: 0 120px 120px 0;
    top: -11px;
    left: 30px;
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
    -webkit-transform-origin: 0px 60px;
    transform-origin: 0px 60px;
  }
  
  .loader-alert-icon .loader-alert-placeholder {
    width: 80px;
    height: 80px;
    border-width: 4px;
    border-style: solid;
    -webkit-border-radius: 40px;
    border-radius: 40px;
    border-radius: 50%;
    box-sizing: content-box;
    position: absolute;
    left: -4px;
    top: -4px;
    z-index: 2;
  }
  
  .loader-alert-icon .loader-alert-fix {
    width: 5px;
    height: 90px;
    background-color: inherit;
    position: absolute;
    left: 28px;
    top: 8px;
    z-index: 1;
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
  }
  
  .loader-alert-icon.animate::after {
    -webkit-animation: rotatePlaceholder 2s ease-in;
    animation: rotatePlaceholder 2s ease-in;
  }
  
  .loader-alert-icon {
    border-color: transparent\9;
  }
  .loader-alert-icon .loader-alert-line.loader-alert-tip {
    -ms-transform: rotate(45deg) \9;
  }
  .loader-alert-icon .loader-alert-line.loader-alert-long {
    -ms-transform: rotate(-45deg) \9;
  }
  
  .animateTip {
    -webkit-animation: animateTip 0.75s;
    animation: animateTip 0.75s;
  }
  .animateTip2 {
    -webkit-animation: animateTip2 0.75s;
    animation: animateTip2 0.75s;
  }
  .animateTip3 {
    -webkit-animation: animateTip3 0.75s;
    animation: animateTip3 0.75s;
  }
  
  .animateLong {
    -webkit-animation: animateLong 0.75s;
    animation: animateLong 0.75s;
  }
  
  @-webkit-keyframes animateLong {
    0% {
      width: 0;
      right: 46px;
      top: 54px;
    }
    65% {
      width: 0;
      right: 46px;
      top: 54px;
    }
    84% {
      width: 55px;
      right: 0px;
      top: 35px;
    }
    100% {
      width: 47px;
      right: 8px;
      top: 38px;
    }
  }
  @-webkit-keyframes animateTip {
    0% {
      width: 0;
      left: 1px;
      top: 19px;
    }
    54% {
      width: 0;
      left: 1px;
      top: 19px;
    }
    70% {
      width: 50px;
      left: -8px;
      top: 37px;
    }
    84% {
      width: 17px;
      left: 21px;
      top: 48px;
    }
    100% {
      width: 25px;
      left: 14px;
      top: 45px;
    }
  }
  @keyframes animateTip {
    0% {
      width: 0;
      left: 1px;
      top: 19px;
    }
    54% {
      width: 0;
      left: 1px;
      top: 19px;
    }
    70% {
      width: 50px;
      left: -8px;
      top: 37px;
    }
    84% {
      width: 17px;
      left: 21px;
      top: 48px;
    }
    100% {
      width: 25px;
      left: 14px;
      top: 45px;
    }
  }
  
  @-webkit-keyframes animateTip2 {
    0% {
      width: 0px;
      left: 132px;
      top: -138px;
    }
    100% {
      width: 50px;
      left: 16px;
      top: 38px;
    }
  }
  @keyframes animateTip2 {
    0% {
      width: 0px;
      left: 132px;
      top: -138px;
    }
    100% {
      width: 50px;
      left: 16px;
      top: 38px;
    }
  }
  @-webkit-keyframes animateTip3 {
    0% {
      width: 0px;
      left: 132px;
      top: 138px;
    }
    100% {
      width: 50px;
      left: 16px;
      top: 38px;
    }
  }
  @keyframes animateTip3 {
    0% {
      width: 0px;
      left: 132px;
      top: 138px;
    }
    100% {
      width: 50px;
      left: 16px;
      top: 38px;
    }
  }
  
  @keyframes animateLong {
    0% {
      width: 0;
      right: 46px;
      top: 54px;
    }
    65% {
      width: 0;
      right: 46px;
      top: 54px;
    }
    84% {
      width: 55px;
      right: 0px;
      top: 35px;
    }
    100% {
      width: 47px;
      right: 8px;
      top: 38px;
    }
  }
  
  .loader-alert-icon .loader-alert-line {
    height: 5px;
    display: block;
    border-radius: 2px;
    position: absolute;
    z-index: 2;
  }
  
  .loader-alert-icon .loader-alert-line.loader-alert-tip2 {
    width: 50px;
    left: 16px;
    top: 38px;
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
  }
  
  .loader-alert-icon .loader-alert-line.loader-alert-tip3 {
    width: 50px;
    left: 16px;
    top: 38px;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
  }
  
  .loader-alert-icon .loader-alert-line.loader-alert-tip {
    width: 25px;
    left: 14px;
    top: 46px;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
  }
  
  .loader-alert-icon .loader-alert-line.loader-alert-long {
    width: 47px;
    right: 8px;
    top: 38px;
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
  }
  
  @-webkit-keyframes rotatePlaceholder {
    0% {
      transform: rotate(-45deg);
      -webkit-transform: rotate(-45deg);
    }
    5% {
      transform: rotate(-45deg);
      -webkit-transform: rotate(-45deg);
    }
    12% {
      transform: rotate(-405deg);
      -webkit-transform: rotate(-405deg);
    }
    100% {
      transform: rotate(-405deg);
      -webkit-transform: rotate(-405deg);
    }
  }
  @keyframes rotatePlaceholder {
    0% {
      transform: rotate(-45deg);
      -webkit-transform: rotate(-45deg);
    }
    5% {
      transform: rotate(-45deg);
      -webkit-transform: rotate(-45deg);
    }
    12% {
      transform: rotate(-405deg);
      -webkit-transform: rotate(-405deg);
    }
    100% {
      transform: rotate(-405deg);
      -webkit-transform: rotate(-405deg);
    }
  }

.form-loader {
    width: var(--form-loader-dim); ;
    height: var(--form-loader-dim); ;
    border: 3px solid var(--form-loader-col);
    border-bottom-color: transparent;
    border-radius: 50%;
    display: inline-block;
    box-sizing: border-box;
    animation: fl-rotation 0.7s linear infinite;
    margin: var(--form-loader-margin) 0px;
}

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

.form-feedback-area
{
    margin-top: 5px;
    width: 100%;
    text-align: center;
}

.form-feedback-text
{
    text-align: center;
}