/* ===================================================
  THIS IS AN SCSS FILE

  Installation - https://sass-lang.com/install
  > npm install -g sass

  Running manually (go to /src directory):
  > sass style.scss ../public/style.css
  > sass style_dark.scss ../public/style_dark.css

  Running automatically (go to /src directory in two separate windows and run both at same time):
  > sass --watch style.scss ../public/style.css
  > sass --watch style_dark.scss ../public/style_dark.css
  =================================================== */
/* ===================================================
  COLORS 
  =================================================== */
/* ===================================================
  SIZES 
  =================================================== */
/* ===================================================
  GLOBAL FONTS
  FONTS HAVE BEEN MOVED LOCALLY SO THE APP CAN BE USED OFFLINE (FOR THE TRADE SHOW).
  WOFF2 FONTS WILL WORK ON ALL BROWSERS EXCEPT FOR IE AND SAFARI ON EL CAPITAN (2015) OR EARLIER.
  INCOMPATIBLE BROWSERS HAVE AN EXTREMELY LOW MARKET SHARE SO THIS SHOULD BE FINE. THE APP DOES NOT 
  SUPPORT IE AT ALL. WOFF2 IS ABOUT 30% SMALLER THAN WOFF.
  =================================================== */
/* cyrillic-ext */
@font-face {
  font-family: "Inter";
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/UcCO3FwrK3iLTeHuS_fvQtMwCp50KnMw2boKoduKmMEVuI6fAZJhiI2B.woff2) format("woff2");
  unicode-range: U+0460-052F, U+1C80-1C88, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: "Inter";
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/UcCO3FwrK3iLTeHuS_fvQtMwCp50KnMw2boKoduKmMEVuI6fAZthiI2B.woff2) format("woff2");
  unicode-range: U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: "Inter";
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/UcCO3FwrK3iLTeHuS_fvQtMwCp50KnMw2boKoduKmMEVuI6fAZNhiI2B.woff2) format("woff2");
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: "Inter";
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/UcCO3FwrK3iLTeHuS_fvQtMwCp50KnMw2boKoduKmMEVuI6fAZxhiI2B.woff2) format("woff2");
  unicode-range: U+0370-03FF;
}
/* vietnamese */
@font-face {
  font-family: "Inter";
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/UcCO3FwrK3iLTeHuS_fvQtMwCp50KnMw2boKoduKmMEVuI6fAZBhiI2B.woff2) format("woff2");
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: "Inter";
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/UcCO3FwrK3iLTeHuS_fvQtMwCp50KnMw2boKoduKmMEVuI6fAZFhiI2B.woff2) format("woff2");
  unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: "Inter";
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/UcCO3FwrK3iLTeHuS_fvQtMwCp50KnMw2boKoduKmMEVuI6fAZ9hiA.woff2) format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* fallback */
@font-face {
  font-family: "Material Icons";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(fonts/flUhRq6tzZclQEJ-Vdg-IuiaDsNc.woff2) format("woff2");
}
/* fallback */
@font-face {
  font-family: "Material Icons Outlined";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(fonts/gok-H7zzDkdnRel8-DQ6KAXJ69wP1tGnf4ZGhUce.woff2) format("woff2");
}
/* devanagari */
@font-face {
  font-family: "Poppins";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(fonts/pxiEyp8kv8JHgFVrJJbecmNE.woff2) format("woff2");
  unicode-range: U+0900-097F, U+1CD0-1CF6, U+1CF8-1CF9, U+200C-200D, U+20A8, U+20B9, U+25CC, U+A830-A839, U+A8E0-A8FB;
}
/* latin-ext */
@font-face {
  font-family: "Poppins";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(fonts/pxiEyp8kv8JHgFVrJJnecmNE.woff2) format("woff2");
  unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: "Poppins";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(fonts/pxiEyp8kv8JHgFVrJJfecg.woff2) format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: "Roboto";
  src: url(roboto-v48-latin-regular.woff2) format("woff2");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Roboto";
  src: url(roboto-v48-latin-800.woff2) format("woff2");
  font-weight: 800;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Roboto";
  src: url(roboto-v48-latin-500italic.woff2) format("woff2");
  font-weight: 500;
  font-style: italic;
  font-display: swap;
}
.material-icons {
  font-family: "Material Icons";
  font-weight: normal;
  font-style: normal;
  font-size: 24px;
  line-height: 1;
  letter-spacing: normal;
  text-transform: none;
  display: inline-block;
  white-space: nowrap;
  word-wrap: normal;
  direction: ltr;
  -webkit-font-feature-settings: "liga";
  -webkit-font-smoothing: antialiased;
}

.material-icons-outlined {
  font-family: "Material Icons Outlined";
  font-weight: normal;
  font-style: normal;
  font-size: 24px;
  line-height: 1;
  letter-spacing: normal;
  text-transform: none;
  display: inline-block;
  white-space: nowrap;
  word-wrap: normal;
  direction: ltr;
  -webkit-font-feature-settings: "liga";
  -webkit-font-smoothing: antialiased;
}

/* ===================================================
  CSS RESET 
  =================================================== */
html, body {
  min-height: 100%;
}

body {
  margin: 0;
  box-sizing: border-box;
  font-family: "Inter", sans-serif;
  font-size: 14px;
  min-width: 320px;
  color: #393D46;
  background: linear-gradient(125.24deg, #FFFFFF -74.39%, #85B8DE 100%);
}
body div, body span, body input, body button, body textarea {
  box-sizing: border-box;
}
body th button {
  padding: 0;
}
body th button:hover {
  text-decoration-line: underline;
}
body button {
  padding: 0;
}

body.groupMode {
  background: linear-gradient(125.24deg, #FFFFFF -74.39%, #85DEB8 100%);
}

body.disconnectMode {
  background: linear-gradient(125.24deg, #cc6c5f -74.39%, #cc4c1d 100%);
}

h1, h2, h3, h4, h5, h6 {
  font-weight: 600;
}

h1 {
  font-size: 32px;
  margin-top: 0;
}

.save-page h1 {
  width: calc(100% - 240px);
}
@media (max-width: 500px) {
  .save-page h1 {
    width: calc(100% - 32px);
    margin-bottom: 60px;
  }
}

hr {
  border-color: #bcbcbc;
  border-top: none;
}

a {
  text-decoration: none;
  color: #393D46;
}

p {
  color: #6E6B7B;
}

table {
  clear: both;
  width: 100%;
  border-collapse: collapse;
  color: #393D46;
}
table th,
table th button {
  text-align: left;
  font-size: 12px;
  font-weight: 500;
  color: #6E6B7B;
}
table th .material-icons, table th .material-icons-outlined {
  vertical-align: middle;
}
table td {
  font-size: 14px;
  padding-right: 8px;
}
table th, table td {
  padding-right: 4px;
}

form {
  clear: both;
}

label,
.form-title {
  font-size: 12px;
  margin-bottom: 8px;
  display: inline-block;
  color: #6E6B7B;
  display: block;
  user-select: none;
  font-weight: 600;
}

.title {
  font-weight: 600;
  margin-bottom: 8px;
}

.name {
  font-weight: 600;
}

.checkbox-field > span .override {
  margin-right: 10px;
}
.checkbox-field > span {
  margin-right: 16px;
  margin-bottom: 16px;
  display: inline-block;
}
.checkbox-field > span label {
  display: inline;
  line-height: 20px;
  vertical-align: top;
  padding-left: 6px;
  user-select: none;
  color: #393D46;
  font-size: 14px;
  cursor: pointer;
  font-weight: 500;
}
.checkbox-field > span label.small-text {
  font-size: 12px;
  margin-bottom: 0;
}

label.checkbox-label {
  margin-left: 6px;
  display: inline-block;
  vertical-align: text-top;
}

textarea,
input[type=date],
input[type=number],
input[type=email],
input[type=time],
input[type=text],
input[type=tel],
input[type=password] {
  font-family: "Inter", sans-serif;
  font-size: 14px;
  border: 1px solid #aaa;
  border-radius: 10px;
  padding: 10.5px 12px;
  display: block;
  color: #393D46;
  background-color: white;
}
textarea::placeholder,
input[type=date]::placeholder,
input[type=number]::placeholder,
input[type=email]::placeholder,
input[type=time]::placeholder,
input[type=text]::placeholder,
input[type=tel]::placeholder,
input[type=password]::placeholder {
  color: #aaa;
  opacity: 1;
}
textarea:focus,
input[type=date]:focus,
input[type=number]:focus,
input[type=email]:focus,
input[type=time]:focus,
input[type=text]:focus,
input[type=tel]:focus,
input[type=password]:focus {
  border: 1px solid #1F8DED;
}
textarea:hover,
input[type=date]:hover,
input[type=number]:hover,
input[type=email]:hover,
input[type=time]:hover,
input[type=text]:hover,
input[type=tel]:hover,
input[type=password]:hover {
  border: 1px solid #1F8DED;
}
textarea.fullwidth,
input[type=date].fullwidth,
input[type=number].fullwidth,
input[type=email].fullwidth,
input[type=time].fullwidth,
input[type=text].fullwidth,
input[type=tel].fullwidth,
input[type=password].fullwidth {
  width: 100%;
}

input[type=password],
input[type=email] {
  margin-bottom: 16px;
}

input[type=email],
input[type=text],
input[type=password] {
  background-color: white;
}

/* HIDE PASSWORD EYEBALL ON EDGE BROWSER */
::-ms-reveal {
  display: none;
}

input[type=time],
input[type=number],
input[type=tel],
input[type=email] {
  display: inline-block;
  margin-right: 10px;
}

input[type=date],
input[type=time] {
  padding: 9px 12px;
  height: 40px;
}

input[type=radio],
input[type=checkbox] {
  transform: scale(1.5);
}

input[type=radio] {
  margin-right: 8px;
}

input[type=time] {
  -webkit-appearance: none;
}

input[type=file] {
  position: absolute;
  width: 200px;
  height: 40px;
  margin-top: -40px;
  z-index: 10;
  opacity: 0;
  cursor: pointer;
}

label.wrap {
  margin-bottom: 0;
}
label.wrap input, label.wrap select {
  margin-top: 8px;
}

textarea {
  vertical-align: bottom;
  font-size: 14px;
  border: 1px solid #aaa;
  border-radius: 10px;
  padding: 10.5px 12px;
  font-family: "Inter", sans-serif;
}

details {
  border: 1px solid #bcbcbc;
  border-radius: 10px;
  padding: 8px 16px;
  max-width: 700px;
  margin: 0 auto 16px 0;
}
details:hover {
  border-color: #1F8DED;
}
details h3 {
  font-weight: normal;
  border-bottom: 1px solid #bcbcbc;
  font-size: 14px;
  padding-bottom: 4px;
}
details label {
  display: inline-block;
  padding-left: 6px;
}
details summary {
  cursor: pointer;
  padding: 8px 0;
  user-select: none;
}
details summary h2 {
  display: inline-block;
  margin: 0 0 0 8px !important;
  font-weight: normal;
  font-size: 18px;
}
details .details {
  margin-top: 1em;
}

.sms-consent-text {
  font-size: 0.85em;
  color: #555;
  font-weight: bold;
  display: block;
}

@media (min-width: 600px) {
  .sms-consent-text {
    max-width: 55%;
  }
}
/* ===================================================
  SELECTOR
  https://moderncss.dev/custom-select-styles-with-pure-css/
  =================================================== */
.custom-select {
  position: relative;
  display: inline-block;
  margin-right: 10px;
  margin-bottom: 16px;
}
.custom-select label {
  color: #6E6B7B;
  float: none;
}
.custom-select .down-arrow {
  position: absolute;
  right: 10px;
  bottom: 8px;
  z-index: 1;
}
.custom-select .save-message {
  position: absolute;
  left: 0;
  bottom: -20px;
  font-size: 12px;
  width: 200px;
  color: #6E6B7B;
}
.custom-select .list-item {
  cursor: pointer;
  background-color: white;
}
.custom-select .list-item.selected {
  background-color: #CCEEEE;
}
.custom-select .list-item:hover {
  background-color: #ddebf8;
}

.custom-select select,
select.MuiSelect-select {
  color: #393D46;
  display: block;
  font-size: 14px;
  border: 1px solid #aaa;
  border-radius: 10px;
  padding: 11px 40px 11px 16px;
  min-width: 100%;
  appearance: none;
  background-color: transparent;
  cursor: pointer;
  position: relative;
  z-index: 2;
  -webkit-appearance: none;
}
.custom-select select::-ms-expand,
select.MuiSelect-select::-ms-expand {
  display: none;
}
.custom-select select:focus,
select.MuiSelect-select:focus {
  border: 1px solid #1F8DED;
}
.custom-select select option,
select.MuiSelect-select option {
  padding: 10px;
  background-color: white;
}
.custom-select select:hover,
select.MuiSelect-select:hover {
  border-color: #1F8DED;
}
.custom-select select:disabled,
select.MuiSelect-select:disabled {
  cursor: default;
  color: #393D46;
  border-color: #aaa;
}

@media (max-width: 500px) {
  .custom-dropdown select {
    width: 0%;
  }
}
.responsive-flex {
  display: flex;
  align-items: normal;
  overflow: hidden;
  white-space: nowrap;
}

/* Small to Medium Devices: Wrap */
@media (max-width: 1024px) {
  .responsive-flex {
    flex-wrap: wrap;
  }
}
/* Large Devices: No Wrap */
@media (min-width: 1025px) {
  .responsive-flex {
    flex-wrap: nowrap;
  }
}
/* ===================================================
  "LARGE MODE"
  =================================================== */
/*
@media (min-width: 1900px) {
  .fullwidth.account-page,
  .fullwidth.site-page {
    zoom: 1.5;
  }
}
*/
/* ===================================================
  GLOBAL STYLES 
  =================================================== */
.clearfloat {
  clear: both;
}

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

.floatleft {
  float: left;
}

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

.inline {
  display: inline !important;
}

.alignbottom {
  vertical-align: bottom;
}

.top-margin-verysmall {
  margin-top: 2px !important;
}

.top-margin-smaller {
  margin-top: 6px;
}

.top-margin-small {
  margin-top: 10px;
}

.top-margin {
  margin-top: 22px;
}

.left-margin {
  margin-left: 6px;
}

.right-margin {
  margin-right: 6px;
}

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

.bottom-margin {
  margin-bottom: 16px;
}

.bottom-padding {
  padding-bottom: 20px;
}

.indented-text {
  margin-left: 16px;
}

.center {
  text-align: center;
}

.alignright {
  text-align: right;
}

.hidden {
  display: none;
}

.colored-link-text {
  color: #1F8DED;
}

.colored-link-text-red {
  color: #EA5455;
}

.divider {
  width: 5px;
  height: auto;
  display: inline-block;
}

.small-text {
  display: inline-block;
  font-size: 12px;
  margin-bottom: 4px;
}

.medium-text {
  font-size: 14px;
}

.large-text {
  font-size: 17px;
}

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

.units {
  font-size: 12px;
  margin-left: 1px;
  margin-right: 10px;
}

.add.material-icons,
.add.material-icons-outlined {
  font-size: 36px;
  color: #1F8DED;
}
.add.material-icons:hover,
.add.material-icons-outlined:hover {
  background-color: #ddebf8;
}

/*
.alarm-on {
  color: $alarm-on !important;
}
*/
.table-container {
  overflow-x: auto;
}

input.license-counter[type=number]::-webkit-inner-spin-button {
  opacity: 1;
}

input.license-counter[type=number]::-webkit-outer-spin-button {
  opacity: 1;
}

.checkout-summary-row {
  text-indent: 40px;
}

.text-input-wrapper .input-error-message {
  margin-bottom: 16px;
  color: #EA5455;
  margin-top: -10px;
  font-size: 12px;
  font-weight: 600;
  display: none;
}
.text-input-wrapper.input-error-general .input-error-message {
  display: block;
}
.text-input-wrapper.input-error input {
  border-color: #EA5455;
}
.text-input-wrapper.input-error .input-error-message {
  display: block;
  white-space: pre;
}

input.with-right-button, button.with-right-button {
  display: inline-block;
  margin-right: 10px;
  margin-bottom: 16px;
}

button, a.button {
  font-size: 14px;
  border: none;
  border-radius: 10px;
  cursor: pointer;
  transition: 0.3s;
  background-color: transparent;
  text-align: center;
  user-select: none;
  font-weight: 500;
}
button.outlined, a.button.outlined {
  padding: 11px 18px;
  color: #1F8DED;
  border: 1px solid #1F8DED;
}
button.outlined:hover, a.button.outlined:hover {
  color: white;
  background-color: #1F8DED;
}
button.outlined:disabled, a.button.outlined:disabled {
  border-color: #aaa;
  color: #aaa;
}
button.outlined:active, a.button.outlined:active {
  background-color: #1F8DED;
  color: white;
}
button.grey, a.button.grey {
  padding: 11px 18px;
  background-color: #e3e3e3;
  border: 1px solid #e3e3e3;
}
button.down-arrow, a.button.down-arrow {
  position: relative;
  padding-right: 50px;
  border-color: #aaa;
  color: #393D46;
}
button.down-arrow span.material-icons, a.button.down-arrow span.material-icons {
  position: absolute;
  right: 16px;
  top: 50%;
  transform: translateY(-50%);
}
button.danger, a.button.danger {
  padding: 11px 18px;
  border: 1px solid #EA5455;
  color: #EA5455;
}
button.danger:hover, a.button.danger:hover {
  background-color: #EA5455;
  color: white;
}
button.icon, a.button.icon {
  border: 1px solid #1F8DED;
  color: #1F8DED;
  height: 40px;
  line-height: 40px;
  padding: 0 16px;
}
button.icon .material-icons,
button.icon .material-icons-outlined, a.button.icon .material-icons,
a.button.icon .material-icons-outlined {
  vertical-align: middle;
  margin-left: 6px;
  margin-top: -4px;
  color: #1F8DED;
}
button.icon:hover, a.button.icon:hover {
  color: white;
  background-color: #1F8DED;
}
button.icon:hover .material-icons,
button.icon:hover .material-icons-outlined, a.button.icon:hover .material-icons,
a.button.icon:hover .material-icons-outlined {
  color: white;
}
button.add, a.button.add {
  border-color: #e3e3e3;
  background-color: #e3e3e3;
  color: #393D46;
  font-weight: 500;
}
button.add .material-icons,
button.add .material-icons-outlined, a.button.add .material-icons,
a.button.add .material-icons-outlined {
  margin-left: -6px;
  font-size: 32px;
}
button.only-icon, a.button.only-icon {
  border: 1px solid #1F8DED;
  color: #1F8DED;
  line-height: 36px;
  height: 36px;
  padding: 0 5px !important;
}
button.only-icon .material-icons,
button.only-icon .material-icons-outlined, a.button.only-icon .material-icons,
a.button.only-icon .material-icons-outlined {
  vertical-align: middle;
  margin: 0;
  color: #1F8DED;
}
button.only-icon:hover, a.button.only-icon:hover {
  border-color: #1F8DED;
}
button.filled, a.button.filled {
  padding: 11px 18px;
}
button.small, a.button.small {
  border: 1px solid #aaa;
  padding: 8px 14px;
  vertical-align: top;
  line-height: normal !important;
}
button.small:hover, a.button.small:hover {
  border-color: #1F8DED;
}
button.small:disabled, a.button.small:disabled {
  color: #aaa;
  border-color: #aaa !important;
  cursor: default;
}
button.small:disabled:hover, a.button.small:disabled:hover {
  border-color: #aaa !important;
}
button.filled, a.button.filled {
  border: 1px solid #1F8DED;
  background-color: #1F8DED;
  color: white;
}
button.filled:hover, a.button.filled:hover {
  background-color: white;
  color: #1F8DED;
}
button.filled:active, a.button.filled:active {
  background-color: #1F8DED;
  color: white;
}
button.filled:disabled, a.button.filled:disabled {
  cursor: default;
  background-color: #aaa;
  color: white;
  border-color: #aaa !important;
}
button.toggle, a.button.toggle {
  padding: 11px 18px;
  border: 2px solid transparent;
  margin-right: 12px;
  margin-bottom: 16px;
  background-color: #e3e3e3;
  color: #393D46;
}
button.toggle.selected, a.button.toggle.selected {
  border-color: #1F8DED;
}
button.toggle:hover, a.button.toggle:hover {
  background-color: #ddebf8;
}
button.download-file, a.button.download-file {
  border: 1px solid #b62822;
  background-color: #b62822;
  color: white;
  height: 40px;
  line-height: 40px;
  padding: 0 16px;
}
button.download-file .material-icons,
button.download-file .material-icons-outlined, a.button.download-file .material-icons,
a.button.download-file .material-icons-outlined {
  vertical-align: middle;
  margin-left: 6px;
  margin-top: -4px;
  color: white;
}
button.download-file:hover, a.button.download-file:hover {
  border-color: white;
}

.material-icons.trash {
  color: #EA5455;
  cursor: pointer;
}

.subnav a {
  font-size: 16px;
  font-weight: bold;
  margin-right: 16px;
  margin-bottom: 16px;
  display: inline-block;
}
.subnav a.active {
  border-bottom: 2px solid #393D46;
}
.subnav a:hover {
  text-decoration: underline;
}

.none-found {
  clear: both;
  color: #6E6B7B;
  text-align: center;
  font-size: 20px;
  margin: 60px 0 30px;
}

.opaque-background {
  background-color: white;
}

html div.progress-bar {
  background-color: #00ff00 !important;
}

/* ===================================================
  EQUIPMENT NOT CONNECTED ICONS
  =================================================== */
.material-icons.not-connected-icon,
.material-icons-outlined.not-connected-icon {
  color: orange;
  display: none;
}

.not-connected-message {
  display: none;
}

.not-synced .not-connected-message,
.not-synced .material-icons.not-connected-icon,
.not-synced .material-icons-outlined.not-connected-icon {
  display: inline;
  cursor: default;
}

.hardware-alert {
  color: orange;
  font-size: 50%;
  vertical-align: middle;
  background-color: white;
  padding: 6px 10px;
  border-radius: 5px;
}
.hardware-alert .material-icons-outlined {
  color: orange;
  vertical-align: middle;
  margin-right: 6px;
}

.button-list {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.button-list button, .button-list a.button {
  padding: 11px 18px;
  border: 1px solid #aaa;
  color: #393D46;
  margin: 0 auto 12px 0;
  display: block;
  min-width: 250px;
}
.button-list button:hover, .button-list a.button:hover {
  background-color: white;
  border-color: #1F8DED;
  color: #1F8DED;
}

.user-toggle-field button {
  padding: 8.2px 18px;
  user-select: none;
  margin-right: 12px;
  margin-bottom: 16px;
  border: 2px solid transparent;
  border-radius: 10px;
  transition: 0.3s;
  background-color: #e3e3e3;
  height: 40px;
  color: black;
}
.user-toggle-field button img {
  width: 20px;
  height: 20px;
  border-radius: 5px;
  margin-right: 8px;
  vertical-align: middle;
}
.user-toggle-field button.selected {
  border-color: #1F8DED;
  background-color: #ddebf8;
  color: #393D46;
}
.user-toggle-field button:hover {
  background-color: #ddebf8;
}
.user-toggle-field.filled button.selected {
  border-color: #1F8DED;
  background-color: #1F8DED;
  color: white;
  cursor: default;
}

.right-checkbox label {
  display: inline-block;
  margin-right: 12px;
}
.right-checkbox input {
  vertical-align: text-top;
}

table.list {
  font-size: 12px;
}
table.list td {
  height: 49px;
}
table.list td:first-of-type {
  padding-left: 6px;
}
table.list td:last-of-type {
  padding-right: 0;
}
table.list tr.alarm-on {
  border-top: 1px solid #EA5455;
  border-bottom: 1px solid #EA5455;
}
table.list tr.alarm-border-on {
  border-top: 1px solid #EA5455;
  border-bottom: 1px solid #EA5455;
  background-color: #f4e5e5;
}
table.list textarea {
  width: 100%;
}

.material-icons,
.material-icons-outlined {
  color: #5E5873;
  vertical-align: top;
}
.material-icons.selected,
.material-icons-outlined.selected {
  color: #1F8DED;
}
.material-icons.button,
.material-icons-outlined.button {
  fill: black;
  cursor: pointer;
}
.material-icons.button:hover,
.material-icons-outlined.button:hover {
  fill: #777;
}

.settings-button {
  cursor: pointer;
}
.settings-button:hover {
  background-color: #ddebf8;
}

table.info-table tr {
  border: 1px solid #bcbcbc;
}
table.info-table td, table.info-table th {
  padding: 4px;
}

.y-axis-label {
  cursor: pointer;
  fill: black;
  text-decoration: underline;
}
.y-axis-label:hover {
  fill: #1F8DED;
}

.gj-expand {
  cursor: pointer;
  color: #1F8DED;
}
.gj-expand:hover {
  text-decoration: underline;
}

/* LEFT AND RIGHT HALF SECTIONS */
section.left-half, section.right-half {
  float: left;
  box-sizing: border-box;
}
section.left-half {
  width: calc(54% - 16px);
  padding-right: 32px;
  border-right: 1px solid #bcbcbc;
  margin-right: 16px;
}
section.right-half {
  width: calc(46% - 16px);
  padding-left: 32px;
  margin-left: 16px;
}
section {
  /* TWO COLUMS IN TABS; NOT REALLY USED */
}
section .left-tab-column,
section .right-tab-column {
  width: 50%;
  float: left;
}
@media (max-width: 820px) {
  section .left-tab-column,
  section .right-tab-column {
    width: 100%;
    float: none;
  }
  section .right-tab-column {
    margin-top: 12px;
  }
}

/* STACK ON MOBILE */
@media (max-width: 1049px) {
  section.left-half, section.right-half {
    width: 100%;
    float: none;
    margin-left: 0;
    margin-right: 0;
  }
  section.left-half {
    border-right: none;
  }
  section.right-half {
    margin-top: 32px;
  }
}
@media (min-width: 1050px) {
  .zone-page #content-area {
    display: flex;
  }
}
.zone-page {
  /* STACK ON MOBILE WITH SIDEBAR OPEN! */
}
@media (max-width: 1514px) {
  .zone-page .sidebar-open #content-area {
    display: block;
  }
  .zone-page .sidebar-open section.left-half, .zone-page .sidebar-open section.right-half {
    width: 100%;
    float: none;
    margin-left: 0;
    margin-right: 0;
  }
  .zone-page .sidebar-open section.left-half {
    border-right: none;
  }
  .zone-page .sidebar-open section.right-half {
    margin-top: 32px;
  }
}
@media (min-width: 1515px) {
  .zone-page #content-area {
    display: flex;
  }
}

/* PAGING ARROWS AT BOTTOM OF PAGE */
.paging {
  float: right;
  clear: both;
  height: 28px;
  margin-top: 16px;
}
.paging > button {
  padding: 0;
  font-size: 32px;
  line-height: 28px;
  display: inline-block;
  cursor: pointer;
  margin-left: 6px;
  margin-right: 6px;
  color: #393D46;
}
.paging > button:hover {
  color: #1F8DED;
}
.paging .page-range {
  font-size: 14px;
  display: inline-block;
  vertical-align: middle;
  padding-bottom: 10px;
}

/* TIME PERIOD PICKER BUTTON */
.time-period-button {
  border: 1px solid #aaa;
  border-radius: 10px;
  padding: 6px 0 6px 6px;
  cursor: pointer;
  margin-bottom: 16px;
}
.time-period-button table td {
  padding: 3px;
}
.time-period-button:hover {
  border-color: #1F8DED;
}
.time-period-button input {
  width: 100px;
}

.checkbox-list label {
  display: inline-block;
  margin-left: 8px;
  margin-bottom: 14px;
  vertical-align: text-top;
  font-size: 14px;
  color: #393D46;
  font-weight: 500;
}

.select-all {
  font-size: 12px;
  color: #1F8DED;
  text-decoration: underline;
  cursor: pointer;
  user-select: none;
  padding-left: 0;
  vertical-align: text-top;
}

/* ===================================================
  GLOBAL MARGINS 
  =================================================== */
h1,
#breadcrumb-container,
#weather-station,
#content-area,
#footer {
  margin-left: 32px;
  margin-right: 32px;
}

.tab-panel {
  padding: 24px;
}

@media (max-width: 800px) {
  h1,
  .save-page #main #save-header,
  #breadcrumb-container,
  #weather-station,
  #content-area,
  #footer {
    margin-left: 10px;
    margin-right: 10px;
  }
  .tab-panel {
    padding-left: 12px;
    padding-right: 12px;
  }
  #main #content-area section {
    padding: 16px 10px;
    /* CENTER STUFF ON MOBILE */
  }
  #main #content-area section .sensor-grid,
  #main #content-area section .controller-grid,
  #main #content-area section .location-grid-area {
    justify-content: center;
  }
  #main #content-area section .button-list button, #main #content-area section .button-list a.button {
    margin-left: auto;
    margin-right: auto;
  }
  #main #content-area section .list-wrapper {
    text-align: center;
  }
  .save-page #main #save-header {
    top: 60px;
  }
}
/* ===================================================
  REUSABLE ELEMENTS
  =================================================== */
.chart-elements-container,
.grow-journal-select-tags {
  background-color: white;
}
.chart-elements-container div,
.grow-journal-select-tags div {
  background-color: white !important;
  color: #393D46 !important;
  cursor: pointer;
}
.chart-elements-container div:hover,
.grow-journal-select-tags div:hover {
  border-color: #1F8DED;
}

.grow-journal-select-tags {
  width: 180px;
}

.grow-journal-tag,
.on-off-indicator {
  display: inline-block;
  background-color: #6e6b7b;
  color: white;
  border-radius: 10px;
  height: 21px;
  line-height: 21px;
  font-size: 12px;
  padding: 0 10px;
}
.grow-journal-tag.on,
.on-off-indicator.on {
  background-color: #1F8DED;
}

.grow-journal-tag {
  margin-top: 8px;
  margin-right: 4px;
}
.grow-journal-tag.site {
  background-color: #555;
}
.grow-journal-tag.zone {
  background-color: #888;
}
.grow-journal-tag.equipment {
  background-color: #3c6478;
}
.grow-journal-tag.sensors {
  background-color: #107896;
}
.grow-journal-tag.plants {
  background-color: #21B52D;
}
.grow-journal-tag.pests {
  background-color: #000;
}
.grow-journal-tag.nutrients {
  background-color: #da621e;
}
.grow-journal-tag.power {
  background-color: #c02f1d;
}
.grow-journal-tag.personnel {
  background-color: #bca136;
}
.grow-journal-tag.supplies {
  background-color: #43abc9;
}
.grow-journal-tag.maintenance {
  background-color: #613fb5;
}
.grow-journal-tag.documentation {
  background-color: #5ca3cc;
}
.grow-journal-tag.link4 {
  background-color: #204080;
}
.grow-journal-tag.other {
  background-color: #829356;
}

table .grow-journal-tag {
  margin-top: 2px;
  margin-bottom: 4px;
}

table .grow-journal-tag.subscription {
  margin-bottom: 0px;
}

.alarm-icon {
  background-color: #EA5455;
  display: inline-block;
  height: 17px;
  width: 17px;
  color: white;
  text-align: center;
  line-height: 17px;
  margin-left: 8px;
  margin-right: 8px;
  border-radius: 4px;
  padding-left: 6px;
  padding-right: 6px;
  padding-top: 1px;
  padding-bottom: 1px;
}

.lock-icon {
  display: inline-block;
  height: 15px;
  width: 15px;
  color: #EA5455;
  text-align: center;
  line-height: 15px;
  margin-left: 8px;
  margin-right: 8px;
  border-radius: 4px;
}

.controller-container .alarm-icon {
  position: absolute;
  top: 27px;
  right: 16px;
}

.small-alarm-icon {
  display: inline-block;
  background-color: #e3e3e3;
  border-radius: 6px;
  padding: 2px 4px;
  margin-right: 6px;
}
.small-alarm-icon .material-icons-outlined {
  font-size: 20px;
}
.small-alarm-icon.urgent-alarm {
  color: #EA5455;
  background-color: #FEECED;
}
.small-alarm-icon.urgent-alarm .material-icons-outlined {
  color: #EA5455;
}
.small-alarm-icon.resolved-alarm {
  color: #22823C;
  background-color: #71F594;
}
.small-alarm-icon.resolved-alarm .material-icons-outlined {
  color: #22823C;
}

.info-button {
  display: inline-block;
  height: 17px;
  width: 17px;
  text-align: center;
  border: 1px solid #5E5873;
  color: #5E5873;
  border-radius: 4px;
  font-size: 12px;
  line-height: 17px;
  cursor: pointer;
  user-select: none;
}
.info-button.non-auto {
  background-color: #FFEEAA;
}
.info-button.forced {
  background-color: #FFAAAA;
}
.info-button.error {
  background-color: #FF0000;
  color: #FFFFFF;
}
.info-button:hover {
  border-color: #1F8DED;
  background-color: #1F8DED;
  color: white;
}
.info-button:hover:disabled {
  border-color: #bcbcbc;
  background-color: white;
  color: #bcbcbc;
}
.info-button:disabled {
  border-color: #bcbcbc;
  cursor: default;
}

.alarm-on .info-button {
  background-color: #EA5455;
  border-color: #EA5455;
  color: white;
}
.alarm-on .info-button:disabled:hover {
  border-color: #EA5455;
  background-color: #EA5455;
  color: white;
}

.flip {
  transform: scaleX(-1);
  padding: 0;
}

.tabs .tab-controls {
  float: right;
  margin-bottom: -1px;
  border-right: 1px solid #bcbcbc;
}
.tabs .tab-controls .tab {
  float: left;
  font-size: 14px;
  height: 40px;
  line-height: 40px;
  padding: 0 20px;
  border-radius: 0;
  border-top: 1px solid #bcbcbc;
  border-left: 1px solid #bcbcbc;
  background-color: #eeeeee;
  border-bottom: 1px solid #bcbcbc;
  color: #6E6B7B;
  cursor: pointer;
  user-select: none;
}
@media (max-width: 400px) {
  .tabs .tab-controls .tab {
    padding: 0 10px;
    font-size: 12px;
    height: 30px;
    line-height: 30px;
  }
}
.tabs .tab-controls .tab.selected {
  background-color: white;
  border-bottom-color: white;
  cursor: default;
}
.tabs .tab-panels .tab-panel {
  clear: both;
  border: 1px solid #bcbcbc;
  display: none;
}
.tabs .tab-panels .tab-panel.selected {
  display: block;
  overflow-x: auto;
}
.tabs .tab-panels .tab-panel h2 {
  margin: 0 0 32px;
}
.tabs .tab-panels .tab-panel h3 {
  margin: 24px 0 6px;
}
.tabs .tab-panels .tab-panel .title {
  font-size: 12px;
  color: #6E6B7B;
}

/* ===================================================
  MAIN HEADER
  =================================================== */
@media (max-width: 600px) {
  .header-Ricon {
    display: none !important;
  }
}
header#main-header {
  box-sizing: border-box;
  font-family: "Poppins", sans-serif;
  font-size: 16px;
  height: 80px;
  border-bottom: 1px solid #bcbcbc;
  width: 100%;
  position: sticky;
  top: 0;
  left: 0;
  background-color: white;
  z-index: 10;
}
@media (max-width: 1000px) {
  header#main-header {
    height: 60px;
  }
}
header#main-header #main-logo {
  float: left;
  display: flex;
  align-items: center;
  width: 80px;
  height: 80px;
  border-right: 1px solid #bcbcbc;
  justify-content: center;
}
@media (max-width: 1000px) {
  header#main-header #main-logo {
    height: 60px;
  }
}
header#main-header #main-logo img {
  height: 30px;
}
@media (max-width: 1000px) {
  header#main-header #main-logo #version-info {
    display: none !important;
  }
}
header#main-header #mobile-menu-button-container {
  float: left;
  align-items: center;
  height: 80px;
  margin-left: 20px;
  display: none;
}
@media (max-width: 1000px) {
  header#main-header #mobile-menu-button-container {
    height: 60px;
  }
}
header#main-header #mobile-menu-button-container #mobile-menu-button {
  display: block;
  background: #fff;
  width: 32px;
  height: 32px;
  border-radius: 3px;
  box-sizing: border-box;
  padding: 9px 6px;
  cursor: pointer;
  user-select: none;
  background-color: white;
}
header#main-header #mobile-menu-button-container #mobile-menu-button span {
  display: block;
  background: #393D46;
  width: 20px;
  height: 2px;
  border-radius: 3px;
  transform-origin: center;
  transition: 0.3s ease;
}
header#main-header #mobile-menu-button-container #mobile-menu-button span:nth-child(2) {
  margin: 4px 0;
}
header#main-header nav#main-nav {
  float: left;
  font-weight: bold;
  color: #5E5873;
  margin-left: 20px;
}
header#main-header nav#main-nav a, header#main-header nav#main-nav span {
  float: left;
  display: block;
  margin: 0 20px;
  height: 80px;
  line-height: 80px;
  cursor: pointer;
  box-sizing: border-box;
}
@media (max-width: 1000px) {
  header#main-header nav#main-nav a, header#main-header nav#main-nav span {
    height: 60px;
    line-height: 60px;
  }
}
header#main-header nav#main-nav a:hover, header#main-header nav#main-nav span:hover {
  text-decoration-line: underline;
}
header#main-header nav#main-nav a.current-menu-item, header#main-header nav#main-nav span.current-menu-item {
  border-bottom: 2px solid #393D46;
}
@media (min-width: 1300px) {
  header#main-header .sub-icon {
    display: none;
  }
}
@media (max-width: 1300px) {
  header#main-header .sub-section {
    display: none;
  }
}
header#main-header {
  /* MOBILE DROPDOWN MENU */
}
@media (max-width: 1000px) {
  header#main-header #mobile-menu-button-container {
    display: flex;
  }
  header#main-header nav#main-nav {
    position: absolute;
    left: -200px;
    top: 60px;
    background-color: white;
    margin-left: 0;
    border: 2px solid #bcbcbc;
    border-left: none;
    border-top: none;
    width: 200px;
    transition: left 0.4s;
    z-index: 2;
  }
  header#main-header nav#main-nav.mobile-menu-triggered {
    display: block;
    left: 0px;
  }
  header#main-header nav#main-nav a {
    float: none;
    height: auto;
    line-height: normal;
    padding-bottom: 10px;
    margin-bottom: 20px;
    margin-top: 20px;
  }
}
header#main-header #header-notifications {
  float: right;
  align-items: center;
  display: flex;
}
header#main-header #header-notifications #header-alarm {
  position: relative;
  margin: 0 20px;
  cursor: pointer;
}
header#main-header #header-notifications #header-alarm #header-alarm-icon {
  background-color: #5E5873;
  width: 24px;
  height: 24px;
  border-radius: 7px;
  text-align: center;
  color: white;
}
header#main-header #header-notifications #header-alarm #header-alarm-icon:hover {
  background-color: #777;
  border-radius: 7px;
}
header#main-header #header-notifications #header-alarm #header-info-icon {
  background-color: #5E5873;
  width: 24px;
  height: 24px;
  border-radius: 7px;
  text-align: center;
  color: white;
}
header#main-header #header-notifications #header-alarm #header-info-icon:hover {
  filter: brightness(120%);
}
header#main-header #header-notifications #header-alarm #header-notify-icon {
  background-color: #5E5873;
  width: 24px;
  height: 24px;
  border-radius: 7px;
  text-align: center;
  color: white;
}
header#main-header #header-notifications #header-alarm #header-notify-icon:hover {
  background-color: #777;
  border-radius: 7px;
}
header#main-header #header-notifications #header-alarm #header-sites-icon {
  background-color: #5E5873;
  width: 24px;
  height: 24px;
  border-radius: 7px;
  text-align: center;
  color: white;
}
header#main-header #header-notifications #header-alarm #header-sites-icon:hover {
  background-color: #777;
  border-radius: 7px;
}
header#main-header #header-notifications #header-alarm #alarm-number {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #5E5873;
  width: 19px;
  height: 19px;
  border: 2px solid white;
  border-radius: 50%;
  color: white;
  position: absolute;
  top: -13px;
  right: -13px;
  font-size: 12px;
}
header#main-header #header-notifications #header-alarm.alarm-on #header-alarm-icon,
header#main-header #header-notifications #header-alarm.alarm-on #alarm-number {
  background-color: #EA5455;
}
header#main-header #header-notifications #header-alarm.alarm-on #header-alarm-icon:hover,
header#main-header #header-notifications #header-alarm.alarm-on #alarm-number:hover {
  background-color: #ec6a6a;
}
header#main-header #header-notifications #header-settings-icon {
  width: 22px;
  margin: 0 20px;
  font-size: 30px;
  color: #5E5873;
  cursor: pointer;
  float: right;
}
header#main-header #header-notifications #header-settings-icon:hover {
  color: #777;
}
header#main-header #header-notifications #user-name {
  color: #393D46;
  margin-left: 20px;
  font-weight: bold;
  cursor: pointer;
}
@media (max-width: 1000px) {
  header#main-header #header-notifications #user-name {
    display: none;
  }
}
header#main-header #header-notifications #header-portrait {
  height: 80px;
  display: flex;
  align-items: center;
  margin: 0 20px;
  cursor: pointer;
  background-color: transparent;
}
header#main-header #header-notifications #header-portrait img {
  width: 50px;
  height: 50px;
  object-fit: cover;
  border-radius: 16px;
}
@media (max-width: 1000px) {
  header#main-header #header-notifications #header-portrait {
    height: 60px;
  }
  header#main-header #header-notifications #header-portrait img {
    height: 40px;
    width: 40px;
  }
}
header#main-header #header-notifications #header-portrait:hover {
  filter: brightness(120%);
}
@media (max-width: 650px) {
  header#main-header #header-notifications #header-alarm,
  header#main-header #header-notifications #header-settings-icon,
  header#main-header #header-notifications #header-portrait {
    margin: 0 10px;
  }
}

/* ===================================================
  SAVE HEADER
  =================================================== */
#save-header {
  display: none;
}

.save-page {
  /*
  header#main-header {
    position: static;
  }
  */
}
.save-page .save-button-spacer {
  float: right;
  width: 1px;
  height: 12px;
}
.save-page #save-header {
  display: block;
  box-sizing: border-box;
  position: sticky;
  top: 90px;
  left: 0;
  padding: 8px;
  background-color: white;
  height: 51px;
  overflow-y: visible;
  z-index: 3;
  border-radius: 10px;
  margin-right: 32px;
  margin-bottom: 12px;
  float: right;
  margin-top: -60px;
  box-shadow: 0px 4px 24px rgba(0, 0, 0, 0.16);
}
.save-page #save-header .float-right-box {
  float: right;
  display: block;
}
.save-page #save-header .float-right-box button {
  margin-left: 8px;
}
.save-page #save-header #error-notification-slideout,
.save-page #save-header #save-notification-slideout {
  position: absolute;
  bottom: -41px;
  right: 0;
  height: 40px;
  width: 0px;
  line-height: 40px;
  background-color: #E9F3FD;
  color: #1F8DED;
  z-index: 20;
  overflow: hidden;
  font-weight: 600;
  transition: width 0.5s;
}
.save-page #save-header #error-notification-slideout.open,
.save-page #save-header #save-notification-slideout.open {
  width: 180px;
  border: 1px solid #1F8DED;
}
.save-page #save-header #error-notification-slideout {
  background-color: #FEECED;
  color: #EA5455;
}
.save-page #save-header #error-notification-slideout.open {
  border-color: #EA5455;
}
.save-page #save-header .save-cancel-box {
  /* CANCEL BUTTON */
}
.save-page #save-header .save-cancel-box button:first-of-type {
  margin-left: 0;
  color: #393D46;
}
.save-page #page-container {
  margin-top: 0;
}

/* FOR ADD AND TRASH ICONS AFTER SELECTOR */
.after-selector {
  vertical-align: bottom !important;
  margin-bottom: 19px;
  /*
  &.trash {
    margin-bottom: 25px;
  }
  */
}

/* ===================================================
  CONTENT AFTER TITLE
  =================================================== */
#page-container {
  display: flex;
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
  transition: 0.5s;
  clear: both;
}
#page-container.sidebar-open {
  max-width: 1636px;
}

/* ===================================================
  FULL WIDTH PAGES
  =================================================== */
.fullwidth #page-container {
  max-width: none;
}
.fullwidth #page-container.sidebar-open {
  max-width: none;
}

/* ===================================================
  BREADCRUMBS
  =================================================== */
@media (max-width: 600px) {
  #breadcrumb-container {
    flex-wrap: nowrap !important;
  }
  #breadcrumb-container a:not(:has(.home-icon)) {
    text-decoration: underline;
    max-width: 130px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }
}
#breadcrumb-container {
  padding: 10px 0;
  text-align: left;
  font-size: 14px;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}
#breadcrumb-container a, #breadcrumb-container span {
  margin-right: 10px;
}
#breadcrumb-container a {
  cursor: pointer;
}
#breadcrumb-container a:hover {
  text-decoration-line: underline;
}
#breadcrumb-container .back-arrow {
  font-size: 30px;
  font-weight: bold;
  color: #393D46;
  padding-left: 0;
  margin-right: 12px;
  background-color: transparent;
}
@media (max-width: 680px) {
  #breadcrumb-container {
    font-size: 17px;
  }
}

/* ===================================================
  WEATHER STATION
  ==================================================== */
#weather-station {
  border-radius: 10px;
  font-size: 16px;
  overflow-x: auto;
  background-color: white;
  clear: both;
  margin-top: 0px;
  margin-bottom: 20px;
  box-shadow: 0px 4px 24px rgba(0, 0, 0, 0.16);
}
#weather-station .inner {
  display: flex;
  flex-wrap: wrap;
}
#weather-station .inner > span {
  display: block;
  text-align: left;
  font-weight: 500;
  margin-top: 16px;
  margin-bottom: 16px;
  padding-left: 10px;
  padding-right: 22px;
}
#weather-station .inner > span .ws-title {
  font-size: 14px;
  color: #6E6B7B;
}
#weather-station .inner > span .ws-small-icon {
  color: #1F8DED;
  font-size: 20px;
  margin-right: 3px;
}
#weather-station .inner > span#ws-icons {
  display: none;
}
#weather-station .inner > span#ws-icons #snow-icon,
#weather-station .inner > span#ws-icons #rain-icon {
  display: none;
  padding-right: 10px;
}
#weather-station .inner > span#ws-icons.rain, #weather-station .inner > span#ws-icons.snow {
  display: flex;
  justify-content: space-around;
}
#weather-station .inner > span#ws-icons.rain #rain-icon {
  display: block;
}
#weather-station .inner > span#ws-icons.snow #snow-icon {
  display: block;
}
#weather-station .inner > span#ws-icons img {
  height: 48px;
  width: 48px;
}

/* ===================================================
  CONTENT SECTIONS
  ==================================================== */
section.link4 {
  padding: 32px;
  border-radius: 10px;
  margin-bottom: 32px;
  background-color: white;
  box-shadow: 0px 4px 24px rgba(0, 0, 0, 0.16);
}

section.no-section {
  padding: 0 !important;
  box-shadow: none;
  background-color: transparent;
  margin-bottom: 0;
}
section .section-header {
  margin-bottom: 16px;
  min-height: 40px;
}
section .tab-header {
  margin-bottom: 32px;
}
section .section-header, section .tab-header {
  line-height: 40px;
}
section .section-header h2, section .tab-header h2 {
  margin-top: 0;
  display: inline-block;
  line-height: 40px;
}
section .section-header .date, section .section-header .title, section .tab-header .date, section .tab-header .title {
  float: left;
  line-height: 40px;
  font-size: 16px;
  font-weight: 500;
}
section .section-controls,
section .tab-header-controls {
  float: right;
}
section .section-controls a,
section .tab-header-controls a,
section .section-controls div,
section .tab-header-controls div,
section button.material-icons,
section button.download {
  margin-left: 10px;
  height: 40px;
  line-height: 40px;
  text-align: center;
  cursor: pointer;
}
section .section-controls a.list-button, section .section-controls a.grid-button, section .section-controls a.phys-button,
section .tab-header-controls a.list-button,
section .tab-header-controls a.grid-button,
section .tab-header-controls a.phys-button,
section .section-controls div.list-button,
section .section-controls div.grid-button,
section .section-controls div.phys-button,
section .tab-header-controls div.list-button,
section .tab-header-controls div.grid-button,
section .tab-header-controls div.phys-button,
section button.material-icons.list-button,
section button.material-icons.grid-button,
section button.material-icons.phys-button,
section button.download.list-button,
section button.download.grid-button,
section button.download.phys-button {
  font-size: 30px;
  width: 40px;
  border-radius: 10px;
  background-color: #e3e3e3;
}
section .section-controls a.settings-button,
section .tab-header-controls a.settings-button,
section .section-controls div.settings-button,
section .tab-header-controls div.settings-button,
section button.material-icons.settings-button,
section button.download.settings-button {
  font-size: 24px;
  margin-left: 20px;
  min-width: 40px;
  background-color: #e3e3e3;
  border-radius: 10px;
}
section .section-controls a.add,
section .tab-header-controls a.add,
section .section-controls div.add,
section .tab-header-controls div.add,
section button.material-icons.add,
section button.download.add {
  float: left;
  min-width: 40px;
  background-color: #e3e3e3;
  border-radius: 10px;
}
section .section-controls a.download,
section .tab-header-controls a.download,
section .section-controls div.download,
section .tab-header-controls div.download,
section button.material-icons.download,
section button.download.download {
  font-size: 32px;
  margin-left: 16px;
  min-width: 40px;
  background-color: #e3e3e3;
  border-radius: 10px;
}
section .section-controls a.quick-charts,
section .tab-header-controls a.quick-charts,
section .section-controls div.quick-charts,
section .tab-header-controls div.quick-charts,
section button.material-icons.quick-charts,
section button.download.quick-charts {
  font-size: 12px;
  color: #1F8DED;
  float: left;
}
section .section-controls a.quick-charts .material-icons-outlined,
section .tab-header-controls a.quick-charts .material-icons-outlined,
section .section-controls div.quick-charts .material-icons-outlined,
section .tab-header-controls div.quick-charts .material-icons-outlined,
section button.material-icons.quick-charts .material-icons-outlined,
section button.download.quick-charts .material-icons-outlined {
  color: #1F8DED;
  font-size: 24px;
  line-height: 40px;
}
section .section-controls a.quick-charts span,
section .tab-header-controls a.quick-charts span,
section .section-controls div.quick-charts span,
section .tab-header-controls div.quick-charts span,
section button.material-icons.quick-charts span,
section button.download.quick-charts span {
  float: left;
}
section .section-controls a.quick-charts:hover,
section .tab-header-controls a.quick-charts:hover,
section .section-controls div.quick-charts:hover,
section .tab-header-controls div.quick-charts:hover,
section button.material-icons.quick-charts:hover,
section button.download.quick-charts:hover {
  background-color: #ddebf8;
  color: black;
}
section .section-controls a.quick-charts:hover .material-icons-outlined,
section .tab-header-controls a.quick-charts:hover .material-icons-outlined,
section .section-controls div.quick-charts:hover .material-icons-outlined,
section .tab-header-controls div.quick-charts:hover .material-icons-outlined,
section button.material-icons.quick-charts:hover .material-icons-outlined,
section button.download.quick-charts:hover .material-icons-outlined {
  color: black;
}
section .section-controls a:hover,
section .tab-header-controls a:hover,
section .section-controls div:hover,
section .tab-header-controls div:hover,
section button.material-icons:hover,
section button.download:hover {
  background-color: #ddebf8;
}
section .section-controls a.selected,
section .tab-header-controls a.selected,
section .section-controls div.selected,
section .tab-header-controls div.selected,
section button.material-icons.selected,
section button.download.selected {
  background-color: #1F8DED;
  color: white;
  cursor: default;
}
section .date-small,
section .info-popover {
  display: inline-block;
}
section .date-large {
  display: inline-block;
}
section .infoicon-hide {
  display: none;
}
@media (max-width: 600px) {
  section .home-icon {
    margin-right: none;
  }
  section .button-css {
    font-size: 24px;
    margin-left: 10px;
    background-color: #e3e3e3;
    border-radius: 10px;
    padding: 6px;
    color: #1F8DED;
  }
  section .button-css {
    cursor: pointer;
  }
  section .button-css:hover {
    background-color: #ddebf8;
  }
  section .settings-button {
    color: #5E5873;
  }
  section .section-header .date {
    float: none;
  }
  section .date-container {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 5px;
    width: 100%;
  }
  section .infoicon-hide {
    display: inline-block;
  }
  section .date-small {
    display: inline-block;
  }
  section .info-popover {
    display: inline-block;
    margin-top: 9px;
    margin-left: 4px;
    font-size: 20px;
  }
  section .date-large {
    display: inline-block;
  }
}
section {
  /* ===================================================
    SITE GRID
    ==================================================== */
}
section .location-grid-area {
  display: flex;
  justify-content: left;
  flex-wrap: wrap;
  margin-left: -14px;
  width: calc(100% + 28px);
}
section .location-grid-area .location-box-container {
  position: relative;
}
section .location-grid-area .location-box-container .create-grow-journal-entry {
  position: absolute;
  display: none;
  right: 6px;
  bottom: 6px;
  background-color: white;
  border: 1px solid #bcbcbc;
  border-radius: 4px;
  color: #1F8DED;
}
section .location-grid-area .location-box-container .not-connected-icon {
  position: absolute;
  right: 6px;
  top: 6px;
  background-color: white;
  border: 1px solid #bcbcbc;
  border-radius: 4px;
}
@media (max-width: 400px) {
  section .location-grid-area {
    margin-left: 0px;
    width: 100%;
  }
}
section .location-grid-area .location-box {
  display: block;
  width: 300px;
  height: 300px;
  border: 1px solid #bcbcbc;
  border-radius: 6px;
  position: relative;
  overflow: hidden;
  margin: 14px;
  box-sizing: border-box;
  cursor: pointer;
  background-color: white;
  box-shadow: 0px 4px 24px rgba(0, 0, 0, 0.16);
}
@media (max-width: 400px) {
  section .location-grid-area .location-box {
    margin: 14px auto;
  }
}
section .location-grid-area .location-box:hover {
  border-color: #1F8DED;
  box-shadow: 0 0 0 1px #1F8DED;
}
section .location-grid-area .location-box.alarm-on {
  border-color: #EA5455;
}
section .location-grid-area .location-box.alarm-on:hover {
  border-color: #EA5455;
  box-shadow: 0 0 0 1px #EA5455;
}
section .location-grid-area .location-box h2 {
  margin: 10px 16px;
  font-size: 22px;
  max-width: calc(100% - 40px);
  color: #393D46;
}
section .location-grid-area .location-box img {
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 140px;
  object-fit: cover;
}
section .location-grid-area .location-box table tr:nth-child(odd) {
  background-color: transparent;
}
section .location-grid-area .location-box table th {
  padding-left: 16px;
}
section .location-grid-area .location-box table td {
  text-align: right;
  padding-right: 16px;
}
section .location-grid-area .location-box table td, section .location-grid-area .location-box table th {
  height: 25px;
}
section .location-grid-area .location-box table tr.alarm-on {
  border-top: 1px solid #EA5455;
  border-bottom: 1px solid #EA5455;
  background-color: #f4e5e5;
}
@media (max-width: 500px) {
  section .customdrop-section {
    margin-top: 55px;
  }
}
section {
  /* ===================================================
    CONTROLLER LIST
    ==================================================== */
}
section .controller-list {
  overflow-x: auto;
}
section .controller-list table {
  margin-bottom: 9px;
  padding: 5px;
  border-collapse: separate;
  border-spacing: 0 10px;
}
section .controller-list table tr:hover {
  outline: thin solid #1F8DED;
  cursor: pointer;
}
section .controller-list table tr.alarm-on {
  border-color: #EA5455;
  outline: thin solid #EA5455;
}
section .controller-list table tr.alarm-on:hover {
  outline: solid #EA5455;
  cursor: pointer;
}
section .controller-list table tr {
  background-color: white;
  background: white;
  border-radius: 6px;
}
section .controller-list table td:first-child {
  border-radius: 10px 0 0 10px;
}
section .controller-list table td:last-child {
  border-radius: 0 10px 10px 0;
}
section .controller-list table th {
  font-weight: normal;
}
section .controller-list table a.name {
  font-size: 16px;
  width: 100%;
  display: block;
}
@media (max-width: 820px) {
  section .controller-list table a.name {
    font-size: 12px;
  }
}
section .controller-list table div.name {
  display: inline-flex;
}
section .controller-list table .alarm-icon {
  margin: 3px 3px 0;
}
section .controller-list table {
  min-width: 1000px;
}
section {
  /* ===================================================
    SITE LIST
    ==================================================== */
}
section .location-list {
  overflow-x: auto;
}
section .location-list table {
  min-width: 620px;
  margin-bottom: 9px;
  padding: 5px;
  border-collapse: separate;
  border-spacing: 0 10px;
}
section .location-list table .not-connected-icon {
  vertical-align: middle;
}
section .location-list tr:hover {
  outline: thin solid #1F8DED;
  cursor: pointer;
}
section .location-list tr.alarm-on {
  border-color: #EA5455;
  outline: thin solid #EA5455;
}
section .location-list tr.alarm-on:hover {
  outline: solid #EA5455;
  cursor: pointer;
}
section .location-list tr {
  background-color: white;
  background: white;
  border-radius: 6px;
}
section .location-list a.name {
  font-size: 16px;
  width: 100%;
  display: block;
}
@media (max-width: 820px) {
  section .location-list a.name {
    font-size: 12px;
  }
}
section .location-list .alarm-icon {
  margin: 3px 3px 0;
}
section .location-list tr:first-child {
  background: none !important;
  border-radius: 0px;
}
section .location-list tr:first-child:hover {
  outline: none;
  cursor: default;
}
section .location-list td:first-child {
  border-radius: 10px 0 0 10px;
}
section .location-list td:last-child {
  border-radius: 0 10px 10px 0;
}
section {
  /* ===================================================
    CONTROLLER GRID
    ==================================================== */
}
section .controller-grid {
  display: flex;
  justify-content: left;
  flex-wrap: wrap;
  margin-left: -16px;
  width: calc(100% + 32px);
}
@media (max-width: 400px) {
  section .controller-grid {
    margin-left: 0;
    width: 100%;
  }
  section .controller-grid .controller-container .controller-wrapper {
    margin: 14px auto;
  }
}
section .controller-grid .controller-container {
  position: relative;
}
section .controller-grid .controller-container .not-connected-icon {
  position: absolute;
  top: 6px;
  right: 6px;
  background-color: white;
  border: 1px solid #bcbcbc;
  border-radius: 4px;
}
section .controller-grid .controller-container .create-grow-journal-entry {
  position: absolute;
  bottom: 6px;
  right: 6px;
  background-color: white;
  border: 1px solid #bcbcbc;
  border-radius: 4px;
  color: #1F8DED;
}
section .controller-grid .controller-container .controller-wrapper {
  display: block;
  border: 1px solid #bcbcbc;
  border-radius: 6px;
  overflow: hidden;
  margin: 16px;
  padding-bottom: 6px;
  cursor: pointer;
  font-size: 12px;
  background-color: white;
  box-shadow: 0px 4px 24px rgba(0, 0, 0, 0.16);
}
section .controller-grid .controller-container .controller-wrapper:hover {
  border-color: #1F8DED;
  box-shadow: 0 0 0 1px #1F8DED;
}
section .controller-grid .controller-container .controller-wrapper.alarm-on {
  border-color: #EA5455;
}
section .controller-grid .controller-container .controller-wrapper.alarm-on:hover {
  box-shadow: 0 0 0 1px #EA5455;
}
section .controller-grid .controller-container .controller-wrapper table {
  width: 240px;
  line-height: 15px;
  padding: 8px 16px;
  border-collapse: collapse;
}
section .controller-grid .controller-container .controller-wrapper table h2 {
  font-size: 16px;
  line-height: 19px;
  margin: 10px 0 5px;
  text-align: left;
  display: inline-block;
  width: calc(100% - 22px);
  height: 38px;
  overflow: hidden;
}
section .controller-grid .controller-container .controller-wrapper table th {
  padding-left: 16px;
}
section .controller-grid .controller-container .controller-wrapper table tr:nth-child(even) {
  background-color: transparent;
}
section .controller-grid .controller-container .controller-wrapper table tr {
  height: 25px;
}
section .controller-grid .controller-container .controller-wrapper table tr.alarm-on {
  border-top: 1px solid #EA5455;
  border-bottom: 1px solid #EA5455;
  background-color: #f4e5e5;
}
section .controller-grid .controller-container .controller-wrapper table td {
  text-align: right;
  padding-right: 16px;
  font-size: 12px;
}
section {
  /* ===================================================
    EQUIPMENT LIST
    ==================================================== */
}
section .two-column-equipment-list table,
section .equipment-list table {
  max-width: 500px;
}
section .two-column-equipment-list table th,
section .equipment-list table th {
  font-weight: normal;
}
section .two-column-equipment-list table td,
section .equipment-list table td {
  font-size: 14px;
}
section .two-column-equipment-list table a.name,
section .equipment-list table a.name {
  width: 100%;
  display: block;
}
section .two-column-equipment-list table tr.show-details,
section .equipment-list table tr.show-details {
  border-bottom-color: white;
}
section .two-column-equipment-list table tr.show-details + tr,
section .equipment-list table tr.show-details + tr {
  display: table-row;
}
section .two-column-equipment-list table tr.equip-hidden-info,
section .equipment-list table tr.equip-hidden-info {
  display: none;
}
section .two-column-equipment-list table tr.equip-hidden-info td,
section .equipment-list table tr.equip-hidden-info td {
  height: 19px;
}
section .two-column-equipment-list table tr.equip-hidden-info td span,
section .equipment-list table tr.equip-hidden-info td span {
  display: inline-block;
  margin: 0 18px 16px 16px;
}
section .two-column-equipment-list table tr.alarm-on + tr,
section .equipment-list table tr.alarm-on + tr {
  border-bottom: 1px solid #EA5455;
}
section .two-column-equipment-list table th:nth-of-type(3),
section .two-column-equipment-list table td:nth-of-type(3),
section .equipment-list table th:nth-of-type(3),
section .equipment-list table td:nth-of-type(3) {
  text-align: right;
}
section .two-column-equipment-list .left-column, section .two-column-equipment-list .right-column {
  width: 50%;
  float: left;
  box-sizing: border-box;
}
section .two-column-equipment-list .left-column {
  padding-right: 20px;
  border-right: 1px solid #bcbcbc;
}
section .two-column-equipment-list .right-column {
  padding-left: 20px;
}
@media (max-width: 860px) {
  section .two-column-equipment-list .left-column, section .two-column-equipment-list .right-column {
    width: 100%;
    float: none;
    padding: 0 !important;
    border-right: none;
  }
  section .two-column-equipment-list .right-column tr:first-child {
    display: none;
  }
}
section {
  /* ===================================================
    SENSOR GRID
    ==================================================== */
}
section .sensor-grid {
  display: flex;
  justify-content: left;
  flex-wrap: wrap;
  margin-left: -12px;
  width: calc(100% + 24px);
}
section .sensor-grid .sensor-box {
  position: relative;
  width: 180px;
  height: 180px;
  border: 1px solid #bcbcbc;
  border-radius: 6px;
  text-align: center;
  font-size: 12px;
  margin: 12px;
  cursor: pointer;
}
section .sensor-grid .sensor-box .name {
  width: calc(100% - 30px);
  margin: 8px 15px 0;
  overflow: hidden;
}
section .sensor-grid .sensor-box .gauge {
  width: 100%;
  height: auto;
}
section .sensor-grid .sensor-box .stage {
  position: absolute;
  left: 50%;
  bottom: 9px;
  transform: translateX(-50%);
  line-height: 17px;
  padding: 1px 6px;
  border-radius: 8px;
}
section .sensor-grid .sensor-box .stage.heat {
  color: #EA5455;
  background-color: #FEECED;
}
section .sensor-grid .sensor-box .stage.cool {
  color: #1F8DED;
  background-color: #E9F3FD;
}
section .sensor-grid .sensor-box .low-alarm,
section .sensor-grid .sensor-box .high-alarm {
  display: none;
  position: absolute;
  bottom: 10px;
  margin: 0;
}
section .sensor-grid .sensor-box .low-alarm {
  left: 10px;
}
section .sensor-grid .sensor-box .high-alarm {
  right: 10px;
}
section .sensor-grid .sensor-box.low-alarm-on {
  border-color: #EA5455;
  background-color: #f4e5e5;
}
section .sensor-grid .sensor-box.low-alarm-on .low-alarm {
  display: block;
}
section .sensor-grid .sensor-box.low-alarm-on:hover {
  border-color: #EA5455;
  box-shadow: 0 0 0 1px #EA5455;
}
section .sensor-grid .sensor-box.high-alarm-on {
  border-color: #EA5455;
  background-color: #f4e5e5;
}
section .sensor-grid .sensor-box.high-alarm-on .high-alarm {
  display: block;
}
section .sensor-grid .sensor-box.high-alarm-on:hover {
  border-color: #EA5455;
  box-shadow: 0 0 0 1px #EA5455;
}
section .sensor-grid .sensor-box:hover {
  border-color: #1F8DED;
  box-shadow: 0 0 0 1px #1F8DED;
}
@media (max-width: 600px) {
  section .sensor-grid .sensor-box {
    border-radius: 22px;
    border: 2px solid #bcbcbc;
  }
}
section {
  /* ===================================================
    REPORTS AND GRAPHS
  =================================================== */
}
section .reports-and-graphs table.list {
  overflow-x: auto;
}
section .reports-and-graphs table.list td a.name {
  font-size: 16px;
  width: 100%;
  display: block;
}
@media (max-width: 1000px) {
  section .reports-and-graphs table.list td a.name {
    font-size: 12px;
    font-weight: 600;
  }
}
section .reports-and-graphs table.list td a.name:hover {
  text-decoration: underline;
}
section .reports-and-graphs table.list.reports, section .reports-and-graphs table.list.schedules, section .reports-and-graphs table.list.graphs {
  max-width: 1000px;
  min-width: 650px;
}
section .reports-and-graphs table.list.report {
  min-width: 968px;
  max-width: 1800px;
}
section .reports-and-graphs table.list {
  /*
  @media (max-width: 500px)  {
    &.reports tr {
      th:nth-of-type(4),
      td:nth-of-type(4),
      th:nth-of-type(3),
      td:nth-of-type(3) {
        display: none;
      }
    }
  }
  @media (max-width: 600px)  {
    &.schedules tr {
      th:nth-of-type(4),
      td:nth-of-type(4),
      th:nth-of-type(3),
      td:nth-of-type(3) {
        display: none;
      }
    }
  }
  @media (max-width: 720px)  {
    &.graphs tr {
      th:nth-of-type(6),
      td:nth-of-type(6),
      th:nth-of-type(5),
      td:nth-of-type(5) {
        display: none;
      }
    }
  }
  */
}
section .reports-and-graphs .float-right-box label {
  font-size: 14px;
}
section .reports-and-graphs .float-right-box button {
  margin-left: 0;
}
section .reports-and-graphs .float-left-box {
  margin-bottom: 32px;
}
section .time-period-container button.icon .material-icons {
  color: #5E5873;
}
section #edit-report details {
  max-width: 1300px;
  margin-left: 0;
}
section {
  /* DATE RANGE PICKER */
}
section .rdrDateRangePickerWrapper {
  box-shadow: 0px 4px 24px rgba(0, 0, 0, 0.16);
  background-color: white;
}
section .rdrDateRangePickerWrapper .rdrDefinedRangesWrapper {
  background-color: transparent !important;
  border-color: #bcbcbc !important;
}
section .rdrDateRangePickerWrapper .rdrDefinedRangesWrapper button.rdrStaticRange {
  background-color: transparent !important;
  border-color: transparent !important;
  color: #393D46;
}
section .rdrDateRangePickerWrapper .rdrDefinedRangesWrapper button.rdrStaticRange:hover .rdrStaticRangeLabel, section .rdrDateRangePickerWrapper .rdrDefinedRangesWrapper button.rdrStaticRange:focus .rdrStaticRangeLabel {
  background-color: white !important;
}
section .rdrDateRangePickerWrapper .rdrCalendarWrapper {
  background-color: transparent !important;
}
section .rdrDateRangePickerWrapper .rdrCalendarWrapper .rdrDateDisplayWrapper {
  background-color: #EFF2F7;
}
section .rdrDateRangePickerWrapper .rdrCalendarWrapper .rdrDateDisplayWrapper .rdrDateDisplayItem {
  background-color: white;
}
section .rdrDateRangePickerWrapper .rdrCalendarWrapper .rdrDateDisplayWrapper .rdrDateDisplayItem input {
  color: #393D46;
}
section .rdrDateRangePickerWrapper .rdrCalendarWrapper .rdrMonthAndYearWrapper .rdrNextPrevButton {
  background-color: #EFF2F7;
}
section .rdrDateRangePickerWrapper .rdrCalendarWrapper .rdrMonthAndYearWrapper .rdrPprevButton i {
  border-right-color: #393D46;
}
section .rdrDateRangePickerWrapper .rdrCalendarWrapper .rdrMonthAndYearWrapper .rdrNextButton i {
  border-left-color: #393D46;
}
section .rdrDateRangePickerWrapper .rdrCalendarWrapper .rdrMonthAndYearWrapper select {
  color: #393D46;
  background-color: #EFF2F7;
}
section .rdrDateRangePickerWrapper .rdrCalendarWrapper .rdrDayNumber span {
  color: #393D46;
}
section .rdrDateRangePickerWrapper .rdrCalendarWrapper .rdrDayPassive .rdrDayNumber span {
  color: #bcbcbc;
}
section {
  /* ===================================================
    GRAPH PAGE
  =================================================== */
}
section .time-period-container {
  float: left;
  margin-right: 16px;
  margin-bottom: 1em;
}
section .time-period-container button.icon {
  color: #393D46;
  border-color: #aaa;
}
section .time-period-container button.icon:hover {
  border-color: #1F8DED;
}
section .chart-elements-container {
  float: left;
  margin-right: 16px;
}
section .chart-elements-container div:nth-of-type(2) {
  cursor: pointer;
}
section .chart-elements-container div:nth-of-type(2) div {
  cursor: pointer !important;
}
section .chart-elements-container:hover {
  border-color: #1F8DED;
}
section .data-markers-box {
  margin-top: 35px;
  margin-bottom: 0 !important;
}
@media (max-width: 700px) {
  section .chart-elements-container,
  section .data-markers-box {
    clear: both;
  }
  section .data-markers-box {
    margin-top: 20px;
  }
}
section #main-graph {
  width: 100%;
  margin-top: 32px;
  margin-bottom: 1px;
  height: 40vw;
  max-height: 400px;
  min-height: 150px;
}
section #guide-graph {
  width: 100%;
  margin-top: 12px;
  margin-bottom: 32px;
  height: 10vw;
  max-height: 100px;
  min-height: 70px;
}
section .float-left-box {
  float: left;
  margin-right: 13px;
}
section .float-right-box {
  float: right;
  box-sizing: border-box;
}
section .float-right-box h3 {
  margin-top: 0;
  font-size: 16px;
  font-weight: 500;
}
section .float-right-box input[type=text] {
  margin-bottom: 16px;
  width: calc(100% - 32px);
}
section .float-right-box {
  /*
  button {
    margin-left: 16px;
  }
  */
}
section .float-right-box .spacer {
  height: 16px;
  clear: both;
}

.float-right-box label,
.float-left-box label {
  display: inline-block;
  line-height: 20px;
  vertical-align: top;
  margin-right: 12px;
}

.graph-axis-popup {
  width: 300px;
}
.graph-axis-popup h2 {
  margin-top: 0;
}
.graph-axis-popup .float-left-box {
  margin-right: 0;
  width: 100%;
}
.graph-axis-popup .manual-axis-selector {
  margin-top: 1em;
  display: none;
}
.graph-axis-popup .manual-axis-selector input {
  width: 80px;
  margin-right: 4px;
}
.graph-axis-popup .color-selector {
  margin-top: 1em;
  margin-bottom: 2em;
}
.graph-axis-popup .axis-color-picker {
  display: flex;
  justify-content: space-between;
}
.graph-axis-popup .axis-color-picker button {
  width: 24px;
  height: 24px;
  background-color: blue;
  box-sizing: content-box;
  border: 2px solid white;
}
.graph-axis-popup .axis-color-picker button.selected {
  box-shadow: 0 0 0 2px #393D46;
}

.table-container {
  overflow-x: auto;
}

/* ===================================================
  ALARM PAGES
  =================================================== */
table.active-alarms-table {
  min-width: 720px;
  max-width: 1500px;
}
table.active-alarms-table th {
  height: 30px;
}
table.active-alarms-table td {
  height: 49px;
}
table.active-alarms-table td:nth-of-type(3),
table.active-alarms-table td:nth-of-type(4) {
  font-size: 16px;
}
table.active-alarms-table td:nth-of-type(9) {
  color: #EA5455;
}
table.active-alarms-table tr.spacer td {
  height: 10px;
}
@media (max-width: 1000px) {
  table.active-alarms-table td {
    font-size: 12px !important;
  }
}

table.alarms-table {
  min-width: 920px;
  max-width: 1500px;
}
table.alarms-table th {
  height: 30px;
}
table.alarms-table td {
  height: 49px;
}
table.alarms-table td:nth-of-type(3) {
  font-size: 16px;
}

table.notification-log-table {
  min-width: 800px;
  max-width: 1200px;
}
table.notification-log-table tr {
  border-bottom: 10px solid white;
}

/* ===================================================
  MAIN BODY AND RIGHT SIDEBAR
  =================================================== */
main#main {
  width: calc(100% - 32px);
  transition: 0.5s;
}
main#main.no-sidebar {
  width: 100%;
}

#right-sidebar {
  width: 30px;
  transition: 0.5s;
  box-sizing: border-box;
  transition: all 0.5s;
}
#right-sidebar #sidebar-arrow {
  font-size: 30px;
  position: fixed;
  top: 50%;
  text-align: center;
  cursor: pointer;
  user-select: none;
  padding: 4px;
  z-index: 2;
  margin-left: -21px;
  color: #5E5873;
  background-color: white;
  box-shadow: 0px 4px 24px rgba(0, 0, 0, 0.46);
}
#right-sidebar #sidebar-arrow:hover {
  background-color: #ddebf8;
}
#right-sidebar #sidebar-content {
  margin-left: 28px;
  margin-right: 32px;
  position: fixed;
  top: 90px;
  width: 0px;
  overflow: hidden;
  transition: all 0.5s;
  background-color: white;
  margin-top: 14px;
}
#right-sidebar #sidebar-content .inner {
  width: 433px;
  padding: 20px;
}
#right-sidebar .floatright.material-icons-outlined,
#right-sidebar .floatright .material-icons-outlined {
  padding-right: 0;
}
#right-sidebar .floatright .only-icon {
  margin-left: 18px;
}

@media (max-width: 1000px) {
  #right-sidebar {
    position: fixed;
    right: 0;
    z-index: 5;
    width: 0;
    border-left: none;
  }
  #right-sidebar #sidebar-content {
    margin-left: 0px;
    margin-right: 0px;
    top: 60px !important;
    background-color: white;
  }
  #right-sidebar #sidebar-arrow {
    padding-left: 0;
    display: block;
  }
  main#main {
    width: 100% !important;
  }
}
#page-container.sidebar-open #right-sidebar #sidebar-content {
  width: 433px;
  transition: all 0.5s;
  border-radius: 10px;
  height: calc(100vh - 150px);
  overflow-y: auto;
  box-shadow: 0px 4px 24px rgba(0, 0, 0, 0.46);
}
#page-container.sidebar-open #right-sidebar #sidebar-content::-webkit-scrollbar {
  width: 0px;
}
#page-container.sidebar-open main#main {
  width: calc(100% - 497px);
  transition: all 0.5s;
}
#page-container.sidebar-open #page-container {
  position: relative;
}
@media (max-width: 1000px) {
  #page-container.sidebar-open #right-sidebar {
    width: 320px;
  }
  #page-container.sidebar-open #right-sidebar #sidebar-content {
    width: 320px;
    height: calc(100vh - 80px);
    box-shadow: 0px 4px 24px rgba(0, 0, 0, 0.46);
  }
  #page-container.sidebar-open #right-sidebar #sidebar-content .inner {
    width: 320px;
    padding: 20px 20px 10px 10px;
  }
  #page-container.sidebar-open #sidebar-arrow {
    padding-right: 0;
    position: fixed;
    margin-left: -10px;
  }
}

@media (max-width: 1000px) {
  .arrows-key {
    margin-left: 0px !important;
    position: inherit !important;
  }
}
/* ===================================================
  RIGHT SIDEBAR / GROW JOURNAL
  =================================================== */
table.grow-journal-table {
  min-width: 900px;
  max-width: 1300px;
}
table.grow-journal-table td:first-of-type {
  font-size: 16px;
}
table.grow-journal-table tr.unread td {
  font-weight: bold;
}
table.grow-journal-table tr.unread td .grow-journal-tag {
  font-weight: normal;
}

.info-section,
#grow-journal-entry-page {
  margin-top: 6px;
  clear: both;
}
.info-section .title,
#grow-journal-entry-page .title {
  float: left;
  margin-bottom: 12px;
  font-size: 14px;
}
.info-section button.read-all, .info-section a.read-all,
#grow-journal-entry-page button.read-all,
#grow-journal-entry-page a.read-all {
  float: right;
  color: #1F8DED;
  cursor: pointer;
}
.info-section .body,
#grow-journal-entry-page .body {
  clear: both;
  margin-top: 1em;
  max-width: 800px;
}
.info-section .body img,
#grow-journal-entry-page .body img {
  display: block;
  margin: 1em 0;
  cursor: pointer;
}
.info-section .body .full,
#grow-journal-entry-page .body .full {
  display: none;
}
.info-section .journal-entry,
#grow-journal-entry-page .journal-entry {
  margin-top: 2em;
  position: relative;
}
.info-section .journal-entry.reply,
#grow-journal-entry-page .journal-entry.reply {
  margin-top: 2em;
  margin-left: 2em;
  margin-bottom: 6px;
  display: none;
}
.info-section .journal-entry.reply.edit,
#grow-journal-entry-page .journal-entry.reply.edit {
  display: block;
}
.info-section .journal-entry textarea,
#grow-journal-entry-page .journal-entry textarea {
  width: 100%;
}
.info-section .hide,
#grow-journal-entry-page .hide {
  display: none;
}
.info-section.expanded .hide,
#grow-journal-entry-page.expanded .hide {
  display: inline-block;
}
.info-section.expanded .body .full,
.info-section.expanded .journal-entry.reply,
#grow-journal-entry-page.expanded .body .full,
#grow-journal-entry-page.expanded .journal-entry.reply {
  display: block;
}
.info-section.expanded .show,
.info-section.expanded .body .excerpt,
#grow-journal-entry-page.expanded .show,
#grow-journal-entry-page.expanded .body .excerpt {
  display: none;
}
.info-section .floatleft span,
#grow-journal-entry-page .floatleft span {
  font-weight: 500;
}
.info-section .floatleft label,
#grow-journal-entry-page .floatleft label {
  display: inline-block;
}
.info-section .floatleft input[type=checkbox],
#grow-journal-entry-page .floatleft input[type=checkbox] {
  vertical-align: text-top;
  margin-right: 10px;
}
.info-section .floatleft img,
#grow-journal-entry-page .floatleft img {
  width: 35px;
  height: 35px;
  object-fit: cover;
  vertical-align: middle;
  margin-right: 12px;
  border-radius: 8px;
}
.info-section.managed-by .title,
#grow-journal-entry-page.managed-by .title {
  margin-top: 8px;
}
.info-section .floatright .time-date, .info-section .floatright.time-date,
#grow-journal-entry-page .floatright .time-date,
#grow-journal-entry-page .floatright.time-date {
  font-size: 12px;
  color: #6E6B7B;
  margin-top: 5px;
}
.info-section .floatright .time-date button, .info-section .floatright.time-date button,
#grow-journal-entry-page .floatright .time-date button,
#grow-journal-entry-page .floatright.time-date button {
  vertical-align: middle;
  margin-left: 6px;
}
.info-section .floatright .time-date button.add, .info-section .floatright.time-date button.add,
#grow-journal-entry-page .floatright .time-date button.add,
#grow-journal-entry-page .floatright.time-date button.add {
  font-size: 24px;
  background-color: transparent;
}
.info-section .floatright .time-date button:hover, .info-section .floatright.time-date button:hover,
#grow-journal-entry-page .floatright .time-date button:hover,
#grow-journal-entry-page .floatright.time-date button:hover {
  background-color: #ddebf8;
}
.info-section .floatright img,
#grow-journal-entry-page .floatright img {
  width: 35px;
  height: 35px;
  object-fit: cover;
  vertical-align: middle;
  margin-right: 12px;
}
.info-section .floatright img.small,
#grow-journal-entry-page .floatright img.small {
  width: 20px;
  height: 20px;
}
.info-section .floatright .due,
#grow-journal-entry-page .floatright .due {
  text-align: right;
  font-size: 12px;
  float: right;
  margin-top: 4px;
}
.info-section.audit-log-reply,
#grow-journal-entry-page.audit-log-reply {
  margin-left: 2em;
  margin-bottom: 6px;
}

.load-more {
  margin-top: 1em;
  display: inline-block;
}

.spinner {
  margin-left: 18px;
  padding-top: 5px;
  display: inline-block;
  float: left;
}

.spinnerGraph {
  margin-right: 4px;
  display: inline-block;
  float: left;
}

.photo-grid {
  clear: both;
  margin-top: 6px;
  text-align: center;
}
.photo-grid button {
  margin: 7.5px;
  display: inline-block;
  padding: 0;
}
.photo-grid button img {
  width: 105px;
  height: 105px;
  object-fit: cover;
  border-radius: 10px;
}
@media (max-width: 1000px) {
  .photo-grid button img {
    width: 80px;
    height: 80px;
  }
}

#sidebar-tasks .floatleft input[type=checkbox] {
  vertical-align: top;
}
#sidebar-tasks .floatleft label {
  max-width: 200px;
}
#sidebar-tasks .floatright {
  max-width: 160px;
}
@media (max-width: 1000px) {
  #sidebar-tasks .floatleft label {
    max-width: calc(100% - 28px);
  }
}

#sidebar-media img {
  margin: 1em 0;
  cursor: pointer;
}

#sidebar-alarms .floatleft .alarm-name {
  max-width: 200px;
  display: inline-block;
  vertical-align: top;
}
@media (max-width: 1000px) {
  #sidebar-alarms .floatleft .alarm-name {
    max-width: calc(100% - 52px);
  }
}

#sidebar-audit-log .floatleft {
  max-width: 230px;
}
#sidebar-audit-log .floatleft .log-entry {
  margin-bottom: 4px;
  display: inline-block;
}
#sidebar-audit-log .floatleft .change {
  font-size: 17px;
}
#sidebar-audit-log .floatright {
  max-width: 160px;
}
@media (max-width: 1000px) {
  #sidebar-audit-log .floatleft {
    max-width: 100%;
  }
}

.file-upload-form {
  clear: none !important;
  float: left !important;
}

/* ===================================================
  GROW JOURNAL PAGE (INHERITS FROM SIDEBAR)
  ==================================================== */
#grow-journal-entry-page {
  max-width: 1000px;
}
#grow-journal-entry-page h2 {
  margin-top: 36px;
  margin-bottom: 0;
}
#grow-journal-entry-page .floatright.time-date {
  font-size: 14px;
  font-weight: 500;
  color: #393D46;
}
#grow-journal-entry-page .replies-container {
  max-width: 590px;
}
#grow-journal-entry-page .replies-container textarea {
  width: 100%;
}

/* ===================================================
    GENERAL INFO PAGE
   =================================================== */
#general-info-page h2:first-of-type {
  margin-top: 0;
}
#general-info-page textarea {
  width: 100%;
  padding: 16px;
}
#general-info-page textarea#crop-info {
  min-height: 300px;
}
#general-info-page textarea#zone-info {
  min-height: 150px;
}

/* ===================================================
  IMAGE POPUPS
  ==================================================== */
.image-popup {
  z-index: 10;
  position: fixed;
  left: 50%;
  top: 10%;
  transform: translateX(-50%);
  max-width: 96%;
}
.image-popup .image-close-button {
  position: absolute;
  top: 0;
  right: 0;
  background-color: white;
}
.image-popup .image-button:hover {
  background-color: #C8C8C8;
}

/* ===================================================
  SENSOR ORDERING LIST
  ==================================================== */
.list-wrapper {
  text-align: left;
}
.list-wrapper ul.ordering-list {
  list-style-type: none;
  padding-left: 0;
  display: inline-block;
}
.list-wrapper ul.ordering-list li {
  margin-bottom: 10px;
  border: 1px solid #bcbcbc;
  border-radius: 10px;
  padding: 8px 48px;
  position: relative;
}
.list-wrapper ul.ordering-list li span, .list-wrapper ul.ordering-list li button {
  vertical-align: middle;
  cursor: pointer;
}
.list-wrapper ul.ordering-list li span.sensor-name, .list-wrapper ul.ordering-list li button.sensor-name {
  margin: 0 10px 0 10px;
  cursor: default;
  font-size: 14px;
  line-height: 16px;
}
.list-wrapper ul.ordering-list li span.up-arrow, .list-wrapper ul.ordering-list li span.down-arrow, .list-wrapper ul.ordering-list li button.up-arrow, .list-wrapper ul.ordering-list li button.down-arrow {
  height: 28px;
  line-height: 28px;
  background-color: white;
}
.list-wrapper ul.ordering-list li span.up-arrow, .list-wrapper ul.ordering-list li button.up-arrow {
  position: absolute;
  left: 10px;
  top: 3px;
  border: 2px solid;
  border-radius: 50%;
  padding: 0;
}
.list-wrapper ul.ordering-list li span.up-arrow:hover, .list-wrapper ul.ordering-list li button.up-arrow:hover {
  color: #1F8DED;
}
.list-wrapper ul.ordering-list li span.down-arrow, .list-wrapper ul.ordering-list li button.down-arrow {
  position: absolute;
  right: 10px;
  top: 3px;
  border: 2px solid;
  border-radius: 50%;
  padding: 0;
}
.list-wrapper ul.ordering-list li span.down-arrow:hover, .list-wrapper ul.ordering-list li button.down-arrow:hover {
  color: #1F8DED;
}
.list-wrapper ul.ordering-list li span.hide, .list-wrapper ul.ordering-list li button.hide {
  display: none;
}
.list-wrapper ul.ordering-list li.last-moved {
  border-color: #1F8DED;
  background-color: #1F8DED;
  color: white;
}
.list-wrapper ul.ordering-list li.last-moved .up-arrow,
.list-wrapper ul.ordering-list li.last-moved .down-arrow {
  color: #1F8DED;
}
.list-wrapper ul.ordering-list li.last-moved .up-arrow:hover,
.list-wrapper ul.ordering-list li.last-moved .down-arrow:hover {
  color: #1F8DED;
}

/* ===================================================
    AUX SETTINGS
  ==================================================== */
.aux table {
  max-width: 800px;
  margin: 0;
}
.aux td:first-of-type {
  width: 100px;
}
.aux td:first-of-type input {
  width: 200px;
}
.aux td:nth-of-type(2) {
  width: 50px;
  text-align: center;
}

.aux-element {
  border: 1px solid #bcbcbc;
  border-radius: 12px;
  display: flex;
  padding: 12px 6px;
  margin-bottom: 36px;
  max-width: 850px;
}
.aux-element .left {
  position: relative;
  width: 36px;
}
.aux-element .left .up-arrow,
.aux-element .left .down-arrow {
  padding-right: 0;
  margin-left: 0;
}
.aux-element .left .trash {
  position: absolute;
  left: 0;
  bottom: 0;
  margin-left: 0;
}
.aux-element .right {
  width: calc(100% - 36px);
}
.aux-element .right .body {
  font-size: 16px;
}
.aux-element .right .body button {
  border: 1px solid #aaa;
  border-radius: 6px;
  padding: 4px;
  cursor: pointer;
  display: inline-block;
  margin: 4px 0;
  font-size: 16px;
  color: #393D46;
}
.aux-element .right .body button:hover {
  border-color: #393D46;
}
.aux-element .right .body input[type=text] {
  width: 100px;
  display: inline-block;
}
.aux-element .right .body input[type=time],
.aux-element .right .body .custom-select {
  margin-right: 0;
}
.aux-element .right .bottom {
  margin-top: 12px;
}
.aux-element .right .bottom textarea {
  width: 100%;
  max-width: 750px;
}

/* ===================================================
    ZONE AUX CONTROLS (OLD MATERIAL UI VERSION)
  ==================================================== */
.zone_Aux_Controls .aux-wrapper {
  width: 400px;
  background-color: #EFF2F7;
  padding: 10px;
  border: 1px solid #bcbcbc;
}
.zone_Aux_Controls .aux-container {
  height: 200px;
  overflow-y: auto;
}

/* ===================================================
  SETTINGS PAGES
  =================================================== */
.site-image {
  margin-top: 12px;
}
.site-image img {
  max-height: 200px;
}

.time-enable {
  margin-bottom: 12px;
}

.user-table-container {
  overflow-x: auto;
}
.user-table-container table.user-table {
  min-width: 1000px;
}
.user-table-container table.user-table td {
  padding-right: 16px;
  padding-top: 10px;
}
.user-table-container table.user-table td img {
  width: 35px;
  height: 35px;
  object-fit: cover;
  vertical-align: middle;
  margin-right: 12px;
  border-radius: 8px;
}
.user-table-container table.user-table th:first-of-type,
.user-table-container table.user-table td:first-of-type {
  width: 46px;
  min-width: 46px;
  padding-right: 0;
}
.user-table-container table.user-table .active {
  background-color: #1F8DED;
}
.user-table-container table.user-table .pending {
  background-color: #777;
}
.user-table-container table.user-table .inactive {
  background-color: #aaa;
}
.user-table-container table.user-table .owner {
  background-color: #595;
}
.user-table-container table.user-table .thirdParty {
  background-color: #980;
}
.user-table-container table.user-table .pending, .user-table-container table.user-table .active, .user-table-container table.user-table .inactive, .user-table-container table.user-table .owner, .user-table-container table.user-table .thirdParty {
  display: inline-block;
  font-size: 12px;
  border-radius: 10px;
  padding: 3px 10px 3px;
  color: white;
}
.user-table-container table.user-table button.invitation {
  color: #1F8DED;
}

.user-table-container table.user-table button.invitation:disabled {
  color: #999;
}

.task-table-container {
  overflow-x: auto;
}
.task-table-container table.task-table {
  min-width: 1000px;
}
.task-table-container table.task-table td {
  padding-right: 16px;
  padding-top: 10px;
}
.task-table-container table.task-table td img {
  width: 35px;
  height: 35px;
  object-fit: cover;
  vertical-align: middle;
  margin-right: 12px;
  border-radius: 8px;
}

.custom-color-select-container {
  text-align: right;
}
.custom-color-select-container .custom-color-select-selection {
  border-radius: 10px;
  right: 0px;
  margin-bottom: initial;
  padding: 0px 40px 0px 16px;
  border: 1px solid #aaa;
}
.custom-color-select-container .custom-color-select-list {
  border-radius: 10px;
  height: initial;
  text-align: left;
  background-color: #FFCCCC;
  border-radius: 10px;
}
.custom-color-select-container .custom-color-select-list td {
  padding: 0px 20px;
  background-color: white;
}
.custom-color-select-container .custom-color-select-list td.over {
  background-color: #EFF2F7;
}

.bubble-text {
  display: inline-block;
  font-size: 12px;
  line-height: 21px;
  border-radius: 10px;
  padding: 3px 10px 3px;
  color: white;
  background-color: #4bd087;
}

.bubble-text.status-created {
  background-color: #f3bb2a;
}

.bubble-text.status-approved {
  background-color: #80d04b;
}

.bubble-text.status-readyToStart {
  background-color: #c7d04b;
}

.bubble-text.status-inProgress {
  background-color: #1f8ded;
}

.bubble-text.status-onHold {
  background-color: #a8a8a8;
}

.bubble-text.status-cancelled {
  background-color: #4bb5d0;
}

.bubble-text.status-waitingForReview {
  background-color: #4bd0a4;
}

.bubble-text.status-complete {
  background-color: #4bd087;
}

.bubble-text.status-problem {
  background-color: #d04b4b;
}

.bubble-text.priority-low {
  background-color: #254bb7;
}

.bubble-text.priority-medium {
  background-color: #5fb725;
}

.bubble-text.priority-high {
  background-color: #adb725;
}

.bubble-text.priority-urgent {
  background-color: #b72525;
}

.bubble-text.category-greenhouse {
  background-color: #bf0065;
}

.bubble-text.category-waterPlants {
  background-color: #bf0243;
}

.bubble-text.category-hydroponic {
  background-color: #b62822;
}

.bubble-text.category-flowerBeds {
  background-color: #a54000;
}

.bubble-text.category-generalMaintenance {
  background-color: #726000;
}

.bubble-text.category-manualLabor {
  background-color: #526a00;
}

.bubble-text.category-plantGrowth {
  background-color: #247000;
}

.bubble-text.category-generalPlantCare {
  background-color: #007514;
}

.bubble-text.category-straightTruck {
  background-color: #00795f;
}

.bubble-text.category-prune {
  background-color: #007982;
}

.bubble-text.category-seasonalPosition {
  background-color: #0077a1;
}

.bubble-text.category-plantMaintenance {
  background-color: #0074ba;
}

.bubble-text.category-dig {
  background-color: #0066d1;
}

.bubble-text.category-assemblyLine {
  background-color: #4159cb;
}

.bubble-text.category-regularBasis {
  background-color: #7949bc;
}

tr.tableBand {
  background-color: #CCCCCC;
}

table.user-access tr {
  height: 32px;
}
table.user-access th {
  color: #6E6B7B;
  padding-top: 12px;
}
table.user-access th:nth-child(1),
table.user-access th:nth-child(2),
table.user-access td:nth-child(1),
table.user-access td:nth-child(2) {
  text-align: center;
  width: 40px;
}
table.user-access th:nth-child(3),
table.user-access td:nth-child(3) {
  padding-left: 20px;
}
table.user-access:first-of-type {
  max-width: 260px;
}

.idoser input, .idoser textarea,
.modbus input,
.modbus textarea {
  min-width: 225px;
}
.idoser input.narrow,
.idoser input[type=number],
.idoser input[type=tel],
.modbus input.narrow,
.modbus input[type=number],
.modbus input[type=tel] {
  min-width: 0;
  width: 90px;
}
.idoser input[type=time],
.idoser input[type=date],
.modbus input[type=time],
.modbus input[type=date] {
  min-width: 0;
  margin-right: 10px;
}
.idoser input[type=text],
.modbus input[type=text] {
  margin-right: 10px;
}
.idoser,
.modbus {
  /*
  .trash {
    vertical-align: sub;
  }
  */
}
.idoser .material-icons-outlined.add,
.modbus .material-icons-outlined.add {
  padding-left: 0;
  background-color: transparent;
}
.idoser .line,
.modbus .line {
  clear: both;
  margin-bottom: 6px;
  white-space: nowrap;
}
.idoser .line input,
.idoser .line .custom-select,
.modbus .line input,
.modbus .line .custom-select {
  margin-bottom: 10px;
}
.idoser .line .label,
.modbus .line .label {
  margin-right: 16px;
  min-width: 170px;
  display: inline-block;
}
.idoser .toggle-field,
.modbus .toggle-field {
  max-width: 570px;
}
.idoser .toggle-field button,
.modbus .toggle-field button {
  min-width: 78px;
}
.idoser .toggle-field.days,
.modbus .toggle-field.days {
  max-width: 660px;
}
.idoser .toggle-field.days-of-month,
.modbus .toggle-field.days-of-month {
  max-width: 500px;
}
.idoser .toggle-field.days-of-month button,
.modbus .toggle-field.days-of-month button {
  min-width: 54px;
}
.idoser .index-field,
.modbus .index-field {
  max-width: 1150px;
}
.idoser .index-field span,
.modbus .index-field span {
  margin-bottom: 16px;
  min-width: 136px;
  text-align: right;
}
.idoser .index-field span input,
.modbus .index-field span input {
  min-width: 100px;
  width: 100px;
}

.zone-box {
  padding: 10px;
  border: 1px solid;
  border-radius: 10px;
  min-height: 300px;
}

@media (min-width: 700px) {
  .zone-box {
    width: 500px;
    min-height: 300px;
    padding: 10px;
    border: 1px solid;
    border-radius: 10px;
  }
}
/* ===================================================
  EQUIPMENT PAGES
  ==================================================== */
.stage-on-off {
  overflow-x: auto;
}
.stage-on-off table {
  max-width: 820px;
  width: auto;
}
.stage-on-off table th {
  text-align: center;
  padding-bottom: 6px;
}
.stage-on-off table td {
  text-align: center;
  padding: 0 4px;
}
.stage-on-off table td button {
  margin: 0;
  min-width: 68px;
}

.biweeklyMappingWrapper {
  overflow-x: auto;
}

.biweeklyMapping {
  min-width: 680px;
  max-width: 800px;
  margin-bottom: 16px;
}
.biweeklyMapping th, .biweeklyMapping td {
  text-align: center;
  padding-bottom: 6px;
}
.biweeklyMapping button.toggle {
  margin: 0;
}

.time-override {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
}

@media (max-width: 500px) {
  .time-override {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
    margin-bottom: 8px;
    padding-left: 2px;
  }
}
/* ===================================================
  SMART COOL PAGE
  ==================================================== */
.smart-cool-table-wrapper {
  overflow-x: auto;
}
.smart-cool-table-wrapper table {
  min-width: 840px;
  max-width: 900px;
}
.smart-cool-table-wrapper table td {
  text-align: center;
}
.smart-cool-table-wrapper table td input {
  width: 70px !important;
  margin-right: 0;
}

/* ===================================================
  RETRACTABLE GREENHOUSE PAGE
  ==================================================== */
/*

    tr {
      &:nth-of-type(1),
      &:nth-of-type(6),
      &:nth-of-type(11),
      &:nth-of-type(16),
       {
         td{
          padding-top: 1em;
          font-size: 18px;
         }
      }
    }

*/
.retractable-greenhouse {
  overflow-x: auto;
}
.retractable-greenhouse table {
  min-width: 1600px;
}
.retractable-greenhouse table td {
  padding: 4px;
  min-width: 90px;
}
.retractable-greenhouse table td input {
  width: 60px;
  text-align: center;
  margin-right: 4px;
  padding-right: 1px;
  color: #393D46;
}
.retractable-greenhouse table td:nth-of-type(3) input {
  background-color: #98fb98;
}
.retractable-greenhouse table td:nth-of-type(4) input, .retractable-greenhouse table td:nth-of-type(5) input, .retractable-greenhouse table td:nth-of-type(6) input, .retractable-greenhouse table td:nth-of-type(7) input, .retractable-greenhouse table td:nth-of-type(8) input {
  background-color: #f5f5dc;
}
.retractable-greenhouse table td:nth-of-type(9) input, .retractable-greenhouse table td:nth-of-type(10) input, .retractable-greenhouse table td:nth-of-type(11) input, .retractable-greenhouse table td:nth-of-type(12) input, .retractable-greenhouse table td:nth-of-type(13) input {
  background-color: #00ffff;
}
.retractable-greenhouse table td:nth-of-type(14) input, .retractable-greenhouse table td:nth-of-type(15) input, .retractable-greenhouse table td:nth-of-type(16) input, .retractable-greenhouse table td:nth-of-type(17) input, .retractable-greenhouse table td:nth-of-type(18) input {
  background-color: #fffacd;
}
.retractable-greenhouse table td:nth-of-type(19) input, .retractable-greenhouse table td:nth-of-type(20) input, .retractable-greenhouse table td:nth-of-type(21) input, .retractable-greenhouse table td:nth-of-type(22) input, .retractable-greenhouse table td:nth-of-type(23) input {
  background-color: #98fb98;
}

/* ===================================================
  RETRACTABLE VENT (CRAVO) TABLES
  ==================================================== */
.vent-position-wrapper {
  margin-top: 3em;
  overflow-x: auto;
}
.vent-position-wrapper table {
  min-width: 1000px;
}
.vent-position-wrapper table td input {
  width: 66px;
  text-align: center;
  margin-right: 4px;
  margin-bottom: 2px;
  padding-right: 1px;
  color: #393D46;
}
.vent-position-wrapper table td:nth-of-type(2) input {
  background-color: #4CE743;
}
.vent-position-wrapper table td:nth-of-type(3) input {
  background-color: #42DC4E;
}
.vent-position-wrapper table td:nth-of-type(4) input {
  background-color: #3AD25E;
}
.vent-position-wrapper table td:nth-of-type(5) input {
  background-color: #32C774;
}
.vent-position-wrapper table td:nth-of-type(6) input {
  background-color: #2EBB91;
}
.vent-position-wrapper table td:nth-of-type(7) input {
  background-color: #29A8AC;
  color: white;
}
.vent-position-wrapper table td:nth-of-type(8) input {
  background-color: #2274A4;
  color: white;
}

.crop-protection-wrapper {
  margin-top: 4em;
  overflow-x: auto;
}
.crop-protection-wrapper table {
  min-width: 840px;
}
.crop-protection-wrapper table td input {
  width: 66px;
  text-align: center;
  margin-right: 4px;
  margin-bottom: 2px;
  padding-right: 1px;
  color: #393D46;
}
.crop-protection-wrapper table table {
  min-width: 182px;
}
.crop-protection-wrapper table table tr:nth-of-type(2) input {
  background-color: #55b4d2;
  color: white;
}
.crop-protection-wrapper table table tr:nth-of-type(3) input {
  background-color: #71e0b6;
}
.crop-protection-wrapper table table tr:nth-of-type(4) input {
  background-color: #71e0b6;
}

.structural-protection-wrapper {
  margin-top: 4em;
  overflow-x: auto;
}
.structural-protection-wrapper table {
  max-width: 530px;
  min-width: 480px;
}
.structural-protection-wrapper table td {
  text-align: left;
}
.structural-protection-wrapper table input {
  width: 66px;
  text-align: center;
  margin-right: 4px;
  margin-bottom: 2px;
  padding-right: 1px;
  background-color: #55b4d2;
  color: white;
}

.fire-rain-wrapper {
  margin-top: 4em;
}
.fire-rain-wrapper input {
  width: 66px;
  text-align: center;
  margin-right: 4px;
  padding-right: 1px;
  margin: 0 6px 6px 6px;
}

.setpoint-wrapper-1,
.setpoint-wrapper-2,
.setpoint-wrapper-3,
.setpoint-wrapper-4 {
  margin-top: 4em;
  overflow-x: auto;
}
.setpoint-wrapper-1 table,
.setpoint-wrapper-2 table,
.setpoint-wrapper-3 table,
.setpoint-wrapper-4 table {
  min-width: 650px;
}
.setpoint-wrapper-1 table td,
.setpoint-wrapper-2 table td,
.setpoint-wrapper-3 table td,
.setpoint-wrapper-4 table td {
  text-align: left;
}
.setpoint-wrapper-1 table input,
.setpoint-wrapper-2 table input,
.setpoint-wrapper-3 table input,
.setpoint-wrapper-4 table input {
  width: 66px;
  text-align: center;
  margin-right: 4px;
  margin-bottom: 2px;
  padding-right: 1px;
  color: #393D46;
}

.setpoint-wrapper-1 input {
  background-color: #f5f5dc;
}

.setpoint-wrapper-2 input {
  background-color: #00ffff;
}

.setpoint-wrapper-3 input {
  background-color: #fffacd;
}

.setpoint-wrapper-4 input {
  background-color: #98fb98;
}

.intl-tel-input .country-list {
  max-height: none !important;
  overflow-y: hidden !important;
}

/* ===================================================
  NEW LOGIN / REGISTER / REGISTRATION ACTIVATION PAGES
  ==================================================== */
.login-register-new {
  display: flex;
}
.login-register-new a {
  color: #1F8DED;
  text-decoration: underline;
}
.login-register-new .login-left {
  width: 50%;
  min-height: 100vh;
  background: url("img/greenhouse-image.jpg");
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}
.login-register-new .login-left img {
  object-fit: cover;
  height: 100%;
  width: 100%;
}
.login-register-new .login-left.register {
  background: url("img/register-image.jpg");
  background-repeat: no-repeat;
  background-size: cover;
  background-position: top center;
}
.login-register-new .login-right {
  padding: 40px 40px 20px 40px;
  width: 50%;
  min-height: 100vh;
  background-color: white;
  box-shadow: 0 0 20px #808080;
}
.login-register-new .login-right header img {
  max-width: 100px;
}
.login-register-new .login-right header .floatright {
  margin-top: 10px;
}
@media (max-width: 420px) {
  .login-register-new .login-right header .floatright,
  .login-register-new .login-right header .floatleft {
    float: none;
    text-align: center;
  }
}
.login-register-new .login-right form {
  width: 100%;
  max-width: 436px;
  padding-top: 10px;
  margin: calc(50vh - 260px) auto 0;
}
@media (max-height: 560px) {
  .login-register-new .login-right form {
    margin-top: 0;
  }
}
.login-register-new .login-right form.register {
  margin: 10vh auto 0;
}
.login-register-new .login-right form h1 {
  text-align: center;
}
.login-register-new .login-right form input[type=text],
.login-register-new .login-right form input[type=email],
.login-register-new .login-right form input[type=password] {
  width: 100%;
  margin-bottom: 1em;
}
.login-register-new .login-right form .password-container {
  position: relative;
}
.login-register-new .login-right form .password-container .visible-button {
  position: absolute;
  right: -36px;
  top: 2px;
  background: none;
  border: none;
  padding: 6px;
}
.login-register-new .login-right form .password-container .visible-button .material-icons {
  color: #6E6B7B;
}
.login-register-new .login-right form .remember-container {
  margin: 1.5em 1em 2em;
}
.login-register-new .login-right form .remember-container label {
  display: inline-block;
  margin-left: 0.8em;
  max-width: 80%;
  vertical-align: text-top;
}
.login-register-new .login-right form .recaptcha-wrapper {
  margin-left: -40px;
  width: calc(100% + 80px);
}
.login-register-new .login-right form .recaptcha-wrapper .recaptcha-container {
  width: 304px;
  height: 108px;
  margin: 1em auto 0;
}
.login-register-new .login-right form .button-container {
  clear: both;
  margin-top: 1em;
}
.login-register-new .login-right form .button-container button {
  display: block;
  margin: 1em auto;
  width: 165px;
}
.login-register-new .login-right form .button-container #face-id-button,
.login-register-new .login-right form .button-container #touch-id-button {
  display: none;
}
.login-register-new .login-right .info-section {
  margin-top: 20%;
}
.login-register-new .login-right .info-section h1 {
  text-align: center;
}
.login-register-new {
  /* TEMPORARY HACK FOR INVITE-USER PAGE; REMOVE WHEN WE GET RID OF MATERIAL INPUTS */
}
.login-register-new .join-wrapper {
  max-width: 300px;
  margin: 0 auto;
}
.login-register-new .join-wrapper div:first-of-type div {
  padding-left: 10px;
}
.login-register-new #footer {
  position: sticky;
  top: 100vh;
  margin: 0;
  padding: 0;
}
@media (max-width: 820px) {
  .login-register-new .login-left {
    display: none;
  }
  .login-register-new .login-right {
    width: 100%;
  }
}

/* ===================================================
  PROFILE PAGE
  =================================================== */
#login-register .password-container {
  position: relative;
  display: inline-block;
}
#login-register .password-container .visible-button {
  position: absolute;
  right: -36px;
  top: 2px;
  background: none;
  border: none;
  padding: 6px;
}
#login-register input[type=number],
#login-register input[type=email],
#login-register input[type=text],
#login-register input[type=password] {
  font-size: 16px;
  padding: 9px;
  margin: 0 auto;
  margin-bottom: 16px;
  width: 221px;
}

#profile-page #login-register {
  text-align: left;
  margin-top: 0;
}
#profile-page #login-register label {
  margin: 0 0 6px;
}
#profile-page .title {
  font-size: 14px;
  color: #5E5873;
}
#profile-page img {
  width: 103px;
  height: 103px;
  object-fit: cover;
  border-radius: 10px;
  vertical-align: middle;
  margin-right: 20px;
}
#profile-page button {
  vertical-align: middle;
}
#profile-page button.outlined {
  margin-right: 20px;
}
#profile-page .text-input-wrapper {
  float: left;
  margin-right: 32px;
}
#profile-page .text-input-wrapper.password-wrapper {
  margin-right: 64px;
}

/* ===================================================
  MANAGE ACCOUNT PAGE
  =================================================== */
.manage-account-wrapper {
  overflow-x: auto;
}
.manage-account-wrapper .manage-account {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 1em;
  align-items: center;
  max-width: 500px;
}
.manage-account-wrapper .manage-account label {
  margin-top: 2px;
  margin-bottom: 0px;
  display: inline-block;
}
.manage-account-wrapper .manage-account input {
  min-width: 50px;
  margin: 0;
}
.manage-account-wrapper .manage-account .custom-select {
  margin: 0;
}
.manage-account-wrapper .manage-account .custom-select select {
  width: 100%;
}
.manage-account-wrapper .manage-account h2 {
  grid-column: 1/3;
  margin: 10px 0 0;
}
.manage-account-wrapper .manage-account h2:first-child {
  margin-top: 0;
}

/* ===================================================
  MANAGE GATEWAY PAGE
  =================================================== */
.remote-control-wrapper {
  text-align: center;
}
.remote-control-wrapper .remote-control-canvas {
  width: 512px;
  height: 256px;
}
@media (max-width: 500px) {
  .remote-control-wrapper .remote-control-canvas {
    width: 256px;
    height: 128px;
  }
}
.remote-control-wrapper .remote-control-table {
  width: 512px;
  height: 128px;
  margin: 0 auto;
}
.remote-control-wrapper .remote-control-table button {
  /* CSS */
  appearance: none;
  background-color: transparent;
  border: 2px solid #1A1A1A;
  border-radius: 15px;
  box-sizing: border-box;
  color: #3B3B3B;
  cursor: pointer;
  display: inline-block;
  margin: 0;
  min-height: 60px;
  min-width: 0;
  outline: none;
  text-align: center;
  text-decoration: none;
  transition: all 300ms cubic-bezier(0.23, 1, 0.32, 1);
  user-select: none;
  -webkit-user-select: none;
  touch-action: manipulation;
  width: 100%;
  will-change: transform;
}
.remote-control-wrapper .remote-control-table button:disabled {
  pointer-events: none;
}
.remote-control-wrapper .remote-control-table button:hover {
  color: #fff;
  background-color: #1A1A1A;
  box-shadow: rgba(0, 0, 0, 0.25) 0 8px 15px;
  transform: translateY(-2px);
}
.remote-control-wrapper .remote-control-table button:focus {
  color: #fff;
  background-color: #1A1A1A;
  box-shadow: rgba(0, 0, 0, 0.25) 0 8px 15px;
  transform: translateY(-2px);
}
.remote-control-wrapper .remote-control-table button:active {
  box-shadow: none;
  transform: translateY(0);
}
.remote-control-wrapper .remote-control-table button .material-icons-outlined {
  font-size: 40px;
}
@media (max-width: 500px) {
  .remote-control-wrapper .remote-control-table button .material-icons-outlined {
    font-size: 30px;
  }
}
@media (max-width: 500px) {
  .remote-control-wrapper .remote-control-table {
    width: 256px;
    height: 128px;
  }
}

/* ===================================================
  SELECT A PLAN PAGE
  =================================================== */
.plan-grid-wrapper {
  overflow-x: auto;
}
.plan-grid-wrapper .plan-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  min-width: 600px;
}
.plan-grid-wrapper .plan-grid > div {
  text-align: center;
  overflow: hidden;
}
.plan-grid-wrapper .plan-grid > div.header {
  position: sticky;
}
.plan-grid-wrapper .plan-grid > div:nth-child(4n+1) {
  text-align: left;
}
.plan-grid-wrapper .plan-grid {
  /*
  @media (max-width: 680px) {
    grid-template-columns: auto 0 auto 0;
  }
  */
}

/* ===================================================
  FOOTER
  =================================================== */
#footer {
  clear: both;
  border-top: 1px solid white;
  margin-top: 100px;
  margin-bottom: 8px;
  min-width: 80px;
  color: #6E6B7B;
  font-size: 14px;
  text-align: center;
  padding-bottom: 6px;
}

/* ===================================================
  GLOBAL STYLES 
  =================================================== */
.popup {
  display: none;
  position: fixed;
  top: 50%;
  left: 50%;
  padding: 20px;
  min-width: 300px;
  z-index: 100;
  background-color: white;
  box-shadow: 5px 5px 30px #AAAAAA;
  border-radius: 10px;
  transform: translate(-50%, -50%);
}
.popup p, .popup h1, .popup h2, .popup h3, .popup h4, .popup h5, .popup h6 {
  margin-top: 0;
}
.popup .close {
  position: absolute;
  top: 0px;
  right: 0px;
  background-color: white;
  padding: 4px;
  border-radius: 50%;
}
.popup .resize {
  position: absolute;
  bottom: 4px;
  right: 4px;
  padding: 0;
  transform: rotate(90deg);
  font-size: 18px;
  cursor: nwse-resize;
}
.popup.image-popup {
  cursor: grab;
}

.popup-scrim {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 99;
  background-color: rgba(0, 0, 0, 0.3);
}

/* ===================================================
  MUI PAGE STYLES 
  =================================================== */
.mui-button-container {
  display: inline-block;
  margin-right: 6px;
  vertical-align: text-top;
}

.mui-input-container {
  display: inline-block;
  vertical-align: middle;
}

/* ===================================================
  HTML TOGGLE SWITCHES MODIFIED TO BE SMALLER AND ACCESSIBLE
  https://www.w3schools.com/howto/howto_css_switch.asp
  =================================================== */
/* The switch - the box around the slider */
.switch {
  position: relative;
  display: inline-block;
  width: 36px;
  height: 20px;
}

/* Hide default HTML checkbox BUT KEEP OUTLINE WHEN SELECTED WITH TAB KEY! 
   MODIFIED BY BRIAN */
.switch input {
  width: 22px;
  height: 12px;
  -webkit-appearance: none;
  vertical-align: text-bottom;
}

/* HIDE OUTLINE ON IOS; OTHERWISE IT SHOWS WHEN SWITCH IS OFF 
  https://stackoverflow.com/questions/30102792/css-media-query-to-target-only-ios-devices */
@supports (-webkit-touch-callout: none) {
  .switch input {
    opacity: 0;
  }
}
/* The slider */
.slider {
  position: absolute;
  cursor: pointer;
  top: 0;
  left: -3px;
  right: 0;
  bottom: 0;
  width: 36px;
  background-color: #a8a8a8;
  -webkit-transition: 0.4s;
  transition: 0.4s;
}

.slider:before {
  position: absolute;
  content: "";
  height: 16px;
  width: 16px;
  left: 2px;
  bottom: 2px;
  background-color: white;
  -webkit-transition: 0.4s;
  transition: 0.4s;
}

input:checked + .slider {
  background-color: #1F8DED;
}

input:focus + .slider {
  box-shadow: 0 0 1px #1F8DED;
}

input:checked + .slider:before {
  -webkit-transform: translateX(16px);
  -ms-transform: translateX(16px);
  transform: translateX(16px);
}

/* Rounded sliders */
.slider.round {
  border-radius: 16px;
}

.slider.round:before {
  border-radius: 50%;
}

/* ADDED BY BRIAN */
.switch-label {
  display: inline;
  font-size: 14px;
  font-weight: 500;
  padding-right: 8px;
  vertical-align: text-bottom;
}

.slide-switch {
  display: inline-block;
  white-space: nowrap;
  margin-right: 40px;
}

table.slide-table td {
  min-width: 75px;
}

table.subscription td {
  min-width: 130px;
}

table.pricing-table td {
  padding: 6px;
}

.subscription-alarm-number {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #EA5455;
  width: 19px;
  height: 19px;
  border: 2px solid white;
  border-radius: 50%;
  color: white;
  font-size: 12px;
}

.copy-button {
  font-size: 22px;
  font-family: "Material Icons Outlined";
  cursor: "pointer";
}
.copy-button:hover {
  color: #a8a8a8;
}

@media (max-width: 1023px) {
  #weather-station .weather-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
  }
  #weather-station .inner span.title {
    background: #0074ba;
    color: #e1e1e1;
    padding: 5px 10px;
    border-bottom: 3px solid #f9da00;
    width: 100%;
    border-radius: 0 10px 10px 0;
  }
  #weather-station .inner {
    display: grid;
    grid-auto-flow: column;
  }
  #weather-station .inner span {
    box-sizing: border-box;
  }
  #weather-station .inner > span {
    padding-top: 10px;
  }
  #weather-station .inner .weather-one {
    display: flex;
    flex-direction: column;
  }
  #weather-station .inner .line-one {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 16px;
  }
  #weather-station .inner .wind-info {
    display: inline-flex;
    align-items: center;
    white-space: nowrap;
    margin-bottom: 2px;
  }
  #weather-station .inner .line-two {
    display: flex;
    align-items: center;
    white-space: nowrap;
  }
  #weather-station .inner .weather-air {
    display: flex;
    align-items: center;
    white-space: nowrap;
  }
  #weather-station .inner .weather-light {
    white-space: nowrap;
  }
  #weather-station .inner .weather-rain {
    display: flex;
    gap: 8px;
    white-space: nowrap;
  }
  #weather-station .inner .ws-small-icon {
    color: #1F8DED;
    margin-right: 0px;
    font-size: 14px;
  }
  #weather-station .inner .ws-title {
    font-size: 12px;
  }
  span.material-icons-outlined.ws-small-icon {
    width: 25px !important;
  }
  #weather-station .inner:nth-child(2), #weather-station .inner:nth-child(2) span:nth-child(5) {
    padding-bottom: 12px;
  }
}
@media (min-width: 740px) {
  .weather-line {
    display: flex;
    align-items: center;
  }
}
@media (max-width: 600px) {
  .hide-mobile {
    display: none !important;
  }
}
@media (max-width: 600px) {
  .hide-mobile-600 {
    display: none !important;
  }
}
@media (min-width: 601px) {
  .hide-desktop {
    display: none !important;
  }
}
@media (min-width: 1024px) {
  #weather-station .inner span.title {
    background: #0074ba;
    color: #e1e1e1;
    padding: 13px 10px;
    border-right: 5px solid #f9da00;
    border-radius: 0 10px 10px 0;
  }
  #weather-station .inner {
    display: grid;
    grid-template-columns: 13% 17% 17% 17% 18% 18%;
    grid-auto-flow: column;
  }
  #weather-station .inner span {
    margin-top: 8px;
    margin-bottom: 8px;
    margin-right: 10px;
  }
  #weather-station .inner > span {
    padding: 5px 10px;
  }
  #weather-station .inner:nth-child(2) span:nth-child(2) {
    padding: 13px 10px;
  }
}
#\/sidebar\/header > #\/sidebar\/header\/linkBot {
  background-image: url("img/spark-icon.png");
  background-size: 71%;
  width: 66px;
  background-position: 50% -17%;
  background-repeat: no-repeat;
  position: relative;
  top: 5.75px;
  height: 40px;
}

#\/sidebar\/header > .selected#\/sidebar\/header\/linkBot {
  background-position: 50% 116%;
  transition: none;
}

/*
.overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(109, 106, 106, 0.5); /* Adjust the color and opacity as needed */
/*}*/
@media (max-width: 1023px) {
  #infoWindow {
    width: 100% !important;
    right: 0 !important;
    top: 63px !important;
    height: 92vh !important;
  }
  #infoWindow > div {
    width: 100% !important;
  }
  h1, #breadcrumb-container, #weather-station, #content-area, #footer {
    margin-left: 32px;
    margin-right: 32px;
  }
  #infoWindow > div > div {
    width: 100% !important;
    min-height: 4vh !important;
    max-height: 100vh !important;
    padding: 2px;
  }
  #infoWindow > div > div {
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding: 0px 10px !important;
  }
}
.cbHost-nIcon {
  display: flex;
}
.cbHost-nIcon span {
  margin-right: 15px;
}
.cbHost-nIcon span label {
  background: #1f8ded;
  width: 25px;
  height: 25px;
  padding: 3px;
  box-sizing: border-box;
  border-radius: 5px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.cbHost-nIcon h3 {
  margin: 4px 0 0 0;
}

.cbHost-nIcon span label img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.cbGuest .cbHost-nIcon span label {
  background: black;
}

.cbChat-fChild .chArea-wrap textarea.cbtextArea {
  width: 100%;
  height: 90px;
  outline: none;
  resize: none;
}

.btn-area ul {
  margin: 0px;
  list-style: none;
  display: flex;
  justify-content: right;
  position: relative;
}
.btn-area ul li.cbSync button {
  background: #1f8ded;
  width: 48px;
  height: 36px;
  color: white;
}

/* Enhanced existing styles for iOS compatibility */
.chat-container {
  display: flex;
  flex-direction: column;
}

.chat-messages {
  flex: 1;
  overflow-y: auto;
  margin-bottom: 10px;
  height: 100%;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
}

.cbtextArea {
  width: 100%;
  height: 90px;
  padding: 10px;
  border-radius: 8px;
  border: 1px solid #ccc;
  resize: none;
  outline: none;
  font-size: 16px !important;
  -webkit-appearance: none;
}

.btn-area {
  margin-top: 8px;
}

.replyReaction {
  display: flex;
  justify-content: right;
  margin-top: 5px;
}

.replyReaction span {
  width: 20px;
  margin-right: 8px;
}

.btn-ul {
  margin: 0px;
  list-style: none;
  display: flex;
  justify-content: right;
  position: relative;
  align-items: center;
}

.sendButton {
  background: #1f8ded;
  width: 36px;
  height: 36px;
  background-image: url("img/send-btn-white.png");
  background-position: 50%;
  background-repeat: no-repeat;
  background-size: 35%;
  border: none;
  border-radius: 8px;
  cursor: pointer;
}

.ldrChBox {
  bottom: 15px;
  display: block;
  width: 36px;
  height: 36px;
  background: #1f8ded;
  border-radius: 10px;
  padding: 10px 10px 10px 10px;
  box-sizing: border-box;
  right: 0;
}

.togglesButtons {
  margin-right: 100px !important;
}

.togglesButtons.onlyTraining {
  margin-right: 190px !important;
}

@media (min-width: 1000px) {
  .togglesButtons.bothButtons {
    margin-right: 190px !important;
  }
  .togglesButtons.onlyTraining {
    margin-right: 290px !important;
  }
}
li.btn-area {
  justify-content: right !important;
  flex-direction: row;
}

ul li.edMode {
  display: flex;
  margin-right: 115px;
}

ul li.edMode .slide-switch {
  margin: 0;
  margin-top: 14px;
  margin-right: 0;
}

.wave {
  display: flex;
  align-items: center;
  gap: 3px;
}

.bar {
  width: 3px;
  height: 10px;
  background-color: #333;
  animation: waveAnim 1s infinite ease-in-out;
  border-radius: 2px;
}

.bar:nth-child(2) {
  animation-delay: 0.1s;
}

.bar:nth-child(3) {
  animation-delay: 0.2s;
}

.bar:nth-child(4) {
  animation-delay: 0.3s;
}

.bar:nth-child(5) {
  animation-delay: 0.4s;
}

@keyframes waveAnim {
  0%, 100% {
    height: 10px;
  }
  50% {
    height: 20px;
  }
}
/* Safe area support for newer iOS devices */
@supports (-webkit-touch-callout: none) {
  .cbFormWrap {
    -webkit-overflow-scrolling: touch;
  }
}
.chatbot-toast-message {
  position: fixed;
  top: 20px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 1000;
  background: rgba(0, 0, 0, 0.8);
  color: white;
  padding: 10px 10px;
  border-radius: 5px;
}

.edMode input[type=file] {
  position: relative !important;
}

.btn-area ul li.cbSync {
  position: absolute;
  right: 0;
  bottom: 11px;
}

li.edMode > div:nth-child(2) {
  margin-top: 5px;
}

#sidebar-content .inner {
  overflow: hidden !important;
}

#sidebar-tasks {
  height: calc(100vh - 300px);
  overflow-y: scroll;
  overflow-x: hidden;
  padding-right: 10px;
  box-sizing: border-box;
}

#sidebar-content .inner div > div #\/sidebar\/auditLog {
  overflow-y: scroll;
  height: calc(100vh - 300px);
  overflow-x: hidden;
  padding-right: 10px;
  box-sizing: border-box;
}

#sidebar-content .inner div > div #\/sidebar\/weatherInfo {
  overflow-y: scroll;
  height: calc(100vh - 300px);
  overflow-x: hidden;
  padding-right: 10px;
  box-sizing: border-box;
}

#sidebar-content .inner div > div #\/sidebar\/growJournal {
  overflow-y: scroll;
  height: calc(100vh - 300px);
  overflow-x: hidden;
  padding-right: 10px;
  box-sizing: border-box;
}

#\/sidebar\/growJournalEntry {
  padding-right: 10px;
}

#sidebar-alarms {
  overflow-y: scroll;
  height: calc(100vh - 300px);
  padding-right: 10px;
  overflow-x: hidden;
}

/* loading.css */
.loading-container {
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

.loadside-spinner {
  width: 20px;
  height: 20px;
  border: 3px solid #ccc;
  border-top: 3px solid #000;
  border-radius: 50%;
  animation: spin 1s linear infinite;
}

@keyframes spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
.info-section .floatleft {
  width: 100%;
}

.info-section .floatleft > span:nth-child(2) {
  word-wrap: break-word;
}

.cbChat-sChild {
  min-height: 120px;
  max-height: calc(100vh - 325px);
}

.replyReaction {
  display: flex;
  justify-content: right;
  margin-top: 5px;
}
.replyReaction span {
  width: 20px;
  margin-right: 8px;
}

.cbConversationWrap {
  min-height: calc(100vh - 508px);
  max-height: calc(100vh - 508px);
  overflow-y: scroll;
}

.cbHost .cbAns p > div > ul > li > p {
  margin-left: 0;
}

span.lBtn > svg:hover {
  fill: #1f8ded;
  cursor: pointer;
}

span.lBtn > svg:active, span.lBtn > svg:focus {
  fill: #1f8ded;
}

span.lBtn:focus {
  fill: #1f8ded;
}

.cbTextareStatic {
  position: absolute;
  width: 100%;
  bottom: 15px;
}

.cbfileWrap .ui-doc.cbFileTab > h2 {
  display: none;
}

ul.document-list.docTabWrap li.document-item h3.docTab {
  margin-bottom: 5px;
  margin-top: 22px;
}

ul.document-list.docTabWrap {
  list-style: none;
  padding: 0;
  min-height: calc(100vh - 508px);
  max-height: calc(100vh - 508px);
  overflow-y: scroll;
  padding-right: 10px;
  box-sizing: border-box;
  padding-top: 25px;
  overflow-x: hidden;
}

.docActions {
  display: flex;
  justify-content: right;
}

.docActions span {
  margin-left: 11px;
}

.docActions span svg {
  width: 20px;
}

ul.document-list.docTabWrap li.document-item {
  border-bottom: 1px solid #C1C1C1;
}

.docActions span.viewIcon:hover svg {
  fill: #1f8ded;
  cursor: pointer;
}

.docActions span.delIcon:hover svg {
  fill: red;
  cursor: pointer;
}

.cbFileInner {
  height: calc(100vh - 334px);
}

.chFtArea.chArea-wrap textarea {
  width: 100%;
  height: 90px;
  outline: none;
  resize: none;
}

.btn-area.fModeBtn ul {
  margin-top: 5px;
}

.btn-area.fModeBtn ul li.cbSend {
  bottom: 0;
}

.btn-area.fModeBtn ul li.cbSync {
  bottom: 0;
}

.chatbot-toast-message {
  position: fixed;
  bottom: 20px;
  right: 20px;
  background-color: #1F8DED;
  color: white;
  padding: 10px 20px;
  border-radius: 5px;
  z-index: 1000;
}

.dot-loader {
  width: 60px;
  aspect-ratio: 4;
  --_g: no-repeat radial-gradient(circle closest-side,#000 90%,#0000);
  background: var(--_g) 0% 50%, var(--_g) 50% 50%, var(--_g) 100% 50%;
  background-size: 33.3333333333% 100%;
  animation: l7 1s infinite linear;
}

@keyframes l7 {
  33% {
    background-size: 33.3333333333% 0%, 33.3333333333% 100%, 33.3333333333% 100%;
  }
  50% {
    background-size: 33.3333333333% 100%, 33.3333333333% 0%, 33.3333333333% 100%;
  }
  66% {
    background-size: 33.3333333333% 100%, 33.3333333333% 100%, 33.3333333333% 0%;
  }
}
.pagination_report_list {
  display: flex;
  justify-content: center;
  margin-top: 10px;
}

.pagination_report_list button {
  margin: 0 5px;
  padding: 5px 10px;
  cursor: pointer;
}

.pagination_report_list button.active {
  font-weight: bold;
}

/* Time picker */
.time-picker {
  font-size: 12px;
  margin-bottom: 8px;
  display: inline-block;
  color: #6E6B7B;
  display: block;
  user-select: none;
  font-weight: 600;
}

/*# sourceMappingURL=style.css.map */
