@import url('https://fonts.googleapis.com/css2?family=Nunito:ital,wght@0,200..1000;1,200..1000&family=Roboto+Flex:opsz,wght,XOPQ,XTRA,YOPQ,YTDE,YTFI,YTLC,YTUC@8..144,100..1000,96,468,79,-203,738,514,712&display=swap');

* {
    box-sizing: border-box;
	font-family: "Roboto Flex", -apple-system, BlinkMacSystemFont, "segoe ui", roboto, oxygen, ubuntu, cantarell, "fira sans", "droid sans", "helvetica neue", Arial, sans-serif;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

*:focus {
	outline: none !important;
	box-shadow: none !important;
}

input:focus, select:focus {
	border: 1px solid #3f70b2 !important;
}

body {
	background: #e7e9f0;
	color: #222c41;
	margin: 0;
}

a {
	color: #2c7aca;
	text-decoration: none;
}

.text-muted {
	color: #4b5872 !important;
}

.container {
	width: 95%;
	max-width: 1900px;
	margin: 0 auto;
	position: relative;
}

.text-success {
	color: #51ce57;
}

.text-danger {
	color: #ce5151;
}

.required-marker {
	font-weight: 800;
	color: #ce5151;
}

.helper {
	font-size: 13px !important;
}

.helper-danger {
	color: #ce5151;
}

.cents {
    vertical-align: super;
	font-size: 22px;
    top: 3px;
    display: inline-block;
    position: relative;
	underline: 3px solid currentColor;
}   

.two_number {
	font-family: 'Nunito', sans-serif;
	font-weight: 900;
}

#week_at_glance {
	position: fixed;
	bottom: 15px;
	right: 10px;
}

.show_week_glance {
	padding: 6px 20px;
	border-radius: 3px;
	color: #fff;
    background: #2c7aca;
    border: 1px solid #2c7aca;
	cursor: pointer;
}

.alert {
	padding: 10px 12px;
    border-radius: 5px;
	font-size: 16px;
    font-weight: 500;
	display: block;
	margin: 5px 0;
}

.global-alert {
	margin: 0;
	border-radius: 0;
	padding: 10px 0;
	font-size: 17px !important;
    font-weight: 500;
}

.alert-lg {
	padding: 15px 20px;
    border-radius: 5px;
	font-size: 18px !important;
}

.alert-lg * {
	font-size: 18px !important;
}

.alert-success {
	background-color: #51ce57;
    color: #fff;
}

.alert-danger {
	background-color: #ce5151;
    color: #fff;
}

.alert-warning {
	background-color: gold;
    color: #6c4f06;
}
.alert-warning a {
	 color: #6c4f06;
}

.lgspin123 {
	margin-right: 8px;
}

.btn {
	border: 0;
	border-radius: 0.25em;
	background: initial;
	font-size: 16px;
	padding: 10px 20px;
	text-align: center;
	cursor: pointer;
}

.btn-primary {
	background-color: #2c7aca;
	color: #fff;
}

.btn-primary:hover, .btn-primary:focus, .btn-primary:active {
	background-color: #266ab0;
}

.btn-danger {
	background-color: #ce5151;
	color: #fff;
}

.btn-gray {
	background-color: #ccc;
	color: #fff;
}

.btn-sm {
	font-size: 14px;
	padding: 6px 12px;
}

.info_icons {
	position: relative;
}

.info_icon {
	cursor: pointer;
	width: auto;
	display: inline-block;
	vertical-align: bottom;
	color: var(--accent-color-light);
	position: relative;
	top: 0;
	right: 0;
}

.info_icon .tooltip {
	position: absolute;
	background: #ffffa3;
	border: 1px solid #f1d031;
	min-width: 200px;
	color: #555555;
	padding: 5px 12px;
	z-index: 99;
	font-size: 13px;
	border-radius: 0;
	left: 6px;
	top: 25px;
	opacity: 1;
}

.info_icon .tooltip::before {
	content: "";
	width: 0px;
	height: 0px;
	border-style: solid;
	border-width: 0 13.5px 13px 13.5px;
	border-color: transparent transparent #ffffa3 transparent;
	transform: rotate(90deg);
	left: -7px;
	position: absolute;
	top: -1px;
	z-index: 9;
}

.info_icon .tooltip::after {
	content: "";
	width: 0px;
	height: 0px;
	border-style: solid;
	border-width: 0 13.5px 13px 13.5px;
	border-color: transparent transparent #f1d031 transparent;
	transform: rotate(90deg);
	left: -8px;
	position: absolute;
	top: -2px;
	z-index: 8;
}

.info_icon .tooltip.right {
	left: auto;
	right: 6px;
}

.info_icon .tooltip.right::before {
	transform: rotate(270deg);
	left: auto;
	right: -7px;
}

.info_icon .tooltip.right::after {
	transform: rotate(270deg);
	left: auto;
	right: -8px;
}

.info_icon.top .tooltip {
	display: block;
	bottom: 25px;
	top: auto;
}

.info_icon.top .tooltip::before {
	bottom: -1px;
	top: auto;
}

.info_icon.top .tooltip::after {
	bottom: -2px;
	top: auto;
}


.card {
	position: relative;
	margin-top: 20px;
	margin-bottom: 15px;
	border: 1px solid #e6e9ea;
	border-radius: 10px;
	padding: 20px 30px 30px;
	overflow: hidden
}

.card h2 {
	padding: 5px 0 20px !important;
	margin-bottom: 20px !important;
}

.card-icon {
	display: flex; justify-content: center; align-items: center;
}

.card-icon svg {
	margin: 0 auto;
}

.swal2-html-container {
	overflow-x: hidden !important;
}

.swal2-confirm {
	background: #2c7aca;
}

.swal2-confirm:hover {
	background: #266ab0;
}

h3.section-title {
	font-size: 26px;
	margin: 0 0 15px 0;
	font-family: 'Roboto Flex', sans-serif;
	color: #3b4656;
}

.navtop {
    background-color: #3f70b2;
    height: 70px;
    width: 100%;
    border: 0;
}

.navtop div {
    display: flex;
    margin: 0 auto;
    width: 95%;
	max-width: 1900px;
}

.navtop div h1, .navtop div a {
    display: inline-flex;
    align-items: center;
}

.navtop div h1 {
    flex: 1;
    font-size: 24px;
    padding: 0;
    margin: 0;
    color: #ebedee;
	line-height: 2.25em;
	font-family: 'Roboto Flex', sans-serif !important;
	font-weight: 800;
}

.navtop div h1 a {
	font-size: 24px;
	color: #fff;
	padding: 0;
}

.navtop div h1 img {
	max-height: 65px;
	margin: 5px 0;
}

.navtop div a {
    padding: 0 20px;
    text-decoration: none;
    color: #c4c8cc;
    font-weight: bold;
}

.navtop div a i {
    padding: 2px 8px 0 0;
}

.navtop div a:hover {
    color: #ebedee;
}

.content {
    width: 95%;
	max-width: 1900px;
    margin: 0 auto;
	padding-bottom: 40px;
}

#user-nav {
	position: absolute;
    right: 0;
    color: #fff;
    text-align: right;
    width: 200px;
    max-width: 200px;
    display: block;
    padding: 18px 0px;
	
}

#user-nav i {
	cursor: pointer;
	font-size: 24px;
	margin-left: 15px
}



#user-menu {
	position: absolute;
	background: #fff;
    text-align: left;
	top: 60px;
	right: 0px;
	border: 1px solid #ebedee;
	margin: 0;
	display: none;
	width: auto;
	min-width: 150px;
	z-index: 99;
}

#user-menu.open {
	display: block;
}

#user-menu ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

#user-menu  ul li {
	text-align: left;
}

#user-menu  ul li a:hover {
	color: #2c7aca;
}

#loginFrm {
	width: 90%;
	max-width: 300px;
	margin: 100px auto;
}

#loginFrm h1 {
	font-size: 34px;
	color: #3b4656;
    padding: 0;
    margin: 0;
	line-height: 2.25em;
	font-family: 'Roboto Flex', sans-serif !important;
	font-weight: 800;
	
}

.income-container {
	position: relative;
	margin-top: 20px;
	margin-bottom: 15px;
	border: 1px solid #cecfd7;
	border-radius: 3px;
	padding: 20px 30px 30px;
}

#addl_income .income-container {
    border-top: 0px solid #ccc;
}


#incomeFrm {
	width: 100%;
	max-width: 600px;
}

.income-container h3 {
	font-size: 16px;
	color: #333;
    font-weight: 400;
	margin: 0 0 20px;
}

.delete_incomeBtn { 
	position: absolute;
    top: -40px;
    right: -15px;
    color: #ccc;
    padding: 5px;
    cursor: pointer;
    
}

.edit_incomeBtn { 
	position: absolute;
    top: -40px;
    right: 20px;
    color: #ccc;
    padding: 5px;
    cursor: pointer;
    
}

.cancelIncomeEdit {
	display: none;
}

.delete_incomeBtn i, .edit_incomeBtn i { 
	font-size: 20px;
}

.delete_incomeBtn:hover  { 
	color: #ce5151;
}

.edit_incomeBtn:hover  { 
	color: #666;
}

.dow, .dom, .ccb {
	display: none;
}

.navtop #user-menu  ul li a {
	padding: 5px 15px !important;
}

.inc_text {
	position: relative;
}

.inc_text h4 {
	font-size: 26px;
	margin: 0 0 15px 0;
	font-family: 'Roboto Flex', sans-serif;
}

.inc_text .inc_amt {
	font-size: 17px;
	font-weight: 500;
	margin: 0 0 15px 0;
}

.inc_text .inc_freq {
	font-size: 14px;
	color: #666;
}

.content h2 {
    margin: 0;
    padding: 25px 0;
    font-size: 22px;
    border-bottom: 1px solid #ebebeb;
    color: #666666;
}

.mb-list {
	width: 300px;
	display: inline-block;
	vertical-align: top;
}

.mb-list h2 {
	position: relative;
}

.mb-list h2 .add-bill {
	position: absolute;
	color: #2c7aca;
	cursor: pointer;
	top: 33px;
    right: 0;
    font-size: 13px;
}

#wag-calendar .add_expense {
	color: #2c7aca;
	cursor: pointer;
    font-size: 14px;
}

#wag-calendar .add-bill {
	color: #2c7aca;
	cursor: pointer;
    font-size: 14px;
	margin-left: 10px;
}


.mb-calendar {
	width: calc(100% - 305px);
	display: inline-block;
	vertical-align: top;
	padding-left: 40px;
}

.calendar {
    display: flex;
    flex-flow: column;
}

.calendar .header .month-year {
    font-size: 20px;
    font-weight: bold;
    color: #636e73;
    padding: 20px 0;
	display: inline-block;
	width: calc(100% - 340px);
    vertical-align: middle;
	text-align: center;
	font-family: 'Roboto Flex', sans-serif;
}

.cal-nav {
	display: inline-block;
    width: 120px;
    vertical-align: middle;
	text-align: left;
	
}

.cal-nav a {
	display: inline-block;
	margin-left: 12px;
}

.cal-nav i {
	font-size: 22px;
}

.cal-nav2 {
	display: inline-block;
    width: 210px;
    vertical-align: middle;
	text-align: right;
	
}

.cal-nav2 span {
	color: #2c7aca;
	border: 1px solid #2c7aca;
	padding: 8px 15px;
	border-radius: 5px;
	cursor: pointer;
}

.cal-nav2 span.active {
	color: #fff;
	background: #2c7aca;
	border: 1px solid #2c7aca;
}

.cal-nav2:hover span.active {
	background: #266ab0;
}

.calendar .days {
    display: flex;
    flex-flow: wrap;
}

.calendar .days .day_name {
    width: calc(100% / 7);
    border-right: 1px solid #2c7aca;
    padding: 20px;
    text-transform: uppercase;
    font-size: 12px;
    font-weight: bold;
    color: #818589;
    color: #fff;
    background-color: #448cd6;
}

.calendar .days .day_name:nth-child(7) {
    border: none;
}

.calendar .days .day_num {
    display: flex;
    flex-flow: column;
    width: calc(100% / 7);
    border-right: 1px solid #cecfd7;
    border-bottom: 1px solid #cecfd7;
    padding: 15px;
    font-weight: bold;
    color: #7c878d;
    cursor: pointer;
    min-height: 100px;
}

.calendar .days .day_num span {
    display: inline-block;
    width: 22px;
	height: 22px;
	text-align: center;
	border-radius: 22px;
    font-size: 14px;
}

.calendar .days .day_num.payday span {
	background: #2c7aca;
	color: #fff;
}

.calendar .days .day_num .event {
    margin-top: 10px;
    font-weight: 500;
    font-size: 14px;
    padding: 3px 6px;
    border-radius: 4px;
    background-color: #f7c30d;
    color: #fff;
    word-wrap: break-word;
	transition: all 0.1s ease-in-out;
}

.calendar .days .day_num .event svg {
	height: 20px;
}

.calendar .days .day_num .event.grow {
	transform: scale(1.1);
}

.calendar .days .day_num .event.green {
    background-color: #51ce57;
}
.calendar .days .day_num .event.blue {
    background-color: #518fce;
}
.calendar .days .day_num .event.red {
    background-color: #ce5151;
}
.calendar .days .day_num .event.purple {
    background-color: #E936A7;
}
.calendar .days .day_num .event.dark-blue {
    background-color: #778BA5;
}
.calendar .days .day_num .event.light-blue {
    background-color: #50BFE6;
}
.calendar .days .day_num .event.mint {
    background-color: #30BFBF;
}
.calendar .days .day_num .event.paid {
    background-color: #c8c8c8;
}

.calendar .days .day_num .event.unpaid {
/*border: 4px solid indianred;*/
}



.calendar .days .day_num:nth-child(7n+1) {
    border-left: 1px solid #cecfd7;
}

.calendar .days .day_num:hover {
    background-color: #fdfdfd;
}

.calendar .days .day_num.ignore {
    background-color: #fdfdfd;
    color: #ced2d4;
    cursor: inherit;
}

.calendar .days .day_num.selected {
    background-color: #f6f8fc;
    cursor: inherit;
}

.paid-badge {
	background-color: #51ce57;
	color: #fff;
}

.unpaid-badge {
	background-color: #ce5151;
	color: #fff;
}

.paid-badge:hover, .unpaid-badge:hover {
	color: #fff;
}

.changePaymentStatus {
	cursor: pointer;
	margin: 0; 
}

.swal2-popup .changePaymentStatus:hover {
	color: #198754;
}

.archiveBill {
	cursor: pointer;
	margin: 0 0 0 15px; 
}

.bills-list .bill-details {
	cursor: pointer;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    width: 150px;
    position: relative;
    display: block;
}

.bill-details {
	cursor: pointer;
}

.amount-due:hover {
	cursor: pointer;
	text-decoration: underline;
}

.bills-list {
	width: 100%;
	border-collapse: collapse;
}

.bills-list tr:hover {
	background: #f6f8fc;
}

.bills-list td {
	padding: 4px;
}

.bills-list .bill-details {
	
}

.bills-list .bill-details:hover {
	text-decoration: underline;
}

.form-group {
	text-align: left;
	margin: 0 0 12px 0;
}

.form-group label {
	display: block;
	font-weight: 600;
	margin:  0 0 5px 0;
}

.form-control {
	border: 1px solid #cecfd7;
	padding: 10px;
	width: 100%;
	
}

.due_date, .dow, .start_date {
	display: none;
}

.chart {
	display: inline-block;
	vertical-align: top;
	width: 790px;
	margin-right: 25px;
}

.overview {
	display: inline-block;
	vertical-align: top;
	width: calc(100% - 820px);
}

.budget-expenses {
	width: 100%;
}

.budget-expenses td {
	padding: 5px;
	font-size: 19px;
}

.compare-table {
	margin: 25px 0; 
	width: 100%; 
	/*max-width: 950px;*/
	border-collapse: collapse;
}

.compare-table th {
	padding: 2px 5px;
}

.compare-table td {
	padding: 5px;
}

.compare-table tr:nth-child(even) {background: #f6f8fc}
.compare-table tr:nth-child(odd) {background: #FFF}

.add_expense {
	color: #2c7aca;
	cursor: pointer;
}
#bank_balance {
	max-width: 100px;
	border: 1px solid #cecfd7;
	display: inline-block;
}

#bank_balance_input {
	display: none;
}

.edit_bank_balance {
	color: #2c7aca;
	cursor: pointer;
	margin-left: 68px;
	margin-right: 10px;
}

#save_bank_balance {
	background: #2c7aca;
	color: #FFF;
	border: 0;
	cursor: pointer;
	border-radius: 3px;
}

#cancel_bank_balance {
	background: #ce5151;
	color: #FFF;
	border: 0;
	cursor: pointer;
	border-radius: 3px;
}

#calculator {
	display: none;
}

.calculator {
	position: fixed;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
    padding: 30px 10px 10px;
    border-radius: 1em;
    height: 380px;
    width: 400px;
    margin: auto;
    background-color: #f6f8fc;
    box-shadow: rgba(0, 0, 0, 0.19) 0px 10px 20px, rgba(0, 0, 0, 0.23) 0px 6px 6px;
}

.closeCalc {
	font-size: 35px;
    cursor: pointer;
    position: absolute;
    top: -5px;
    right: 12px;
}

.calculator td {
	width: 25%;
}

.history {
	text-align: right;
	height: 25px;
}

.display-box {
   	font-size: 50px;
    color: black;
    border-radius: 5px;
    width: 100%;
    height: 50px;
    font-weight: 600;
    border: 0;
    background-color: transparent;
    text-align: right;
    padding: 0;
}

.functionBtn {
    background-color: #f3f5f9 !important;
}

.calcBtn {
	background-color: #448cd6 !important;
	color: #fff !important;
}

input[type=button] {
    font-family: 'Orbitron', sans-serif;
    background-color: #fff;
    color: #000;
    border: solid #cecfd7 0.5px;
    width: 100%;
    border-radius: 5px;
    height: 55px;
    outline: none;
	cursor: pointer;
}

input:active[type=button], input:hover[type=button]  {
    background-color: #f3f5f9;
    border-color: #dfe2e3;
}

.functionBtn:active, .functionBtn:hover {
	background-color: #eff1f5 !important;
}

.subhead {
	font-size: 12px;
	color: #999;
}

.bighead, .bighead span {
	font-size: 26px !important;
	font-weight: 600;
}

/*** custom checkboxes ***/

.checkbox label {
	cursor: pointer;
}

.checkbox input[type=checkbox], .checkbox input[type=radio] {
	position: relative;
	width: 24px;
	height: 17px;
}

/* to hide the checkbox itself */
.checkbox label>input[type=checkbox]:before, .checkbox label>input[type=radio]:before {
	position: absolute;
	background-color: #FFFFFF;
	height: 22px;
	width: 22px;
	border: 1px solid #cecfd7;
	display: inline-block;
	content:"";
	cursor: pointer;
}

/* space between checkbox and label */
.checkbox label>input[type=checkbox]:checked:before, .checkbox label>input[type=radio]:checked:before {
	font-family: FontAwesome;
	display: inline-block;
	content:"\f00c";
	color: #2c7aca;
	border: 2px solid #cecfd7;
	line-height: 1.0em;
    text-align: center;
}


.checkbox label.is-invalid {
	color: #dc3545;
}

.checkbox label.is-invalid input[type=checkbox], .checkbox label.is-invalid input[type=radio] {

}

/* to hide the checkbox itself */
.checkbox label.is-invalid>input[type=checkbox]:before, .checkbox label.is-invalid>input[type=radio]:before {
	height: 22px;
	width: 22px;
	border: 1px solid #dc3545;
}

/* space between checkbox and label */
.checkbox label.is-invalid>input[type=checkbox]:checked:before, .checkbox label.is-invalid>input[type=radio]:checked:before {
	border: 1px solid #dc3545;
}
 
/* allow space for check mark */

/* ON/OFF Switch */
.onoffswitch {
  position: relative;
  width: 70px;
  display: inline-block;
  font-size: 80%;
}
.onoffswitch .onoffswitch-label {
  display: block;
  overflow: hidden;
  cursor: pointer;
  border: 1px solid hsl(0, 0%, 90%);
  -moz-border-radius: 20px;
  -webkit-border-radius: 20px;
  border-radius: 20px;
  margin: 0;
}
.onoffswitch .onoffswitch-inner {
  width: 200%;
  margin-left: -100%;
  -webkit-transition: margin 0.15s ease-in-out;
  -o-transition: margin 0.15s ease-in-out;
  -moz-transition: margin 0.15s ease-in-out;
  transition: margin 0.15s ease-in-out;
}
.onoffswitch .onoffswitch-inner:before,
.onoffswitch .onoffswitch-inner:after {
  float: left;
  width: 50%;
  height: 32px;
  padding: 0;
  line-height: 32px;
  font-size: 14px;
  color: hsl(0, 0%, 100%);
  font-weight: normal;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
.onoffswitch .onoffswitch-inner:before {
  content: "Yes";
  padding-left: 10px;
  background-color: hsl(203, 100%, 39.1569%);
  color: hsl(0, 0%, 100%);
}
.onoffswitch .onoffswitch-inner:after {
  content: "No";
  padding-right: 10px;
  background-color: hsl(0, 0%, 98%);
  color: hsl(0, 0%, 24%);
  text-align: right;
}
.onoffswitch .onoffswitch-switch {
  width: 30px;
  height: 30px;
  margin: 0;
  background: hsl(0, 0%, 100%);
  box-shadow: 0 0 3px rgba(0, 0, 0, 0.3);
  -moz-border-radius: 50%;
  -webkit-border-radius: 50%;
  border-radius: 50%;
  position: absolute;
  top: 2px;
  bottom: 0;
  right: 39px;
  -webkit-transition: right 0.15s ease-in-out;
  -o-transition: right 0.15s ease-in-out;
  -moz-transition: right 0.15s ease-in-out;
  transition: right 0.15s ease-in-out;
}
.toggle-group {
  position: relative;
  height: 35px;
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  top: 50%;
  left: 0px;
  margin-top: 0;
}
.toggle-group input[type=checkbox] {
  position: absolute;
  left: 10px;
}
.toggle-group input[type=checkbox]:checked ~ .onoffswitch .onoffswitch-label .onoffswitch-inner {
  margin-left: 0;
}
.toggle-group input[type=checkbox]:checked ~ .onoffswitch .onoffswitch-label .onoffswitch-switch {
  right: 1px;
  box-shadow: 0 0 3px rgba(0, 0, 0, 0.5);
}
.toggle-group input[type=checkbox]:focus ~ .onoffswitch {
  outline: thin dotted #333;
  outline: 0;
}
.toggle-group label {
  position: absolute;
  cursor: pointer;
  padding-left: 65px;
  display: inline-block;
  text-align: left;
  line-height: 24px;
  width: 100%;
  z-index: 1;
  height: 24px;
  font-weight: 200;
}
/* ==== Accessibility ===== */
.aural {
  clip: rect(1px, 1px, 1px, 1px);
  height: 1px;
  overflow: hidden;
  position: absolute;
  width: 1px;
}
.aural:focus {
  clip: rect(0, 0, 0, 0);
  font-size: 1em;
  height: auto;
  outline: thin dotted;
  position: static !important;
  width: auto;
  overflow: visible;
}

.cal_view .onoffswitch {
	width: 100px;
}
.cal_view .onoffswitch .onoffswitch-inner:before {
  content: "Monthly";
}

.cal_view .onoffswitch .onoffswitch-inner:after {
  content: "Weekly";
}

.cal_view .onoffswitch .onoffswitch-switch {
    right: 68px;
}

.tab-menu {
	display: flex;
    align-items: stretch; /* Default */
    justify-content: space-between;
    width: 100%;
	list-style: none;
	margin: 0;
	padding: 0;
	border-bottom: 1px solid #a1abb6;
	margin-bottom: 25px;
}

.tab-menu li {
	display: block;
    flex: 0 1 auto; /* Default */
    list-style-type: none;
	color: #595f65;
	padding: 15px 0;
	text-align: center;
	width: 100%;
	cursor: pointer;
	position: relative;
}

.tab-menu li:hover {
	color: #000;
	font-weight: 600;
}

.SELECTOR .tab-content {
	display: none;
}

.SELECTOR .tab-content.active {
	display: block;
}


/*
.tab-menu li:hover::after {
	content: "";
	border-bottom: 2px solid #1068eb;
	width: 100%;
    display: inline-block;
    position: absolute;
    bottom: -1px;
    right: 0;
}
*/

.tab-menu li.active {
	color: #000;
	font-weight: 600;
}

.tab-menu li.active::after {
	content: "";
	border-bottom: 3px solid #1068eb;
	width: 100%;
    display: inline-block;
    position: absolute;
    bottom: -1px;
    right: 0;
}

#donutchart {
	width: 730px; height: 450px;
}

.bill-wizard {
	
}

.bill-wizard h3 {
	margin: 0;
}

.bill-wizard .step-content h3 {
	margin: 0 0 20px 0;
}

.bill-wizard .step-selection .fa-circle-check, #setupWizard .fa-circle-check {
	font-size: 45px;
    vertical-align: sub;
}

.bill-wizard .disabled { 
	
}

#setupWizard .card.disabled {
	max-height: 250px;
}

.bill-wizard .disabled::after, #setupWizard .card.disabled::after  {
    background-image: linear-gradient( top, 
            rgba( 255, 255, 255, 0 ) -200%, 
            rgba( 255, 255, 255, 1 ) 100% );
        background-image: -moz-linear-gradient( top, 
            rgba( 255, 255, 255, 0 ) -200%, 
            rgba( 255, 255, 255, 1 ) 100% );
        background-image: -ms-linear-gradient( top, 
            rgba( 255, 255, 255, 0 ) -200%, 
            rgba( 255, 255, 255, 1 ) 100% );
        background-image: -o-linear-gradient( top, 
            rgba( 255, 255, 255, 0 ) -200%, 
            rgba( 255, 255, 255, 1 ) 100% );
        background-image: -webkit-linear-gradient( top, 
            rgba( 255, 255, 255, 0 ) -200%, 
            rgba( 255, 255, 255, 1 ) 100% );
	left: -1px;
    content: "\00a0";
    height: 95%;
    position: absolute;
    width: calc(100% + 2px);
	z-index: 99;
	bottom: -1px;
}

.bill-wizard .hidden, #setupWizard .hidden {
	display: none;
}

.change_selection {
	color: #2c7aca;
	cursor: pointer;
	font-weight: 700;
	text-decoration: underline;
	display: inline-block;
	margin-left: 20px;
	position: absolute;
    right: 20px;
    top: 35px;
	z-index: 3;
}

/* Setup Wizard Resets and styling */

.setup_title {
	position: absolute;
    z-index: 3;
    top: -30px;
    left: .75rem;
}

.sw {
    background: transparent;
    border: 0;
    border-radius: 0;
    box-shadow: none;
    overflow: hidden;
	top: -20px;
    position: relative;
	padding-top: 120px;
}

.sw > .nav {
	justify-content: center;
	position: absolute;
	top: 0;
	right: 0;
	z-index: 3;
	box-shadow: none !important;
}

.sw > .nav .nav-item {
	width: 175px;
	border-right: 0 !important;
}

.sw>.nav .nav-link.active {
	border: 0;
    box-shadow: none;
    background: transparent;
    color: #3f70b2;
	font-weight: 600;
}

.sw >.nav .nav-link.completed {
	background: transparent;
	border: 0;
	color: #3f70b2;
} 

.sw>.nav .nav-link {
	display: inline-block;
	background: transparent;
	color: #666;
}

.sw>.nav .nav-link > .badge {
	display: block;
	margin: 0 auto;
	height: 35px;
    width: 35px;
	line-height: 2em;
	font-size: 15px;
	background: #fff;
	border: 2px solid #999;
    color: #999;position: relative;
	z-index: 2;
}

.sw>.nav .nav-link.active .badge {
    background: #fff;
	border: 2px solid #3f70b2;
    color: #3f70b2;
}

.sw>.nav .nav-link.completed > .badge {
	background: #3f70b2;
	border: 2px solid #3f70b2;
    color: #fff;
}

.sw>.nav li:not(:last-child) .nav-link::after {
	content: "";
	display: block;
	height: 3px;
	width: calc(100% - 25px);
	/*background: #3f70b2;*/
	background: #ccc;
	position: absolute;
	top: 29px;
	left: 104px;
	z-index: 1;
}

.sw>.nav .nav-link:hover:not(.disabled) .badge::after {
  /*  transform: scale(1);*/
}


.sw>.nav .nav-link > .sw-nav-text {
	display: block;
	margin: 0 auto;
	font-size: 16px;
	text-align: center;
}

.sw>.tab-content {
    background: transparent;
	padding: 0;
	color: inherit;
}

.sw>.tab-content>.tab-pane {
	padding: 0;
}

.sw .toolbar {
    background: transparent;
}

.sw .toolbar {
	padding: 15px 0;
}

.sw .toolbar>.sw-btn {
    align-items: center;
    background: #3f70b2;
}

.sw .form-group.checkbox label {
	display: inline-block;
}

#site-url {
	display: none;
}

/* ================================== *\
    Mediaqueries
\* ================================== */
@media (max-width: 1500px) {
	.mb-list {
    	width: 250px;
	}
	.mb-calendar {
    	width: calc(100% - 255px);
	}
	.bills-list .bill-details {
    	width: 100px;
	}
}

@media (max-width: 667px) {
	.col-4, .col-6, .col-12 {
		display: block;
		width: 100%;
		margin: 0 !important; 
	}
	
	.mb-list {
    	width: 100%;
	}
	.mb-calendar {
    	width: 100%;
		padding-left: 0;
	}
	
	.cal-nav2 {
		display: none;
	}
	
	#month-calendar {
		display: none;
	}
	
	#week-calendar {
		display: block;
	}
	
	#month-calendar, #week-calendar {
		overflow-x: auto;
	}
	
	#donutchart {
		width: 600px; height: 450px;
	}
	
	.chart {
		width: 100%;
	}
	
	.overview {
		width: 100%;
	}
}


@media (max-width: 400px) {
	#donutchart {
		width: 300px; height: 250px;
	}
}
