/* Sini Colors */
/* Global colors */
.sini-fg-pink {
  color: #D7006C !important; }

.sini-fg-white {
  color: white !important; }

.sini-fg-primary {
  color: #D7006C !important; }

.sini-fg-red {
  color: #AA1919 !important; }

.sini-fg-blue {
  color: #1986AA !important; }

.sini-fg-purple {
  color: #971AB3 !important; }

.sini-fg-green {
  color: #19AA73 !important; }

.sini-fg-grey {
  color: #9BA3A0 !important; }

.sini-fg-brown {
  color: #AA7019 !important; }

.sini-fg-orange {
  color: #DE8B29 !important; }

.sini-bg-pink {
  background-color: #D7006C !important; }

.sini-bg-white {
  background-color: white !important; }

.sini-bg-primary {
  background-color: #D7006C !important; }

.sini-bg-red {
  background-color: #AA1919 !important; }

.sini-bg-blue {
  background-color: #1986AA !important; }

.sini-bg-purple {
  background-color: #971AB3 !important; }

.sini-bg-green {
  background-color: #19AA73 !important; }

.sini-bg-grey {
  background-color: #9BA3A0 !important; }

.sini-bg-brown {
  background-color: #AA7019 !important; }

.sini-bg-orange {
  background-color: #DE8B29 !important; }

.sini-bg-smoke {
  background-color: #f1f1f1 !important; }

/* Grid */
.font-weight-normal {
  font-weight: 400; }

.font-weight-600 {
  font-weight: 600; }

.font-weight-500 {
  font-weight: 500; }

.font-weight-400 {
  font-weight: 400; }

.font-40 {
  font-size: 40px; }

.font-38 {
  font-size: 38px; }

.font-36 {
  font-size: 36px; }

.font-34 {
  font-size: 34px; }

.font-32 {
  font-size: 32px; }

.font-30 {
  font-size: 30px; }

.font-28 {
  font-size: 28px; }

.font-26 {
  font-size: 26px; }

.font-24 {
  font-size: 24px; }

.font-22 {
  font-size: 22px; }

.font-20 {
  font-size: 20px; }

.font-18 {
  font-size: 18px; }

.font-16 {
  font-size: 1rem; }

.font-15 {
  font-size: 0.9375rem; }

.font-14 {
  font-size: 0.875rem; }

.font-13 {
  font-size: 0.8125rem; }

.font-12 {
  font-size: 0.75rem; }

html, body {
  position: relative;
  min-height: 100%;
  margin: 0;
  padding: 0;
  font-family: 'open sans', 'Helvetica Neue', Helvetica, Arial, sans-serif;
  font-size: 1em !important; }

html {
  height: 100%; }

div.app-splash {
  height: 100%;
  width: 100%;
  position: absolute; }
  div.app-splash .loading-container {
    display: flex;
    height: 100%;
    align-items: center;
    justify-content: center;
    flex-direction: column; }
    div.app-splash .loading-container img {
      margin-top: -100px;
      width: 150px; }
    div.app-splash .loading-container .loading {
      margin-left: -20px;
      margin-top: 15px;
      border-radius: 50%;
      width: 24px;
      height: 24px;
      border: .25rem solid #cac3c6;
      border-top-color: #D7006C;
      animation: spin 1s infinite linear; }

body {
  min-width: 1280px;
  color: #464646; }
  body div.sini-main-container {
    width: 100%;
    font-size: 0.8125rem;
    padding-bottom: 3.5rem; }
  body .app-footer {
    width: 100%;
    font-size: 0.8125rem;
    position: absolute;
    bottom: 0;
    padding: 0.5rem 0.9375rem;
    background-color: white;
    border-top: 1px solid #e7eaec; }
    body .app-footer .developed-by span {
      display: inline-block;
      padding-right: 2px; }
      body .app-footer .developed-by span .company-name {
        letter-spacing: 1px; }

input {
  padding: 3px;
  outline: none;
  border: solid 1px silver; }
  input:focus {
    border: solid 1px #555555 !important;
    outline: none !important; }

a, a:visited, a:hover, a:active {
  color: inherit;
  text-decoration: inherit; }

.clearfix:after {
  content: "";
  display: block;
  clear: both;
  visibility: hidden;
  line-height: 0;
  height: 0; }

.user-select-none {
  user-select: none; }

.avoid-clicks {
  pointer-events: none; }

.user-events-none {
  user-events: none; }

.display-none {
  display: none; }

.inline-block {
  display: inline-block; }

.cursor {
  cursor: pointer; }

.cursor-pointer {
  cursor: pointer; }

.hidden, .print {
  display: none; }

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

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

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

.text-capitalize {
  text-transform: capitalize; }

.text-uppercase {
  text-transform: uppercase; }

.text-lowercase {
  text-transform: lowercase; }

.text-underline {
  text-decoration: underline; }

.visible {
  visibility: visible; }

.invisible {
  visibility: hidden; }

.width-inherit {
  width: inherit; }

.numb-opacity-30 {
  pointer-events: none;
  opacity: .3; }

.sini-blue {
  color: #1986AA; }

.sini-green {
  color: #19AA73; }

.pull-right {
  float: right !important; }

.pull-left {
  float: left !important; }

.full-height {
  min-height: 100%;
  height: 100%; }

.full-width {
  min-width: 100%;
  width: 100%; }

.width-780 {
  width: 780px !important; }

.width-960 {
  width: 960px !important; }

.width-100-percent {
  width: 100%; }

.width-80-percent {
  width: 80%; }

.height-100-percent {
  height: 100%; }

input, textarea, select {
  outline: none;
  font-size: 0.8125rem; }
  input:focus, textarea:focus, select:focus {
    outline: none; }

textarea:focus {
  border: solid 1px #555555 !important;
  outline: none !important; }

.dashed-border-top {
  border-top: dashed 1px #909090; }

.dashed-border-bottom {
  border-bottom: dashed 1px #909090; }

.solid-border-top {
  border-top: solid 1px #909090; }

.solid-border-bottom {
  border-bottom: solid 1px #909090; }

.tr-height-4 {
  height: .25rem; }

.tr-height-8 {
  height: .5rem; }

.tr-height-12 {
  height: .75rem; }

.tr-height-16 {
  height: 1rem; }

.main-view-container > .page {
  width: 100%;
  padding-left: 1rem;
  padding-right: 1rem; }
  .main-view-container > .page .panel-content {
    min-height: 100px; }

.popover {
  max-width: 400px; }

input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
  /* display: none; <- Crashes Chrome on hover */
  -webkit-appearance: none;
  margin: 0;
  /* <-- Apparently some margin are still there even though it's hidden */ }

.border-underline {
  border-bottom: solid 1px silver; }

.sini-label {
  padding: .1875rem .5rem;
  color: white;
  border-radius: 2px;
  background-color: #e2e2e2;
  font-weight: 600; }
  .sini-label.red {
    background-color: #AA1919; }
  .sini-label.blue {
    background-color: #1986AA; }
  .sini-label.green {
    background-color: #19AA73; }
  .sini-label.orange {
    background-color: #DE8B29; }
  .sini-label.pink {
    background-color: #D7006C; }
  .sini-label.grey {
    background-color: #9BA3A0; }
  .sini-label.purple {
    background-color: #971AB3; }
  .sini-label.brown {
    background-color: #AA7019; }

.transparent-when-disabled:disabled {
  pointer-events: none;
  border: solid 1px transparent;
  background-color: transparent;
  box-shadow: none; }

select.transparent-when-disabled:disabled {
  border: none;
  box-shadow: none;
  outline: none;
  box-shadow: none; }

.transform-rotate-180 {
  transform: rotate(-180deg);
  transition: 0.5s; }

.link {
  color: #1986AA; }
  .link:hover {
    text-decoration: underline;
    cursor: pointer; }

.form-reset {
  min-height: 2rem; }
  .form-reset i {
    cursor: pointer;
    padding-left: 1rem;
    padding-right: 1rem;
    display: inline-block;
    margin-top: -3px; }

/* @see https://stackoverflow.com/questions/306252/how-to-align-checkboxes-and-their-labels-consistently-cross-browsers */
div.lovelace-simple-label-checkbox label {
  display: block;
  padding-left: 15px;
  text-indent: -15px; }

div.lovelace-simple-label-checkbox input {
  width: 13px;
  height: 13px;
  padding: 0;
  margin: 0;
  vertical-align: bottom;
  position: relative;
  top: -1px;
  *overflow: hidden; }

.panel-navbar {
  min-height: inherit;
  border: none;
  border-radius: 0;
  margin-bottom: 0;
  background-color: white;
  border-bottom: 1px solid #ddd; }
  .panel-navbar .navbar-nav > li {
    display: inline; }
  .panel-navbar .navbar-nav > li > a {
    font-size: .8rem;
    color: inherit;
    padding-top: 10px;
    padding-bottom: 10px;
    border-bottom: solid 3px transparent; }
    .panel-navbar .navbar-nav > li > a:focus {
      background-color: white; }
    .panel-navbar .navbar-nav > li > a.active {
      border-bottom: solid 3px #D7006C; }
  .panel-navbar .navbar-nav > li.active > a {
    font-size: .8rem;
    background-color: #a40052; }

.margin-left--15 {
  margin-left: -15px !important; }

.margin-right--15 {
  margin-right: -15px !important; }

.padding-0 {
  padding: 0 !important; }

.padding-5 {
  padding: 5px !important; }

.padding-10 {
  padding: 0.625rem !important; }

.padding-15 {
  padding: 0.9375rem !important; }

.padding-20 {
  padding: 1.25rem !important; }

.padding-30 {
  padding: 1.875rem !important; }

.padding-40 {
  padding: 2.5rem !important; }

.padding-50 {
  padding: 3.125rem !important; }

.padding-60 {
  padding: 3.75rem !important; }

.padding-70 {
  padding: 4.375rem !important; }

.padding-80 {
  padding: 5rem !important; }

.padding-90 {
  padding: 5.625rem !important; }

.padding-100 {
  padding: 6.25rem !important; }

.padding-top-0 {
  padding-top: 0 !important; }

.padding-top-5 {
  padding-top: 5px !important; }

.padding-top-10 {
  padding-top: 0.625rem !important; }

.padding-top-15 {
  padding-top: 0.9375rem !important; }

.padding-top-20 {
  padding-top: 1.25rem !important; }

.padding-top-30 {
  padding-top: 1.875rem !important; }

.padding-top-40 {
  padding-top: 2.5rem !important; }

.padding-top-50 {
  padding-top: 3.125rem !important; }

.padding-top-60 {
  padding-top: 3.75rem !important; }

.padding-top-70 {
  padding-top: 4.375rem !important; }

.padding-top-80 {
  padding-top: 5rem !important; }

.padding-top-90 {
  padding-top: 5.625rem !important; }

.padding-top-100 {
  padding-top: 6.25rem !important; }

.padding-left-0 {
  padding-left: 0px !important; }

.padding-left-5 {
  padding-left: 5px !important; }

.padding-left-15 {
  padding-left: 0.9375rem !important; }

.padding-left-10 {
  padding-left: 0.625rem !important; }

.padding-left-20 {
  padding-left: 1.25rem !important; }

.padding-left-30 {
  padding-left: 1.875rem !important; }

.padding-left-40 {
  padding-left: 2.5rem !important; }

.padding-left-50 {
  padding-left: 3.125rem !important; }

.padding-left-60 {
  padding-left: 3.75rem !important; }

.padding-left-70 {
  padding-left: 4.375rem !important; }

.padding-left-80 {
  padding-left: 5rem !important; }

.padding-left-90 {
  padding-left: 5.625rem !important; }

.padding-left-100 {
  padding-left: 6.25rem !important; }

.padding-right-0 {
  padding-right: 0px !important; }

.padding-right-5 {
  padding-right: 5px !important; }

.padding-right-10 {
  padding-right: 0.625rem !important; }

.padding-right-15 {
  padding-right: 0.9375rem !important; }

.padding-right-20 {
  padding-right: 1.25rem !important; }

.padding-right-30 {
  padding-right: 1.875rem !important; }

.padding-right-40 {
  padding-right: 2.5rem !important; }

.padding-right-50 {
  padding-right: 3.125rem !important; }

.padding-right-60 {
  padding-right: 3.75rem !important; }

.padding-right-70 {
  padding-right: 4.375rem !important; }

.padding-right-80 {
  padding-right: 5rem !important; }

.padding-right-90 {
  padding-right: 5.625rem !important; }

.padding-right-100 {
  padding-right: 6.25rem !important; }

.padding-bottom-0 {
  padding-bottom: 0px !important; }

.padding-bottom-5 {
  padding-bottom: 5px !important; }

.padding-bottom-10 {
  padding-bottom: 0.625rem !important; }

.padding-bottom-15 {
  padding-bottom: 0.9375rem !important; }

.padding-bottom-20 {
  padding-bottom: 1.25rem !important; }

.padding-bottom-30 {
  padding-bottom: 1.875rem !important; }

.padding-bottom-40 {
  padding-bottom: 2.5rem !important; }

.padding-bottom-50 {
  padding-bottom: 3.125rem !important; }

.padding-bottom-60 {
  padding-bottom: 3.75rem !important; }

.padding-bottom-70 {
  padding-bottom: 4.375rem !important; }

.padding-bottom-80 {
  padding-bottom: 5rem !important; }

.padding-bottom-90 {
  padding-bottom: 5.625rem !important; }

.padding-bottom-100 {
  padding-bottom: 6.25rem !important; }

.margin-0 {
  margin: 0px !important; }

.margin-5 {
  margin: 5px !important; }

.margin-10 {
  margin: 0.625rem !important; }

.margin-15 {
  margin: 0.9375rem !important; }

.margin-20 {
  margin: 1.25rem !important; }

.margin-30 {
  margin: 1.875rem !important; }

.margin-40 {
  margin: 2.5rem !important; }

.margin-50 {
  margin: 3.125rem !important; }

.margin-60 {
  margin: 3.75rem !important; }

.margin-70 {
  margin: 4.375rem !important; }

.margin-80 {
  margin: 5rem !important; }

.margin-90 {
  margin: 5.625rem !important; }

.margin-100 {
  margin: 6.25rem !important; }

.margin-top-0 {
  margin-top: 0px !important; }

.margin-top-5 {
  margin-top: 5px !important; }

.margin-top-10 {
  margin-top: 0.625rem !important; }

.margin-top-15 {
  margin-top: 0.9375rem !important; }

.margin-top-20 {
  margin-top: 1.25rem !important; }

.margin-top-30 {
  margin-top: 1.875rem !important; }

.margin-top-40 {
  margin-top: 2.5rem !important; }

.margin-top-50 {
  margin-top: 3.125rem !important; }

.margin-top-60 {
  margin-top: 3.75rem !important; }

.margin-top-70 {
  margin-top: 4.375rem !important; }

.margin-top-80 {
  margin-top: 5rem !important; }

.margin-top-90 {
  margin-top: 5.625rem !important; }

.margin-top-100 {
  margin-top: 6.25rem !important; }

.margin-bottom-0 {
  margin-bottom: 0px !important; }

.margin-bottom-5 {
  margin-bottom: 5px !important; }

.margin-bottom-10 {
  margin-bottom: 0.625rem !important; }

.margin-bottom-15 {
  margin-bottom: 0.9375rem !important; }

.margin-bottom-20 {
  margin-bottom: 1.25rem !important; }

.margin-bottom-30 {
  margin-bottom: 1.875rem !important; }

.margin-bottom-40 {
  margin-bottom: 2.5rem !important; }

.margin-bottom-50 {
  margin-bottom: 3.125rem !important; }

.margin-bottom-60 {
  margin-bottom: 3.75rem !important; }

.margin-bottom-70 {
  margin-bottom: 4.375rem !important; }

.margin-bottom-80 {
  margin-bottom: 5rem !important; }

.margin-bottom-90 {
  margin-bottom: 5.625rem !important; }

.margin-bottom-100 {
  margin-bottom: 6.25rem !important; }

.margin-right-0 {
  margin-right: 0px !important; }

.margin-right-5 {
  margin-right: 5px !important; }

.margin-right-10 {
  margin-right: 0.625rem !important; }

.margin-right-15 {
  margin-right: 0.9375rem !important; }

.margin-right-20 {
  margin-right: 1.25rem !important; }

.margin-right-30 {
  margin-right: 1.875rem !important; }

.margin-right-40 {
  margin-right: 2.5rem !important; }

.margin-right-50 {
  margin-right: 3.125rem !important; }

.margin-right-60 {
  margin-right: 3.75rem !important; }

.margin-right-70 {
  margin-right: 4.375rem !important; }

.margin-right-80 {
  margin-right: 5rem !important; }

.margin-right-90 {
  margin-right: 5.625rem !important; }

.margin-right-100 {
  margin-right: 6.25rem !important; }

.margin-left-0 {
  margin-left: 0px !important; }

.margin-left-5 {
  margin-left: 5px !important; }

.margin-left-10 {
  margin-left: 0.625rem !important; }

.margin-left-15 {
  margin-left: 0.9375rem !important; }

.margin-left-20 {
  margin-left: 1.25rem !important; }

.margin-left-30 {
  margin-left: 1.875rem !important; }

.margin-left-40 {
  margin-left: 2.5rem !important; }

.margin-left-50 {
  margin-left: 3.125rem !important; }

.margin-left-60 {
  margin-left: 3.75rem !important; }

.margin-left-70 {
  margin-left: 4.375rem !important; }

.margin-left-80 {
  margin-left: 5rem !important; }

.margin-left-90 {
  margin-left: 5.625rem !important; }

.margin-left-100 {
  margin-left: 6.25rem !important; }

.font-weight-100 {
  font-weight: 100; }

.font-weight-200 {
  font-weight: 200; }

.font-weight-300 {
  font-weight: 300; }

.font-weight-400 {
  font-weight: 400; }

.font-weight-500 {
  font-weight: 500; }

.font-weight-600 {
  font-weight: 600; }

.font-weight-700 {
  font-weight: 700; }

.font-weight-800 {
  font-weight: 800; }

.font-weight-900 {
  font-weight: 900; }

/*
    Flaticon icon font: Flaticon
    Creation date: 07/12/2017 09:23
    */
@font-face {
  font-family: "Flaticon";
  src: url("./Flaticon.eot");
  src: url("./Flaticon.eot?#iefix") format("embedded-opentype"), url("./Flaticon.woff") format("woff"), url("./Flaticon.ttf") format("truetype"), url("./Flaticon.svg#Flaticon") format("svg");
  font-weight: normal;
  font-style: normal; }

@media screen and (-webkit-min-device-pixel-ratio: 0) {
  @font-face {
    font-family: "Flaticon";
    src: url("./Flaticon.svg#Flaticon") format("svg"); } }

.fi:before {
  display: inline-block;
  font-family: "Flaticon";
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  line-height: 1;
  text-decoration: inherit;
  text-rendering: optimizeLegibility;
  text-transform: none;
  -moz-osx-font-smoothing: grayscale;
  -webkit-font-smoothing: antialiased;
  font-smoothing: antialiased; }

.flaticon-kids-couple:before {
  content: "\f100"; }

.flaticon-cake:before {
  content: "\f101"; }

.flaticon-laughing:before {
  content: "\f102"; }

.flaticon-crying:before {
  content: "\f103"; }

.flaticon-happy-2:before {
  content: "\f104"; }

.flaticon-nervous-1:before {
  content: "\f105"; }

.flaticon-calm:before {
  content: "\f106"; }

.flaticon-nervous:before {
  content: "\f107"; }

.flaticon-sad-1:before {
  content: "\f108"; }

.flaticon-happy-1:before {
  content: "\f109"; }

.flaticon-surprised:before {
  content: "\f10a"; }

.flaticon-sad:before {
  content: "\f10b"; }

.flaticon-happy:before {
  content: "\f10c"; }

.flaticon-arrow:before {
  content: "\f10d"; }

.flaticon-delivery-packages-on-a-trolley:before {
  content: "\f10e"; }

.flaticon-stats:before {
  content: "\f10f"; }

.flaticon-hairdresser-chair:before {
  content: "\f110"; }

.flaticon-percent:before {
  content: "\f111"; }

.flaticon-diskette:before {
  content: "\f112"; }

.flaticon-specialist-user:before {
  content: "\f113"; }

.flaticon-user-silhouette:before {
  content: "\f114"; }

.flaticon-rubbish-bin-1:before {
  content: "\f115"; }

.flaticon-rubbish-bin:before {
  content: "\f116"; }

.flaticon-set-alarm:before {
  content: "\f117"; }

.flaticon-united-heterosexual-symbols:before {
  content: "\f118"; }

.flaticon-multiple-users-silhouette:before {
  content: "\f119"; }

.flaticon-users-group:before {
  content: "\f11a"; }

.flaticon-rupee-indian:before {
  content: "\f11b"; }

.flaticon-coins:before {
  content: "\f11c"; }

.flaticon-printer:before {
  content: "\f11d"; }

.flaticon-sms-message:before {
  content: "\f11e"; }

.flaticon-calendar:before {
  content: "\f11f"; }

.flaticon-edit:before {
  content: "\f120"; }

.flaticon-mortarboard:before {
  content: "\f121"; }

.flaticon-dashboard:before {
  content: "\f122"; }

.flaticon-credit-card:before {
  content: "\f123"; }

.flaticon-reception:before {
  content: "\f124"; }

.flaticon-invoice:before {
  content: "\f125"; }

.flaticon-eye:before {
  content: "\f126"; }

.flaticon-menu:before {
  content: "\f127"; }

.flaticon-minus:before {
  content: "\f128"; }

.flaticon-add:before {
  content: "\f129"; }

.flaticon-list:before {
  content: "\f12a"; }

.flaticon-cell-phone:before {
  content: "\f12b"; }

.flaticon-signs:before {
  content: "\f12c"; }

.panel.lovelace-panel-apple {
  border-radius: 0;
  background-color: white; }
  .panel.lovelace-panel-apple p.input-group.has-float-label {
    margin: 0 0 0.75rem; }
  .panel.lovelace-panel-apple .title {
    padding: .875rem .9375rem;
    font-size: .875rem;
    font-weight: 600; }
    .panel.lovelace-panel-apple .title .label {
      line-height: inherit;
      font-weight: 600;
      font-size: .6785rem;
      padding: .1875rem .5rem;
      color: white;
      border-radius: .1875rem; }
  .panel.lovelace-panel-apple.create-panel div.reset {
    min-height: 2rem; }
    .panel.lovelace-panel-apple.create-panel div.reset i {
      cursor: pointer;
      padding-left: 1rem;
      padding-right: 1rem;
      display: inline-block;
      margin-top: -3px; }
  .panel.lovelace-panel-apple.collapsible-panel .title {
    cursor: pointer; }
  .panel.lovelace-panel-apple > .content {
    border-top: solid 1px #e7eaec;
    padding: .9375rem;
    font-size: .8125rem; }

.panel.lovelace-panel-with-border {
  margin-top: 1rem;
  border-radius: 0;
  background-color: white;
  border: solid 1px #e9e9e9;
  border-radius: 3px; }
  .panel.lovelace-panel-with-border p.input-group.has-float-label {
    margin: 0 0 0.75rem; }
  .panel.lovelace-panel-with-border .title {
    padding: .875rem 0rem;
    font-size: .875rem;
    font-weight: 600; }
    .panel.lovelace-panel-with-border .title .label {
      line-height: inherit;
      font-weight: 600;
      font-size: .6785rem;
      padding: .1875rem .5rem;
      color: white;
      border-radius: .1875rem; }
  .panel.lovelace-panel-with-border.create-panel div.reset {
    min-height: 2rem; }
    .panel.lovelace-panel-with-border.create-panel div.reset i {
      cursor: pointer;
      padding-left: 1rem;
      padding-right: 1rem;
      display: inline-block;
      margin-top: -3px; }
  .panel.lovelace-panel-with-border.collapsible-panel .title {
    cursor: pointer; }
  .panel.lovelace-panel-with-border > .content {
    border-top: solid 1px #e7eaec;
    padding-top: .9375rem;
    padding-bottom: .9375rem;
    font-size: .8125rem;
    min-height: 100px; }
  .panel.lovelace-panel-with-border .title, .panel.lovelace-panel-with-border .content {
    padding-left: 10px;
    padding-right: 10px; }
  .panel.lovelace-panel-with-border .title {
    background: #f7f7f7 !important; }
  .panel.lovelace-panel-with-border .component.no-resources .title {
    background: white !important; }

table.lovelace-grid {
  table-layout: fixed; }
  table.lovelace-grid input, table.lovelace-grid select {
    padding: 3px;
    width: 85%;
    height: inherit; }
  table.lovelace-grid th {
    font-weight: 600; }
  table.lovelace-grid td.input-box {
    padding: 0.4rem; }
  table.lovelace-grid tbody tr td {
    vertical-align: middle;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap; }
  table.lovelace-grid tbody.disable-all-rows button.edit, table.lovelace-grid tbody.disable-all-rows button.delete {
    pointer-events: none;
    background-color: #ff71b8;
    border: solid 1px #ff71b8; }

.lovelace-grid-row:nth-of-type(even) {
  background-color: #FFFFFF; }

.lovelace-grid-row:nth-of-type(odd) {
  background-color: #F9F9F9; }

.lovelace-grid-row:hover {
  background-color: #EAEAEA !important; }

.lovelace-grid-row.editing {
  background-color: #D6D6D6 !important; }

.display-flex {
  display: flex; }

.flex-1 {
  flex: 1; }

.flex-2 {
  flex: 2; }

.flex-3 {
  flex: 3; }

.flex-4 {
  flex: 4; }

.flex-5 {
  flex: 5; }

.flex-6 {
  flex: 6; }

.flex-7 {
  flex: 7; }

.flex-8 {
  flex: 8; }

.flex-9 {
  flex: 9; }

.flex-10 {
  flex: 10; }

.flex-11 {
  flex: 11; }

.flex-12 {
  flex: 12; }

.flex-13 {
  flex: 13; }

.flex-14 {
  flex: 14; }

.flex-15 {
  flex: 15; }

.flex-16 {
  flex: 16; }

.flex-17 {
  flex: 17; }

.flex-18 {
  flex: 18; }

.flex-19 {
  flex: 19; }

.flex-20 {
  flex: 20; }

.justify-content-flex-end {
  justify-content: flex-end; }

.justify-content-center {
  justify-content: center; }

.justify-content-flex-start {
  justify-content: flex-start; }

.align-self-center {
  align-self: center; }

.align-self-flex-end {
  align-self: flex-end; }

.align-self-flex-start {
  align-self: flex-start; }

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

.flex-direction-column {
  flex-direction: column; }

div.ui-grid {
  height: calc(100% - 50px);
  border: none !important; }
  div.ui-grid .ui-grid-header {
    font-size: 0.8175rem;
    color: white; }
    div.ui-grid .ui-grid-header .ui-grid-top-panel {
      color: #464646 !important;
      background: white !important;
      background-color: white !important; }

div.ui-grid-contents-wrapper {
  font-size: 0.8175rem !important; }

.ui-grid-cell, .ui-grid-header-cell, .ui-grid-header {
  border: none !important; }

.ui-grid-cell-contents {
  padding: 0.5rem; }

.ui-grid-row .ui-grid-cell {
  border-top: 1px solid #e7eaec !important; }

.ui-grid-row:nth-child(even) .ui-grid-cell {
  background-color: #FFFFFF !important; }

.ui-grid-row:nth-child(odd) .ui-grid-cell {
  background-color: #F9F9F9 !important; }

.ui-grid-row:hover .ui-grid-cell {
  background-color: #EAEAEA !important; }

.ui-grid-row.editing .ui-grid-cell {
  background-color: #D6D6D6 !important; }

div.ui-grid-canvas div.ui-grid-cell {
  height: 2.1rem; }
  div.ui-grid-canvas div.ui-grid-cell div.action-div {
    padding: 3px;
    text-align: center;
    margin-top: 3px; }

.ui-grid .ui-grid-render-container-body .ui-grid-viewport {
  overflow-y: auto !important;
  overflow-x: auto !important; }

.ui-grid-cell-contents .ui-grid-invisible {
  display: none; }

.input-textbox-addon {
  font-size: 0px; }
  .input-textbox-addon span:first-of-type {
    position: relative;
    width: 1.875rem;
    height: 1.875rem;
    border: solid 1px silver;
    border-left: none;
    background-color: white;
    display: inline-block;
    cursor: pointer;
    vertical-align: bottom; }
    .input-textbox-addon span:first-of-type:before {
      color: #D7006C;
      font-family: Flaticon;
      position: absolute;
      display: block;
      line-height: 1.875rem;
      top: 0;
      left: 0;
      width: 1.875rem;
      height: 1.875rem;
      text-align: center;
      font-size: 1rem; }
    .input-textbox-addon span:first-of-type.user:before {
      content: "\f10b"; }
    .input-textbox-addon span:first-of-type.phone:before {
      content: "\f102 "; }
    .input-textbox-addon span:first-of-type.card:before {
      content: "\f09d"; }
    .input-textbox-addon span:first-of-type.calendar:before {
      content: "\f101"; }
    .input-textbox-addon span:first-of-type.scissors:before {
      content: "\f0c4"; }
    .input-textbox-addon span:first-of-type.time:before {
      content: "\f017"; }
    .input-textbox-addon span:first-of-type.rupee:before {
      content: "\f156"; }
    .input-textbox-addon span:first-of-type.dark-bg {
      background-color: #D7006C !important;
      border: none !important; }
      .input-textbox-addon span:first-of-type.dark-bg:before {
        color: white !important; }
  .input-textbox-addon input {
    font-size: 0.8125rem;
    border: solid 1px silver;
    border-right: none !important;
    height: 1.875rem; }
    .input-textbox-addon input:focus {
      border: solid 1px silver !important;
      border-right: none !important; }
    .input-textbox-addon input.editable:focus {
      border: solid 1px grey !important;
      border-right: none !important; }

button [class^="flaticon-"]:before, button [class*=" flaticon-"]:before,
button [class^="flaticon-"]:after, button [class*=" flaticon-"]:after {
  font-size: 0.8125rem;
  margin-left: 0;
  margin-right: 5px; }

button.btn-xs [class^="flaticon-"]:before, button.btn-xs [class*=" flaticon-"]:before,
button.btn-xs [class^="flaticon-"]:after, button.btn-xs [class*=" flaticon-"]:after {
  font-size: 10px;
  margin-left: 0;
  margin-right: 5px; }

button i.glyphicon:before {
  margin-left: 0;
  margin-right: 5px; }

button.btn {
  border-radius: 2px; }

.input-group-btn button i.fi:before {
  margin-left: 0;
  margin-right: 0;
  width: 16px; }

.input-group-btn button i.glyphicon:before {
  margin-left: 0;
  margin-right: 0; }

.input-group-btn button i {
  min-width: 16px; }

.input-group input {
  padding: 6px;
  box-shadow: none;
  border-radius: 0; }
  .input-group input:focus {
    outline: none !important; }

.form-control {
  font-size: 0.8125rem;
  border-radius: 0; }
  .form-control:focus {
    border-color: inherit;
    box-shadow: none;
    border-radius: 0; }
  .form-control textarea {
    border-radius: 0; }

.input-group-btn:last-child > .btn {
  border-radius: 0; }

.form-control[disabled], .form-control[readonly], fieldset[disabled] .form-control {
  background-color: inherit;
  opacity: inherit; }

.modal-dialog .modal-title {
  color: #353535; }

.table > thead > tr > th, .table > tbody > tr > th {
  border: 0 !important;
  font-weight: 600; }

table tfoot {
  border-bottom: 1px solid #ddd; }

.modal .modal-content {
  border-radius: 2px; }

@media (min-width: 768px) {
  .modal-xl {
    width: 90%;
    max-width: 1200px; } }

@media (min-width: 768px) {
  .modal-sm-350 {
    width: 350px; } }

div.pagination > li > a,
div.pagination > li > span {
  color: #D7006C; }

div.pagination > .active > a, div.pagination > .active > a:hover, div.pagination > .active > a:focus,
div.pagination > .active > span,
div.pagination > .active > span:hover,
div.pagination > .active > span:focus {
  z-index: 3;
  color: white;
  background-color: #D7006C;
  border-color: #D7006C;
  cursor: default; }

div.pagination > li > a:hover, div.pagination > li > a:focus,
div.pagination > li > span:hover,
div.pagination > li > span:focus {
  outline: none;
  color: #D7006C; }

/* Specify styling for tooltip contents */
.tooltip.lovelace-tooltip .tooltip-inner {
  color: white;
  background-color: #8B8987;
  box-shadow: 0 6px 12px rgba(0, 0, 0, 0.175); }

/* Hide arrow */
.tooltip.lovelace-tooltip .tooltip-arrow {
  display: none; }

.pagination {
  margin: 0; }

.modal .modal-title {
  color: inherit;
  font-size: 1rem; }

.modal .modal-header button.close {
  opacity: 0.5; }
  .modal .modal-header button.close:hover {
    opacity: 0.8; }

.modal .modal-body {
  font-size: 0.8125rem; }

.modal .modal-footer .btn {
  font-size: 0.8125rem; }

div.btn-group.lovelace-list-dropdown {
  cursor: pointer; }
  div.btn-group.lovelace-list-dropdown > button.btn:first-child:hover, div.btn-group.lovelace-list-dropdown > button.btn:first-child:focus, div.btn-group.lovelace-list-dropdown > button.btn:first-child:active {
    border-right: solid 1px #f3f3f4; }
  div.btn-group.lovelace-list-dropdown.open > .dropdown-toggle.btn-primary {
    background-color: #D7006C; }
  div.btn-group.lovelace-list-dropdown button.btn:focus {
    transform: none;
    box-shadow: none;
    border-right: solid 1px #f3f3f4; }
  div.btn-group.lovelace-list-dropdown > .btn + .dropdown-toggle {
    border-left: solid 1px #f3f3f4; }
  div.btn-group.lovelace-list-dropdown ul.dropdown-menu.position-left {
    right: 0 !important;
    left: inherit; }
  div.btn-group.lovelace-list-dropdown ul.dropdown-menu {
    padding: 0; }
  div.btn-group.lovelace-list-dropdown ul li a {
    padding: 6px 10px; }
    div.btn-group.lovelace-list-dropdown ul li a i {
      margin-right: 7px;
      color: #D7006C; }
    div.btn-group.lovelace-list-dropdown ul li a:hover {
      background-color: #e8e8e8; }
  div.btn-group.lovelace-list-dropdown .divider {
    margin: 0; }

.uib-daypicker:focus, .uib-monthpicker:focus, .uib-yearpicker:focus {
  outline: none !important; }

.uib-daypicker thead button, .uib-monthpicker thead button, .uib-yearpicker thead button {
  border: none !important;
  box-shadow: none !important; }

.uib-daypicker .uib-day button {
  border: none !important;
  box-shadow: none !important; }

.uib-monthpicker .uib-month button {
  border: none !important;
  box-shadow: none !important; }

.uib-yearpicker .uib-year button {
  border: none !important;
  box-shadow: none !important; }

.growl-container > .growl-item.ng-enter,
.growl-container > .growl-item.ng-leave {
  transition: 0.2s linear all; }

/* @see https://github.com/minipai/ng-trans.css/blob/master/ng-trans.css */
.growl-container > .growl-item.ng-enter, .growl-container > .growl-item.ng-leave.ng-leave-active, .growl-container > .growl-item.ng-hide-remove, .growl-container > .growl-item.ng-hide-add.ng-hide-add-active {
  opacity: 0;
  -webkit-transform: perspective(400px) rotateX(90deg);
  -ms-transform: perspective(400px) rotateX(90deg);
  transform: perspective(400px) rotateX(90deg); }

.growl-container > .growl-item.ng-leave, .growl-container > .growl-item.ng-enter.ng-enter-active, .growl-container > .growl-item.ng-hide-remove.ng-hide-remove-active, .growl-container > .growl-item.ng-hide-add {
  opacity: 1;
  -webkit-transform: perspective(400px) rotateX(0deg);
  -ms-transform: perspective(400px) rotateX(0deg);
  transform: perspective(400px) rotateX(0deg); }

.growl-container > .growl-item:nth-child(1) {
  margin-top: 40px; }

.growl-container > .growl-item button.close {
  opacity: .5;
  color: white; }
  .growl-container > .growl-item button.close:hover {
    opacity: .9;
    color: white; }

/* @see https://github.com/needim/noty/blob/master/src/themes/mint.scss */
.alert-success {
  color: white;
  background-color: #AFC765;
  border: 1px solid #A0B55C;
  border-radius: 2px; }

.alert-info {
  color: white;
  background-color: #7F7EFF;
  border-bottom: 1px solid #7473E8;
  border-radius: 2px; }

.alert-error {
  color: white;
  background-color: #DE636F;
  border: 1px solid #CA5A65;
  border-radius: 2px; }

.alert-warning {
  color: white;
  background-color: #FFAE42;
  border: 1px solid #E89F3C;
  border-radius: 2px; }

.alert-success {
  color: white;
  background-color: #60A917;
  border: 1px solid #60A917; }

.alert-warning {
  background-color: #ff9200; }

treasure-overlay-spinner {
  transition: none !important; }

.treasure-overlay-spinner-container {
  background-color: white;
  transition: none !important;
  z-index: 10; }

.modal .modal-body .treasure-overlay-spinner-container {
  z-index: 10; }

.modal .modal-body .treasure-overlay-spinner-content {
  padding-top: 5px; }

treasure-overlay-spinner.transparent .treasure-overlay-spinner-container, .modal .modal-body .transparent .treasure-overlay-spinner-container {
  background-color: rgba(255, 255, 255, 0.2);
  opacity: 1; }

.with-default-opacity.treasure-overlay-spinner-active .treasure-overlay-spinner-container {
  opacity: 0.6; }

.ui-select-container.select2-container.select2-container-active .select2-choice {
  border: solid 1px #555; }

.ui-select-container.select2-container.select2-container-active.select2-dropdown-open .select2-choice {
  border: 1px solid #aaa; }

.ui-select-container.select2-container .select2-choice {
  border-radius: 0;
  border: solid 1px #aaa;
  box-shadow: none;
  background-image: none; }
  .ui-select-container.select2-container .select2-choice span {
    color: #636363; }

.ui-select-container.select2-container .search-container.select2-search {
  margin-top: 6px; }

.ui-select-container.select2-container .ui-select-dropdown.select2-drop-active {
  border: 1px solid #aaa; }

.ui-select-container.select2-container .select2-arrow.ui-select-toggle {
  background: none;
  border-left: none; }

.ui-select-container.select2-container.select2-container-active.select2-dropdown-open .select2-choice {
  border-bottom: none;
  background-color: white; }
  .ui-select-container.select2-container.select2-container-active.select2-dropdown-open .select2-choice span {
    color: #3a3a3a; }

.ui-select-container.select2-container.select2-container-active.select2-dropdown-open .select2-with-searchbox.select2-drop-active {
  border-top: none; }

.aligner {
  display: flex;
  align-items: center;
  justify-content: center; }

.aligner-item {
  flex: 1; }

.aligner-item-top {
  align-self: flex-start; }

.aligner-item-bottom {
  align-self: flex-end; }

.aligner-item-fixed {
  flex: none;
  max-width: 50%; }

.component.bounce-spinner .bounce-spinner-container {
  width: 40px;
  height: 40px;
  position: relative;
  margin: 100px auto; }
  .component.bounce-spinner .bounce-spinner-container .double-bounce1, .component.bounce-spinner .bounce-spinner-container .double-bounce2 {
    width: 100%;
    height: 100%;
    border-radius: 50%;
    background-color: #D7006C;
    opacity: 0.6;
    position: absolute;
    top: 0;
    left: 0;
    animation: bounce 2.0s infinite ease-in-out; }
  .component.bounce-spinner .bounce-spinner-container .double-bounce2 {
    animation-delay: -1.0s; }

@-webkit-keyframes bounce {
  0%, 100% {
    -webkit-transform: scale(0); }
  50% {
    -webkit-transform: scale(1); } }

@keyframes bounce {
  0%, 100% {
    transform: scale(0);
    -webkit-transform: scale(0); }
  50% {
    transform: scale(1);
    -webkit-transform: scale(1); } }

.has-float-label {
  position: relative; }

.has-float-label label {
  position: absolute;
  cursor: text;
  font-size: 11px;
  color: #D7006C;
  opacity: 1;
  -webkit-transition: all .2s;
  transition: all .2s;
  top: -.5em;
  left: 12px;
  z-index: 3;
  line-height: 1;
  padding: 0 1px; }

.has-float-label label::after {
  content: " ";
  display: block;
  position: absolute;
  background: #fff;
  height: 2px;
  top: 50%;
  left: -.2em;
  right: -.2em;
  z-index: -1; }

.has-float-label .form-control::-webkit-input-placeholder {
  opacity: 1;
  -webkit-transition: all .2s;
  transition: all .2s; }

.has-float-label .form-control:placeholder-shown:not(:focus)::-webkit-input-placeholder {
  opacity: 0; }

.has-float-label .form-control:placeholder-shown:not(:focus) + label {
  font-size: 0.8125rem;
  opacity: .8;
  top: .8em;
  font-weight: 400;
  color: #464646; }

.input-group .has-float-label {
  display: table-cell; }

.input-group.has-float-label input {
  padding-left: 12px; }

.input-group .has-float-label .form-control {
  border-radius: 4px; }

.input-group .has-float-label:not(:last-child) .form-control {
  border-bottom-right-radius: 0;
  border-top-right-radius: 0; }

.input-group .has-float-label:not(:first-child) .form-control {
  border-bottom-left-radius: 0;
  border-top-left-radius: 0;
  margin-left: -1px; }

.btn {
  border-radius: 2px;
  font-weight: 600; }
  .btn:focus, .btn:active, .btn:focus-within, .btn:focus-visible {
    outline: none; }

.btn-primary {
  background-color: #f10079;
  border: solid 1px #f10079;
  outline: none; }
  .btn-primary:hover, .btn-primary:active, .btn-primary:focus, .btn-primary:active:focus, .btn-primary:active:hover {
    outline: none;
    border: solid 1px #f10079;
    background-color: #D7006C; }
  .btn-primary:focus {
    border: solid 1px #555555 !important; }
  .btn-primary:disabled, .btn-primary.disabled, .btn-primary[disabled]:focus, .btn-primary[disabled]:hover {
    pointer-events: none;
    background-color: #ff71b8;
    border: solid 1px #ff71b8; }
  .btn-primary.active {
    background-color: #a40052; }
    .btn-primary.active:hover, .btn-primary.active:active, .btn-primary.active:focus, .btn-primary.active:active:focus {
      background-color: #a40052 !important; }

.btn-blue {
  background-color: #1c98c0;
  border: solid 1px #1c98c0;
  outline: none; }
  .btn-blue:hover, .btn-blue:active, .btn-blue:focus, .btn-blue:active:focus, .btn-blue:active:hover {
    outline: none;
    border: solid 1px #1c98c0;
    background-color: #1986AA; }
  .btn-blue:focus {
    border: solid 1px #555555 !important; }
  .btn-blue:disabled, .btn-blue.disabled, .btn-blue[disabled]:focus, .btn-blue[disabled]:hover {
    pointer-events: none;
    background-color: #72ccea;
    border: solid 1px #72ccea; }
  .btn-blue.active {
    background-color: #12637e; }
    .btn-blue.active:hover, .btn-blue.active:active, .btn-blue.active:focus, .btn-blue.active:active:focus {
      background-color: #12637e !important; }

.btn-green {
  background-color: #1cc082;
  border: solid 1px #1cc082;
  outline: none; }
  .btn-green:hover, .btn-green:active, .btn-green:focus, .btn-green:active:focus, .btn-green:active:hover {
    outline: none;
    border: solid 1px #1cc082;
    background-color: #19AA73; }
  .btn-green:focus {
    border: solid 1px #555555 !important; }
  .btn-green:disabled, .btn-green.disabled, .btn-green[disabled]:focus, .btn-green[disabled]:hover {
    pointer-events: none;
    background-color: #72eabd;
    border: solid 1px #72eabd; }
  .btn-green.active {
    background-color: #127e55; }
    .btn-green.active:hover, .btn-green.active:active, .btn-green.active:focus, .btn-green.active:active:focus {
      background-color: #127e55 !important; }

.btn-light-green {
  background-color: #8ac91d;
  border: solid 1px #8ac91d;
  outline: none; }
  .btn-light-green:hover, .btn-light-green:active, .btn-light-green:focus, .btn-light-green:active:focus, .btn-light-green:active:hover {
    outline: none;
    border: solid 1px #8ac91d;
    background-color: #7BB31A; }
  .btn-light-green:focus {
    border: solid 1px #555555 !important; }
  .btn-light-green:disabled, .btn-light-green.disabled, .btn-light-green[disabled]:focus, .btn-light-green[disabled]:hover {
    pointer-events: none;
    background-color: #c2ec7a;
    border: solid 1px #c2ec7a; }
  .btn-light-green.active {
    background-color: #5c8614; }
    .btn-light-green.active:hover, .btn-light-green.active:active, .btn-light-green.active:focus, .btn-light-green.active:active:focus {
      background-color: #5c8614 !important; }

.btn-purple {
  background-color: #aa1dc9;
  border: solid 1px #aa1dc9;
  outline: none; }
  .btn-purple:hover, .btn-purple:active, .btn-purple:focus, .btn-purple:active:focus, .btn-purple:active:hover {
    outline: none;
    border: solid 1px #aa1dc9;
    background-color: #971AB3; }
  .btn-purple:focus {
    border: solid 1px #555555 !important; }
  .btn-purple:disabled, .btn-purple.disabled, .btn-purple[disabled]:focus, .btn-purple[disabled]:hover {
    pointer-events: none;
    background-color: #d77aec;
    border: solid 1px #d77aec; }
  .btn-purple.active {
    background-color: #711486; }
    .btn-purple.active:hover, .btn-purple.active:active, .btn-purple.active:focus, .btn-purple.active:active:focus {
      background-color: #711486 !important; }

.btn-brown {
  background-color: #c07f1c;
  border: solid 1px #c07f1c;
  outline: none; }
  .btn-brown:hover, .btn-brown:active, .btn-brown:focus, .btn-brown:active:focus, .btn-brown:active:hover {
    outline: none;
    border: solid 1px #c07f1c;
    background-color: #AA7019; }
  .btn-brown:focus {
    border: solid 1px #555555 !important; }
  .btn-brown:disabled, .btn-brown.disabled, .btn-brown[disabled]:focus, .btn-brown[disabled]:hover {
    pointer-events: none;
    background-color: #eaba72;
    border: solid 1px #eaba72; }
  .btn-brown.active {
    background-color: #7e5312; }
    .btn-brown.active:hover, .btn-brown.active:active, .btn-brown.active:focus, .btn-brown.active:active:focus {
      background-color: #7e5312 !important; }

.btn-red {
  background-color: #c01c1c;
  border: solid 1px #c01c1c;
  outline: none; }
  .btn-red:hover, .btn-red:active, .btn-red:focus, .btn-red:active:focus, .btn-red:active:hover {
    outline: none;
    border: solid 1px #c01c1c;
    background-color: #AA1919; }
  .btn-red:focus {
    border: solid 1px #555555 !important; }
  .btn-red:disabled, .btn-red.disabled, .btn-red[disabled]:focus, .btn-red[disabled]:hover {
    pointer-events: none;
    background-color: #ea7272;
    border: solid 1px #ea7272; }
  .btn-red.active {
    background-color: #7e1212; }
    .btn-red.active:hover, .btn-red.active:active, .btn-red.active:focus, .btn-red.active:active:focus {
      background-color: #7e1212 !important; }

.btn-orange {
  background-color: #e1973f;
  border: solid 1px #e1973f;
  outline: none; }
  .btn-orange:hover, .btn-orange:active, .btn-orange:focus, .btn-orange:active:focus, .btn-orange:active:hover {
    outline: none;
    border: solid 1px #e1973f;
    background-color: #DE8B29; }
  .btn-orange:focus {
    border: solid 1px #555555 !important; }
  .btn-orange:disabled, .btn-orange.disabled, .btn-orange[disabled]:focus, .btn-orange[disabled]:hover {
    pointer-events: none;
    background-color: #f2d3ae;
    border: solid 1px #f2d3ae; }
  .btn-orange.active {
    background-color: #b8701c; }
    .btn-orange.active:hover, .btn-orange.active:active, .btn-orange.active:focus, .btn-orange.active:active:focus {
      background-color: #b8701c !important; }

.btn-grey {
  background-color: #a8afad;
  border: solid 1px #a8afad;
  outline: none; }
  .btn-grey:hover, .btn-grey:active, .btn-grey:focus, .btn-grey:active:focus, .btn-grey:active:hover {
    outline: none;
    border: solid 1px #a8afad;
    background-color: #9BA3A0; }
  .btn-grey:focus {
    border: solid 1px #555555 !important; }
  .btn-grey:disabled, .btn-grey.disabled, .btn-grey[disabled]:focus, .btn-grey[disabled]:hover {
    pointer-events: none;
    background-color: #ebecec;
    border: solid 1px #ebecec; }
  .btn-grey.active {
    background-color: #808b87; }
    .btn-grey.active:hover, .btn-grey.active:active, .btn-grey.active:focus, .btn-grey.active:active:focus {
      background-color: #808b87 !important; }

.btn-light-grey {
  background-color: #989694;
  border: solid 1px #989694;
  outline: none; }
  .btn-light-grey:hover, .btn-light-grey:active, .btn-light-grey:focus, .btn-light-grey:active:focus, .btn-light-grey:active:hover {
    outline: none;
    border: solid 1px #989694;
    background-color: #8B8987; }
  .btn-light-grey:focus {
    border: solid 1px #555555 !important; }
  .btn-light-grey:disabled, .btn-light-grey.disabled, .btn-light-grey[disabled]:focus, .btn-light-grey[disabled]:hover {
    pointer-events: none;
    background-color: #d6d6d5;
    border: solid 1px #d6d6d5; }
  .btn-light-grey.active {
    background-color: #71706e; }
    .btn-light-grey.active:hover, .btn-light-grey.active:active, .btn-light-grey.active:focus, .btn-light-grey.active:active:focus {
      background-color: #71706e !important; }

.btn-xs i.glyphicon {
  font-size: 11px; }

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

.component.horizontal-menubar {
  background-color: #D7006C !important;
  color: white !important;
  min-height: 4px !important; }
  .component.horizontal-menubar .logout .icon {
    font-size: 11px; }
  .component.horizontal-menubar .navbar-nav {
    float: left;
    margin: 0; }
  .component.horizontal-menubar .nav > li {
    float: left; }
  .component.horizontal-menubar .navbar-right {
    float: right !important; }
  .component.horizontal-menubar .navbar-nav > li > a {
    color: white !important;
    font-size: .8rem;
    font-weight: 600;
    padding-top: 0.5rem;
    padding-bottom: 0.5rem; }
    .component.horizontal-menubar .navbar-nav > li > a:focus, .component.horizontal-menubar .navbar-nav > li > a:hover {
      color: white !important;
      background-color: #be005f !important; }
  .component.horizontal-menubar .navbar-nav > li.active > a {
    color: white;
    font-size: .8rem;
    background-color: #a40052; }
  .component.horizontal-menubar .navbar-right.right a {
    padding-left: 12px;
    padding-right: 12px; }
    .component.horizontal-menubar .navbar-right.right a:focus {
      background-color: inherit !important; }

.component.user-dropdown .user-button {
  position: relative;
  border: none;
  background: none;
  padding-left: 12px;
  padding-right: 12px;
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
  -webkit-box-shadow: none; }

.component.user-dropdown ul.dropdown-menu {
  min-width: 220px;
  margin-right: 2px; }

.component.user-dropdown .user-button:hover {
  background: #be005f !important; }

.component.user-dropdown small {
  color: #464646; }

.component.user-dropdown ul li {
  font-size: 0.8125rem;
  padding-left: 0.9375rem;
  padding-right: 0.9375rem;
  color: #464646; }

.component.user-dropdown ul li a {
  padding-left: 0 !important;
  padding-right: 0 !important; }
  .component.user-dropdown ul li a:hover {
    text-decoration: underline;
    background: none; }

.component.user-dropdown .component.backoffice-role-type-label {
  margin-top: 5px;
  font-size: 0.8125rem; }

.component.no-resources div.panel-content {
  padding-top: 0; }
  .component.no-resources div.panel-content .repeat-item.ng-leave {
    transition: 0.3s ease-out all; }
  .component.no-resources div.panel-content .no-resources {
    margin-bottom: 8rem;
    margin-top: 3rem; }
    .component.no-resources div.panel-content .no-resources div.title {
      font-family: Roboto;
      font-weight: 300;
      font-size: 1.8rem;
      margin-bottom: 1rem; }
    .component.no-resources div.panel-content .no-resources div.icon {
      color: #D7006C;
      font-size: 3.5rem;
      margin-bottom: 1rem; }
    .component.no-resources div.panel-content .no-resources button {
      margin-top: 1rem; }

.component.page-size-selector {
  display: flex;
  padding-right: 1rem; }
  .component.page-size-selector label {
    font-weight: normal;
    display: flex;
    margin: 0;
    align-items: center;
    padding-right: 10px; }
  .component.page-size-selector select {
    border: 1px solid #ddd;
    outline: none !important; }

.component.lovelace-spinner .spinner .xs {
  border-radius: 50%;
  width: 10px;
  height: 10px;
  border: 0.15rem solid #cac3c6;
  border-top-color: #D7006C;
  animation: spin 1s infinite linear; }

.component.lovelace-spinner .spinner .sm {
  border-radius: 50%;
  width: 15px;
  height: 15px;
  border: 0.2rem solid #cac3c6;
  border-top-color: #D7006C;
  animation: spin 1s infinite linear; }

.component.lovelace-spinner .spinner .md {
  border-radius: 50%;
  width: 22px;
  height: 22px;
  border: 0.2rem solid #cac3c6;
  border-top-color: #D7006C;
  animation: spin 1s infinite linear; }

.component.lovelace-spinner .spinner .lg {
  border-radius: 50%;
  width: 30px;
  height: 30px;
  border: 0.25rem solid #cac3c6;
  border-top-color: #D7006C;
  animation: spin 1s infinite linear; }

.component.captcha-generator .captcha-code {
  border: 1px solid;
  position: relative;
  text-align: center;
  color: white; }

.component.captcha-generator img {
  width: 50%; }

.component.captcha-generator .center-code {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%); }

.component.captcha-generator .regenerate {
  cursor: pointer;
  align-self: center; }

.component.daterange-selector {
  background-color: #e6e6e6; }
  .component.daterange-selector .btn.select-dropdown {
    font-size: 0.8125rem;
    background: transparent;
    border: 0;
    box-shadow: none; }
    .component.daterange-selector .btn.select-dropdown:hover, .component.daterange-selector .btn.select-dropdown:focus, .component.daterange-selector .btn.select-dropdown:active {
      background: transparent;
      border: 0;
      box-shadow: none; }
    .component.daterange-selector .btn.select-dropdown .caret {
      margin-left: 3px; }
  .component.daterange-selector p.input-group.date-selector {
    width: 7rem;
    margin-bottom: 0; }
    .component.daterange-selector p.input-group.date-selector input, .component.daterange-selector p.input-group.date-selector input:focus, .component.daterange-selector p.input-group.date-selector input:active {
      border: 0 !important; }
    .component.daterange-selector p.input-group.date-selector span.calendar {
      padding: 6px; }
  .component.daterange-selector ul.select-dropdown-menu {
    padding-top: 0;
    padding-bottom: 0; }
    .component.daterange-selector ul.select-dropdown-menu li {
      font-size: 0.8125rem;
      padding: 0.3rem 0.75rem;
      cursor: pointer; }
      .component.daterange-selector ul.select-dropdown-menu li:hover {
        background: #e8e8e8; }
      .component.daterange-selector ul.select-dropdown-menu li.active {
        background: #dbdbdb; }
  .component.daterange-selector button.apply:focus {
    transform: none !important;
    box-shadow: none !important; }

.component.toggle .btn-switch {
  position: relative;
  display: block;
  width: 40px;
  height: 20px;
  cursor: pointer;
  background-color: #e7e7e7;
  border: 2px solid #e7e7e7;
  border-radius: 40px; }
  .component.toggle .btn-switch .btn-switch-circle {
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    height: 16px;
    width: 16px;
    background-color: #ffffff;
    border-radius: 40px; }

.component.toggle .btn-switch--on {
  background-color: #D7006C;
  border: 2px solid #D7006C; }
  .component.toggle .btn-switch--on .btn-switch-circle--on {
    left: auto;
    right: 0; }

.alert-modal .notification {
  animation-name: zoomIn;
  animation-duration: .5s;
  animation-delay: 0s; }
  .alert-modal .notification.ng-show {
    animation-name: fadeOut;
    animation-duration: .5s; }
  .alert-modal .notification i {
    font-size: 4rem; }
  .alert-modal .notification span {
    padding-top: .5rem;
    display: inline-block;
    font-size: 1rem;
    padding-bottom: 2rem; }

div.select-date-modal div.uib-daypicker {
  display: flex;
  justify-content: center; }
  div.select-date-modal div.uib-daypicker button.active {
    background: #1986AA; }
  div.select-date-modal div.uib-daypicker span.text-info {
    color: white; }

.page.login {
  display: flex;
  flex-direction: column;
  padding-top: 70px;
  align-items: center;
  position: relative;
  min-height: 100%;
  /* Animation Keyframes */
  /* Login Form */
  /* Form */
  /* Inputs */
  /* Submit Button */ }

@keyframes scale_header {
  0% {
    max-height: 0px;
    margin-bottom: 0px;
    opacity: 0; }
  100% {
    max-height: 117px;
    margin-bottom: 25px;
    opacity: 1; } }

@keyframes input_opacity {
  0% {
    transform: translateY(-10px);
    opacity: 0; }
  100% {
    transform: translateY(0px);
    opacity: 1; } }

@keyframes text_opacity {
  0% {
    color: transparent; } }

@keyframes error_before {
  0% {
    height: 5px;
    background: rgba(0, 0, 0, 0.156);
    color: transparent; }
  10% {
    height: 117px;
    background: #FFFFFF;
    color: #C62828; }
  90% {
    height: 117px;
    background: #FFFFFF;
    color: #C62828; }
  100% {
    height: 5px;
    background: rgba(0, 0, 0, 0.156);
    color: transparent; } }
  .page.login .login-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    position: relative;
    width: 340px;
    height: auto;
    padding: 5px;
    box-sizing: border-box; }
    .page.login .login-container > section {
      box-shadow: 0px 0px 12px 0px rgba(50, 50, 50, 0.3); }
  .page.login .login-container p {
    align-self: flex-start;
    font-family: 'Roboto', sans-serif;
    font-size: 0.8rem;
    color: rgba(0, 0, 0, 0.5); }
  .page.login .login-container p a {
    color: rgba(0, 0, 0, 0.4); }
  .page.login .login {
    position: relative;
    width: 100%;
    padding: 10px;
    margin: 0 0 10px 0;
    box-sizing: border-box;
    border-radius: 3px;
    background: #FAFAFA;
    overflow: hidden;
    animation: input_opacity 0.2s cubic-bezier(0.55, 0, 0.1, 1);
    box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12), 0 3px 1px -2px rgba(0, 0, 0, 0.2); }
  .page.login .login > header {
    position: relative;
    padding: 10px;
    margin: -10px -10px 25px -10px;
    border-bottom: 1px solid rgba(0, 0, 0, 0.1);
    background: #D7006C;
    font-family: 'Roboto', sans-serif;
    font-size: 1.3rem;
    color: #FAFAFA;
    animation: scale_header 0.6s cubic-bezier(0.55, 0, 0.1, 1), text_opacity 1s cubic-bezier(0.55, 0, 0.1, 1);
    box-shadow: 0px 2px 2px 0px rgba(0, 0, 0, 0.14), 0px 1px 5px 0px rgba(0, 0, 0, 0.12), 0px 3px 1px -2px rgba(0, 0, 0, 0.2); }
  .page.login .login > header:before {
    content: '';
    display: flex;
    justify-content: center;
    align-items: center;
    position: absolute;
    width: 100%;
    height: 5px;
    padding: 10px;
    margin: -10px 0 0px -10px;
    box-sizing: border-box;
    background: rgba(0, 0, 0, 0.156);
    font-family: 'Roboto', sans-serif;
    font-size: 0.9rem;
    color: transparent;
    z-index: 5; }
  .page.login .login.error_1 > header:before,
  .page.login .login.error_2 > header:before {
    animation: error_before 3s cubic-bezier(0.55, 0, 0.1, 1); }
  .page.login .login.error_1 > header:before {
    content: 'Invalid username or password!'; }
  .page.login .login.error_2 > header:before {
    content: 'Invalid or expired Token!'; }
  .page.login .login > header h2 {
    margin: 50px 0 10px 0; }
  .page.login .login > header h4 {
    font-size: 0.7em;
    animation: text_opacity 1.5s cubic-bezier(0.55, 0, 0.1, 1);
    color: #fafafa; }
  .page.login .login-form {
    padding: 15px;
    box-sizing: border-box; }
  .page.login .login-input {
    position: relative;
    width: 100%;
    padding: 10px 5px;
    margin: 0 0 25px 0;
    border: none;
    border-bottom: 2px solid rgba(0, 0, 0, 0.2);
    box-sizing: border-box;
    background: transparent !important;
    font-size: 1rem;
    font-family: 'Roboto', sans-serif;
    opacity: 1;
    animation: input_opacity 0.8s cubic-bezier(0.55, 0, 0.1, 1);
    transition: border-bottom 0.2s cubic-bezier(0.55, 0, 0.1, 1); }
  .page.login .login-input:focus {
    outline: none;
    border-bottom: 2px solid #D7006C !important;
    border-top: none !important;
    border-left: none !important;
    border-right: none !important; }
  .page.login .submit-container {
    padding: 10px;
    margin: 0px -25px -25px -25px; }
    .page.login .submit-container img {
      width: 100px; }
  .page.login .powered-by-container {
    display: flex;
    flex-direction: row;
    position: relative;
    border-top: 1px solid rgba(111, 111, 111, 0.1);
    justify-content: center;
    margin: 35px -25px -25px -25px; }
    .page.login .powered-by-container div {
      display: inline-block;
      padding: 10px;
      display: inline-block;
      padding: 11px;
      font-size: 13px; }
      .page.login .powered-by-container div span {
        font-weight: 600; }

.component.branch-selector p.input-group {
  width: 15rem; }
  .component.branch-selector p.input-group:last-child {
    margin-bottom: 0; }

.component.yearly-bills-bar-chart #yearly-bills-bar-chart-wrapper {
  position: relative;
  height: 300px; }

.component.rangewise-bills-bar-chart #rangewise-bills-bar-chart-wrapper {
  position: relative;
  height: 300px; }

.component.rangewise-bills-bar-chart .component.date-selector {
  margin-top: 7px;
  margin-bottom: -3px;
  width: 150px; }

.component.create-ticket .component.branch-selector p.input-group {
  width: 100%; }

.component.lovelace-support-reply {
  background-color: #F3F3F4;
  border-radius: 3px;
  border: solid 1px silver;
  border-color: #dad9d9; }
  .component.lovelace-support-reply.author-support {
    background-color: white;
    border-color: #ffa4d2; }
    .component.lovelace-support-reply.author-support .fa-user-circle {
      color: #D7006C; }

.component.ticket-status-selector {
  min-width: 100px; }

.component.ticket-status-label {
  color: white; }

.component.ticket-status-label {
  color: white; }

.page.ticket-view {
  max-width: 780px; }

.page.reports-home {
  max-width: 600px; }

.page.reports-pending-payments table td, .page.reports-pending-payments table th {
  padding-right: 15px; }

.page.reports-pending-payments table th {
  padding-bottom: 10px; }

.page.dashboard table td, .page.dashboard table th {
  padding-right: 10px; }

.page.dashboard i.flaticon-rupee-indian {
  color: #D7006C;
  margin-right: .2rem; }

.page.dashboard .panel .content {
  min-height: 70px; }

.page.dashboard .scoreboard .panel .content {
  font-size: 1.5rem;
  font-weight: 300; }
  .page.dashboard .scoreboard .panel .content i {
    font-size: 1.4rem; }

.page.dashboard .subscriptions.panel i.flaticon-rupee-indian {
  color: white;
  margin-right: .2rem; }

.page.dashboard .subscriptions.panel tr.month {
  border-bottom: solid 1px silver; }
  .page.dashboard .subscriptions.panel tr.month td {
    padding-top: 10px;
    padding-bottom: 5px; }
    .page.dashboard .subscriptions.panel tr.month td:first-child {
      font-weight: 600; }

.page.subscriptions-subscriptions {
  margin-top: 1.25rem; }
  .page.subscriptions-subscriptions .subscriptions-view-container {
    background-color: white;
    padding: 1.25rem;
    width: 100%;
    min-height: 5rem; }

.component.create-subscription .component.branch-selector p.input-group {
  width: 100%; }

.component.date-view {
  background-color: #F3F3F4;
  border: 1px solid #9BA3A0;
  margin-bottom: 10px;
  width: 318px; }
  .component.date-view .flex-2 {
    font-weight: 600; }

.page.subscription-subscription-history .component.subscriptions-list {
  border-top: none;
  margin-top: -58px;
  background: transparent; }
  .page.subscription-subscription-history .component.subscriptions-list .subscription-type {
    z-index: 1000;
    padding-right: 0 !important; }

.page.subscription-subscription-history .content.panel-content {
  margin-left: -15px;
  margin-right: -15px;
  border-top: none; }

div.zoho-subscription-set-success-modal span.plan-description {
  border: solid 1px silver;
  border-radius: 3px;
  padding: 0.2rem 0.3rem;
  display: inline-block;
  font-weight: 600;
  background-color: #ebebeb; }

.page.clients-view .clients-view-view-container {
  background-color: white;
  padding: 1.25rem;
  width: 100%;
  min-height: 5rem; }

.page.clients-view span.client-id {
  border: solid 1px silver;
  border-radius: 3px;
  padding: 0.2rem 0.3rem;
  display: inline-block;
  font-weight: 600;
  background-color: #ebebeb; }

.page.clients-view span.viewing {
  position: absolute;
  right: 0.9375rem;
  margin-top: -50px;
  text-align: center;
  background-color: #1986AA;
  padding: 5px 8px;
  border-radius: 3px;
  color: white;
  font-weight: 600; }

.page.clients-view-overview table.branches {
  table-layout: fixed; }
  .page.clients-view-overview table.branches td {
    overflow: inherit;
    white-space: nowrap;
    text-overflow: ellipsis; }

.page.client-view-bills {
  background-color: #F3F3F4;
  padding-top: .05rem;
  margin: -1.25rem -1.25rem -2.5rem -1.25rem; }
  .page.client-view-bills .branch-date-wrapper {
    margin-top: -42px; }
  .page.client-view-bills .component.rangewise-bills-bar-chart #rangewise-bills-bar-chart-wrapper {
    position: relative;
    height: 400px; }
  .page.client-view-bills .component.yearly-bills-bar-chart #yearly-bills-bar-chart-wrapper {
    position: relative;
    height: 400px; }

.page.client-view-users {
  background-color: #F3F3F4; }
  .page.client-view-users .panel {
    border-top: none;
    margin-top: 0; }
    .page.client-view-users .panel .content {
      border-top: none;
      padding: 0; }
  .page.client-view-users .branch-selector-wrapper {
    margin-top: -87px; }

.component.client-status-selector {
  min-width: 100px; }

.component.clients-selector p.input-group {
  width: 15rem; }
  .component.clients-selector p.input-group:last-child {
    margin-bottom: 0; }

.clients-search-modal.modal-body ul {
  margin: 0;
  padding: 0; }
  .clients-search-modal.modal-body ul li {
    border: solid 1px silver;
    padding: 4px 7px;
    font-size: 0.8125rem;
    margin-bottom: 0.5rem;
    cursor: pointer; }
    .clients-search-modal.modal-body ul li span.ui-select-highlight {
      background-color: yellow; }
    .clients-search-modal.modal-body ul li:hover {
      border: solid 1px grey;
      background-color: #eaeaea; }
    .clients-search-modal.modal-body ul li:focus {
      border: solid 1px grey;
      background-color: #EAEAEA;
      outline: none; }
  .clients-search-modal.modal-body ul .inactive {
    border: solid 1px #eb6f6f;
    background-color: #ffe7e7; }

.clients-search-modal.modal-body div.not-found {
  font-size: 1.2rem;
  font-family: Roboto;
  font-weight: 400;
  padding: 2rem; }

.clients-search-modal.modal-body .component.bounce-spinner {
  margin-top: 10px; }

.clients-search-modal.modal-body .bounce-spinner-container {
  margin: 0px auto;
  width: 12px;
  height: 12px;
  top: 2px;
  display: inline-block; }

.view-zoho-subscription-modal .plan {
  border: 1px solid white;
  box-shadow: 0 1px 5px rgba(0, 0, 0, 0.15); }

.view-zoho-subscription-modal .plan-info span.first-column {
  display: inline-block;
  min-width: 150px; }

.view-zoho-subscription-modal .plan-name {
  font-size: 20px; }

.view-zoho-subscription-modal .invoices {
  border-bottom: 1px solid #D7006C; }

.view-zoho-subscription-modal button {
  padding-top: 3px;
  padding-bottom: 3px; }

.page.clients-clients span.clients-search {
  right: 0.9375rem;
  text-align: center;
  background-color: white;
  padding: 5px 15px;
  cursor: pointer;
  border-radius: 3px;
  border: solid 1px silver; }
