@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@500;600;800;900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@500;600;700;800;900&family=Poppins:wght@500;600;800;900&display=swap');

* {
  box-sizing: border-box;
  padding: 0px;
  margin: 0px;
}

*:after,
*::before {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  margin: 0px;
  padding: 0px;
}

html {
  scroll-behavior: smooth;
}

:root {
  --primary-textcolor: #9B51E0;
  --success-textcolor: #30B21A;
  --primary-bgGray: #e1e1e7;
  --primary-textSecondary: #919397;
  --primary-fontFamily: 'Poppins';
  --secondary-fontFamily: 'Inter';
}

.btn-app-outline {
  border: 1px solid var(--primary-textcolor) !important;
  transition: 0.3s ease-in;
  font-size: 14px;
  font-weight: 600;
}

.btn-app-outline:hover {
  background-color: var(--primary-textcolor);
  color: #fff;
}

/* Transition css */
.slide-fade-enter-active {
  transition: all 0.5s ease-in-out;
}

.slide-fade-enter-from,
.slide-fade-leave-to {
  transform: translateX(-40px);
  opacity: 0;
}

/* Guest Navbar Design ************************** */

#top-navbar .navbar {
  background-color: #fff !important;
}

#top-navbar .circle-logo {
  width: 34px;
  height: 34px;
  background-color: var(--primary-textcolor);
  border-radius: 50%;
}

#top-navbar {
  position: relative;
  z-index: 1 !important;
}

#top-navbar .navbar-toggler:focus {
  box-shadow: none;
  border: 1px solid var(--primary-textcolor);
}

#top-navbar .navbar-toggler {
  padding: 8px 10px !important;
}

#top-navbar .navbar-toggler .navbar-toggler-icon {
  font-size: 16px !important;
}

.common{
  color: var(--success-textcolor)
}

/* Register/Login Page ************************** */
.sign-page {
  font-family: var(--secondary-fontFamily);
  height: 100vh !important;
}

.sign-page .title {
  font-size: 38px;
  font-weight: 700;
  line-height: 48px;
  color: #4c4b4b !important;
}

.sign-page .color-title {
  color: var(--success-textcolor)
}


.sign-page .detail {
  font-size: 22px;
  font-weight: 500;
  width: 75%;
  line-height: 30px;
}


.sign-page .right-side {
  background-color: var(--primary-textcolor);
}

.sign-page .right-side .page-title {
  font-size: 30px;
  font-weight: 600;
}

.sign-page .right-side .form-container {
  background-color: var(--primary-textcolor);
  padding-bottom: 1em;
}

.sign-page .right-side .form-container label {
  font-size: 14px;
  letter-spacing: 1px;
  margin-top: 7px;
  margin-bottom: 3px;
  color: #e0e3f4;
}

.sign-page .right-side .form-container .form-control {
  background-color: #e2d8eb !important;
  color: #000;
  border: none;
}

.sign-page .right-side .form-container .form-control:focus {
  border: 0px !important;
  outline: none;
}

.sign-page .right-side .sign-btn {
  background: #fff;
  padding: 5px 0px;
  color: var(--primary-textcolor);
  transition: 0.5s ease;
  border: 1px solid var(--primary-textcolor);
}

.sign-page .right-side .sign-btn:hover {
  color: #fff;
  background: var(--primary-textcolor);
  border: 1px solid #fff;
}

.active-top-nav{
  /* color: var(--primary-textcolor) !important; */
  font-weight: bold;
}

/* static pAges ********************* */
.static-page{
  font-family: var(--secondary-fontFamily);
}

.static-page p{
  font-size: 16px;
  line-height: 28px;
  margin-bottom: 0.8em;
}

/* Sidebar Design************************************* */
.circle-logo {
  width: 34px;
  height: 34px;
  background-color: var(--primary-textcolor);
  border-radius: 50%;
}

.app-nav .nav-link.active {
  color: #ffffff !important;
  background: var(--primary-textcolor);
  border-left: 4px solid #a583eae8 !important;
  font-weight: 500;
}

.app-nav .nav-item .nav-link:hover {
  color: var(--primary-textcolor)
}

.app-nav .nav-item .nav-icon {
  font-size: 17px !important;
}

/* Dashboard CSS ************************************/
.dashboard_layout {
  color: #000;
  font-family: var(--primary-fontFamily) !important;
}

.stat_container {
  background-color: #fff;
  padding: 14px;
  border: 1px solid var(--primary-bgGray);
}

.stat_container:hover {
  box-shadow: rgba(100, 100, 111, 0.2) 0px 7px 29px 0px;
}

.stat_container .stat_content .title {
  font-size: 17px;
  font-weight: 600;
}

.stat_container .stat_content .amount {
  font-size: 30px;
  font-weight: 800;
}

.stat_container img {
  width: 50px;
  height: 50px;
}

/* Line progress stat */
.stat_container .progress_content .title {
  font-size: 17px;
  font-weight: 600;
}

.stat_container .progress_content .wheel_date {
  font-size: 14px;
  font-weight: 500;
  margin: 4px 0px;
}

.stat_container .line_progress .progress-bar {
  background-color: var(--primary-textcolor);
}

/* Category expense container */

.category_expense_container .heading {
  font-weight: 600;
  font-size: 18px;
  display: block;
}

.category_expense_container .subtitle {
  font-weight: 500;
  font-size: 14px;
}

.category_expense_container .category_expense_container_inner {
  margin-top: 12px;
  border-bottom: 1px solid var(--primary-bgGray);
  padding-bottom: 5px;
}

.category_expense_container .category_expense_container_inner .title {
  font-size: 15px;
  font-weight: 500;
}

.category_expense_container .category_expense_container_inner .date {
  font-size: 13px;
  font-weight: 500;
}

/* Progress circle */

/* .progress_circle_container .progress {
  width: 120px;
  height: 120px;
  line-height: 120px;
  background: none;
  margin: 0 auto;
  box-shadow: none;
  position: relative;
}

.progress_circle_container .progress:after {
  content: "";
  width: 100%;
  height: 100%;
  border-radius: 50%;
  border: 12px solid var(--primary-bgGray);
  position: absolute;
  top: 0;
  left: 0;
}

.progress_circle_container .progress>span {
  width: 50%;
  height: 100%;
  overflow: hidden;
  position: absolute;
  top: 0;
  z-index: 1;
}

.progress_circle_container .progress .progress-left {
  left: 0;
}

.progress_circle_container .progress .progress-bar {
  width: 100%;
  height: 100%;
  background: none;
  border-width: 10px;
  border-style: solid;
  position: absolute;
  top: 0;
}

.progress_circle_container .progress .progress-left .progress-bar {
  left: 100%;
  border-top-right-radius: 80px;
  border-bottom-right-radius: 80px;
  border-left: 0;
  -webkit-transform-origin: center left;
  transform-origin: center left;
}

.progress_circle_container .progress .progress-right {
  right: 0;
}

.progress_circle_container .progress .progress-right .progress-bar {
  left: -100%;
  border-top-left-radius: 80px;
  border-bottom-left-radius: 80px;
  border-right: 0;
  -webkit-transform-origin: center right;
  transform-origin: center right;
  animation: loading-1 1.8s linear forwards;
}

.progress_circle_container .progress .progress-value {
  width: 95%;
  height: 95%;
  border-radius: 50%;
  background: #ffffff;
  font-size: 20px;
  line-height: 127px;
  text-align: center;
  position: absolute;
  top: 0%;
  left: 5%;
}

.progress_circle_container .progress.blue .progress-bar {
  border-color: var(--primary-textcolor);
} */

/* .progress_circle_container .progress.blue .progress-left .progress-bar {
  animation: loading-2 1.5s linear forwards 1.8s;
} */

/* @keyframes loading-1 {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }

  100% {
    -webkit-transform: rotate(120deg);
    transform: rotate(120deg);
  }
} * */

/* @keyframes loading-2{
  0%{
      -webkit-transform: rotate(0deg);
      transform: rotate(0deg);
  }
  100%{
      -webkit-transform: rotate(144deg);
      transform: rotate(144deg);
  }
}
@keyframes loading-3{
  0%{
      -webkit-transform: rotate(0deg);
      transform: rotate(0deg);
  }
  100%{
      -webkit-transform: rotate(90deg);
      transform: rotate(90deg);
  }
}
@keyframes loading-4{
  0%{
      -webkit-transform: rotate(0deg);
      transform: rotate(0deg);
  }
  100%{
      -webkit-transform: rotate(36deg);
      transform: rotate(36deg);
  }
}
@keyframes loading-5{
  0%{
      -webkit-transform: rotate(0deg);
      transform: rotate(0deg);
  }
  100%{
      -webkit-transform: rotate(126deg);
      transform: rotate(126deg);
  }
}

/* end circle */


/* Income Layout Css Start ********************** */
.basic-page-layout {
  font-family: var(--secondary-fontFamily);
}

.basic-page-layout .form-control {
  line-height: 1.2rem !important;
  text-transform: capitalize !important;
}

.basic-page-layout .top-heading {
  font-weight: 700;
  font-size: 24px;
  margin-bottom: 1.3rem;
}

.basic-page-layout label {
  font-size: 14px;
  font-weight: 500;
  margin-bottom: 6px;
}

.basic-page-layout input::placeholder {
  color: var(--primary-textSecondary);
}

.basic-page-layout .form-control {
  border: 1px solid var(--primary-bgGray) !important;
}

.basic-page-layout .form-control:focus {
  box-shadow: none !important;
}

.basic-page-layout .total-amount-box {
  font-size: 22px;
  font-weight: 800;
  color: #343434;
}


.basic-page-layout .error {
  font-size: 12px;
  color: red;
}

.basic-page-layout .trash-btn {
  border: 1px solid red;
  color: red;
  font-size: 12px;
  padding: 5px;
  border-radius: 5px;
}

/* Expense Layout ********************************/

.tab_navbar button {
  font-size: 15px;
  font-weight: 500;
}

.tab_navbar .active-tab {
  color: var(--primary-textcolor);
  border-bottom: 2px solid var(--primary-textcolor);
}

.expense-layout .alert-message {
  font-size: 14px;
}

.basic-page-layout table thead th {
  font-size: 14px;
  font-weight: 500;
}

.basic-page-layout table thead {
  background-color: var(--primary-bgGray);
}

.basic-page-layout table .coloerd-cell {
  background-color: #efeaeac8;
}

.hr-style {
  border: 2px solid var(--primary-textcolor);
}

/* Netwoth****************** */
.networth-layout .total-annual-saving {
  font-weight: 800;
  border: 1px solid var(--success-textcolor);
}

.networth-layout .total-annual-saving h6 {
  color: var(--success-textcolor);
  font-size: 30px;
}

.networth-layout .total-debit {
  font-size: 30px;
  font-weight: 800;
  border: 1px solid #FF0800;
}

.networth-layout .total-existingSavings {
  font-size: 30px;
  font-weight: 800;
  border: 1px solid #1cf4b3;
}

.networth-layout .total-existingSavings h6 {
  color: #1cf4b3;
  font-size: 30px;
}

.networth-layout .total-debit h6 {
  color: #FF0800;
  font-size: 30px;
}

.networth-layout .total-networth {
  font-weight: 800;
  border: 1px solid #0070FF;
}

.networth-layout .total-networth h6 {
  color: #0070FF;
  font-size: 30px;
}

/* End  */

/* Profile user */
.user-profile .profile-input {
  border: none;
  color: #9fa7b5;
}

.user-profile .input-group-text {
  border: none;
  background-color: transparent;
}
.user-profile label {
  cursor: pointer;
  font-weight: 500;
}
.user-profile .form-control:focus {
  outline: none !important;
  box-shadow: none !important;
}
.user-profile .error-profile {
  font-size: 12px;
}


