/**
 * importer.less
 *
 * By default, new Sails projects are configured to compile this file
 * from LESS to CSS.  Unlike CSS files, LESS files are not compiled and
 * included automatically unless they are imported below.
 *
 * For more information see:
 *   https://sailsjs.com/anatomy/assets/styles/importer-less
 */
/**
 * Color Variables
 */
/**
 * This file is for overriding some default bootstrap styles.
 *
 * > NOTE THAT THIS FILE AFFECTS GLOBAL STYLES.
 */
* {
  box-sizing: border-box;
}
img {
  display: block;
}
.btn,
[type='button'] {
  -webkit-appearance: none;
}
h1 > a:not(.btn),
h2 > a:not(.btn),
h3 > a:not(.btn),
h4 > a:not(.btn),
h5 > a:not(.btn),
h6 > a:not(.btn),
p > a:not(.btn),
li > a:not(.btn),
blockquote > a:not(.btn),
label > a:not(.btn),
h1 small > a:not(.btn),
h2 small > a:not(.btn),
h3 small > a:not(.btn),
h4 small > a:not(.btn),
h5 small > a:not(.btn),
h6 small > a:not(.btn),
p small > a:not(.btn),
li small > a:not(.btn),
blockquote small > a:not(.btn),
label small > a:not(.btn) {
  color: #14acc2;
  border-bottom: 1px solid #000;
}
h1 > a:not(.btn):hover,
h2 > a:not(.btn):hover,
h3 > a:not(.btn):hover,
h4 > a:not(.btn):hover,
h5 > a:not(.btn):hover,
h6 > a:not(.btn):hover,
p > a:not(.btn):hover,
li > a:not(.btn):hover,
blockquote > a:not(.btn):hover,
label > a:not(.btn):hover,
h1 small > a:not(.btn):hover,
h2 small > a:not(.btn):hover,
h3 small > a:not(.btn):hover,
h4 small > a:not(.btn):hover,
h5 small > a:not(.btn):hover,
h6 small > a:not(.btn):hover,
p small > a:not(.btn):hover,
li small > a:not(.btn):hover,
blockquote small > a:not(.btn):hover,
label small > a:not(.btn):hover {
  text-decoration: none;
  color: #000;
}
blockquote {
  border-left: 3px solid #e4e4e4;
  padding-left: 20px;
}
[v-cloak] {
  display: none;
}
html,
body {
  height: 100%;
  margin: 0;
}
[purpose='page-wrap'] {
  height: 100%;
  /* lesshint-disable */
  height: auto !important;
  /* lesshint-enable */
  min-height: 100%;
  position: relative;
  padding-bottom: 40px;
}
[purpose='page-footer'] {
  border-top: 1px solid rgba(0, 0, 0, 0.1);
  height: 40px;
  width: 100%;
  position: absolute;
  left: 0px;
  bottom: 0px;
}
@media (max-width: 800px) {
  [purpose='page-wrap'] {
    padding-bottom: 75px;
  }
  [purpose='page-wrap'] [purpose='page-footer'] {
    height: 75px;
  }
  [purpose='page-wrap'] [purpose='page-footer'] [purpose='footer-copy'],
  [purpose='page-wrap'] [purpose='page-footer'] [purpose='footer-nav'] {
    width: 100%;
    display: block;
    text-align: center;
  }
}
@media (max-width: 575px) {
  [purpose='page-wrap'] {
    padding-bottom: 100px;
  }
  [purpose='page-wrap'] [purpose='page-footer'] {
    height: 100px;
  }
}
.nav-link .nav-item {
  cursor: pointer !important;
}
.dropdown {
  cursor: pointer !important;
}
.dropdown-menu[data-bs-popper] {
  left: auto !important;
}
/**
 * <stripe-card-element>
 */
[parasails-component='stripe-card-element'] .card-element-wrapper {
  position: relative;
}
[parasails-component='stripe-card-element'] .card-element-wrapper .card-element {
  padding-top: 0;
  padding-bottom: 0;
  padding-right: 30px;
}
[parasails-component='stripe-card-element'] .card-element-wrapper .card-element.pseudofocused {
  border-color: #80bdff;
  outline: 0;
  box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.25);
}
[parasails-component='stripe-card-element'] .card-element-wrapper .status-indicator {
  font-size: 15px;
  position: absolute;
  right: 14px;
  top: 8px;
}
[parasails-component='stripe-card-element'] .card-element-wrapper .status-indicator.hidden {
  display: none;
}
[parasails-component='stripe-card-element'] .card-element-wrapper .status-indicator.syncing {
  -webkit-animation: fa-spinner-rotate 1.5s infinite linear;
  animation: fa-spinner-rotate 1.5s infinite linear;
}
@-webkit-keyframes fa-spinner-rotate {
  0% {
    -webkit-transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
  }
}
@keyframes rotate-clockwise {
  0% {
    -ms-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  100% {
    -ms-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}
[parasails-component='stripe-card-element'] .card-element-wrapper.secret-card-element-wrapper {
  opacity: 0;
  height: 1px;
}
@media screen and (max-width: 450px) {
  [parasails-component='stripe-card-element'] .card-element-wrapper .card-element {
    padding-right: 20px;
  }
  [parasails-component='stripe-card-element'] .card-element-wrapper .status-indicator {
    right: 9px;
  }
}
/**
 * <ajax-button>
 *
 * App-wide styles for our ajax buttons.
 */
[parasails-component='ajax-button'] .button-loader,
[parasails-component='ajax-button'] .button-loading {
  display: none;
  margin: auto;
}
[parasails-component='ajax-button'] .button-loader .loading-dot,
[parasails-component='ajax-button'] .button-loading .loading-dot {
  opacity: 0;
  display: inline;
  -moz-animation-name: fade-in;
  -webkit-animation-name: fade-in;
  -ms-animation-name: fade-in;
  -o-animation-name: fade-in;
  animation-name: fade-in;
  -moz-animation-duration: 1s;
  -webkit-animation-duration: 1s;
  -ms-animation-duration: 1s;
  -o-animation-duration: 1s;
  animation-duration: 1s;
  -moz-animation-iteration-count: infinite;
  -webkit-animation-iteration-count: infinite;
  -ms-animation-iteration-count: infinite;
  -o-animation-iteration-count: infinite;
  animation-iteration-count: infinite;
  -moz-animation-direction: linear;
  -webkit-animation-direction: linear;
  -ms-animation-direction: linear;
  -o-animation-direction: linear;
  animation-direction: linear;
}
@-webkit-keyframes fade-in {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@-moz-keyframes fade-in {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@-o-keyframes fade-in {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes fade-in {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
[parasails-component='ajax-button'] .button-loader .loading-dot.dot1,
[parasails-component='ajax-button'] .button-loading .loading-dot.dot1 {
  -moz-animation-delay: 0.25s;
  -webkit-animation-delay: 0.25s;
  -ms-animation-delay: 0.25s;
  -o-animation-delay: 0.25s;
  animation-delay: 0.25s;
}
[parasails-component='ajax-button'] .button-loader .loading-dot.dot2,
[parasails-component='ajax-button'] .button-loading .loading-dot.dot2 {
  -moz-animation-delay: 0.5s;
  -webkit-animation-delay: 0.5s;
  -ms-animation-delay: 0.5s;
  -o-animation-delay: 0.5s;
  animation-delay: 0.5s;
}
[parasails-component='ajax-button'] .button-loader .loading-dot.dot3,
[parasails-component='ajax-button'] .button-loading .loading-dot.dot3 {
  -moz-animation-delay: 0.75s;
  -webkit-animation-delay: 0.75s;
  -ms-animation-delay: 0.75s;
  -o-animation-delay: 0.75s;
  animation-delay: 0.75s;
}
[parasails-component='ajax-button'] .button-loader .loading-dot.dot4,
[parasails-component='ajax-button'] .button-loading .loading-dot.dot4 {
  -moz-animation-delay: 1s;
  -webkit-animation-delay: 1s;
  -ms-animation-delay: 1s;
  -o-animation-delay: 1s;
  animation-delay: 1s;
}
[parasails-component='ajax-button'].syncing .button-loader,
[parasails-component='ajax-button'].syncing .button-loading {
  display: inline-block;
}
[parasails-component='ajax-button'].syncing .button-text {
  display: none;
}
/**
 * <modal>
 *
 * App-wide styles for our modals.
 */
[parasails-component='modal'] {
  -webkit-overflow-scrolling: touch;
}
[parasails-component='modal'] [purpose='modal-dialog'] {
  z-index: 100;
  position: relative;
  max-width: 700px;
}
[parasails-component='modal'] [purpose='modal-dialog'] [purpose='modal-content'] {
  max-width: 700px;
}
[parasails-component='modal'] [purpose='modal-dialog'] [purpose='modal-content'] [purpose='modal-close-button'] {
  border-top: none;
  border-bottom: none;
  border-left: none;
  border-right: none;
  background: transparent;
  font-family: inherit;
  cursor: pointer;
  opacity: 0.6;
}
[parasails-component='modal'] [purpose='modal-dialog'] [purpose='modal-content'] [purpose='modal-close-button']:focus {
  border-image: none;
  outline: none;
}
[parasails-component='modal'] [purpose='modal-dialog'] [purpose='modal-content'] [purpose='modal-close-button']:hover {
  opacity: 1;
}
[parasails-component='modal'] .petticoat {
  position: fixed;
  width: 100%;
  height: 75px;
  z-index: 50;
  left: 0px;
  top: 0px;
  background-color: #fff;
}
[parasails-component='modal'] .modal-content {
  border-radius: 0px;
  border-color: #fff;
  padding-top: 50px;
  padding-bottom: 50px;
  padding-left: 25px;
  padding-right: 25px;
}
[parasails-component='modal'] .modal-content .modal-header {
  border-bottom: none;
  display: block;
  position: relative;
  text-align: center;
  padding-bottom: 0px;
  padding-left: 0px;
  padding-right: 0px;
  padding-top: 0px;
}
[parasails-component='modal'] .modal-content .modal-header .modal-title {
  font-weight: 700;
}
[parasails-component='modal'] .modal-content .modal-header .modal-intro {
  margin-left: auto;
  margin-right: auto;
  color: #999999;
  margin-bottom: 20px;
}
[parasails-component='modal'] .modal-content .modal-header hr {
  margin-top: 25px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 10px;
  width: 100px;
  height: 2px;
  border-top: 2px solid #14acc2;
}
[parasails-component='modal'] .modal-content .modal-body {
  padding-top: 10px;
  padding-bottom: 10px;
  padding-left: 0px;
  padding-right: 0px;
}
[parasails-component='modal'] .modal-content .modal-footer {
  padding-top: 25px;
  padding-bottom: 0px;
  padding-left: 0px;
  padding-right: 0px;
  margin-top: 10px;
}
.modal-backdrop {
  background-color: #fff;
}
.modal-backdrop.show {
  opacity: 0.95;
}
/**
 * <cloud-error>
 *
 * App-wide styles for our cloud-errors.
 */
#homepage [purpose='cloud-1'] {
  -moz-animation-name: flyfade;
  -webkit-animation-name: flyfade;
  -ms-animation-name: flyfade;
  -o-animation-name: flyfade;
  animation-name: flyfade;
  -moz-animation-duration: 7s;
  -webkit-animation-duration: 7s;
  -ms-animation-duration: 7s;
  -o-animation-duration: 7s;
  animation-duration: 7s;
  -moz-animation-iteration-count: infinite;
  -webkit-animation-iteration-count: infinite;
  -ms-animation-iteration-count: infinite;
  -o-animation-iteration-count: infinite;
  animation-iteration-count: infinite;
  -moz-animation-timing-function: linear;
  -webkit-animation-timing-function: linear;
  -ms-animation-timing-function: linear;
  -o-animation-timing-function: linear;
  animation-timing-function: linear;
  opacity: 0;
}
@-webkit-keyframes flyfade {
  0% {
    -webkit-transform: translate(0px, 0px);
    opacity: 0;
  }
  25% {
    opacity: 1;
  }
  50% {
    -webkit-transform: translate(110px, 0px);
  }
  75% {
    opacity: 1;
  }
  100% {
    -webkit-transform: translate(220px, 0);
    opacity: 0;
  }
}
@-moz-keyframes flyfade {
  0% {
    -moz-transform: translate(0, 0px);
    opacity: 0;
  }
  25% {
    opacity: 1;
  }
  50% {
    -moz-transform: translate(110px, 0px);
    opacity: 1;
  }
  75% {
    opacity: 1;
  }
  100% {
    -moz-transform: translate(220px, 0);
    opacity: 0;
  }
}
@-o-keyframes flyfade {
  0% {
    -o-transform: translate(0, 0px);
    opacity: 0;
  }
  25% {
    opacity: 1;
  }
  50% {
    -o-transform: translate(110px, 0px);
    opacity: 1;
  }
  75% {
    opacity: 1;
  }
  100% {
    -o-transform: translate(220px, 0);
    opacity: 0;
  }
}
@keyframes flyfade {
  0% {
    transform: translate(0, 0px);
    opacity: 0;
  }
  25% {
    opacity: 1;
  }
  50% {
    transform: translate(110px, 0px);
    opacity: 1;
  }
  75% {
    opacity: 1;
  }
  100% {
    transform: translate(220px, 0);
    opacity: 0;
  }
}
#homepage [purpose='cloud-2'] {
  -moz-animation-name: flyfade;
  -webkit-animation-name: flyfade;
  -ms-animation-name: flyfade;
  -o-animation-name: flyfade;
  animation-name: flyfade;
  -moz-animation-duration: 7s;
  -webkit-animation-duration: 7s;
  -ms-animation-duration: 7s;
  -o-animation-duration: 7s;
  animation-duration: 7s;
  -moz-animation-iteration-count: infinite;
  -webkit-animation-iteration-count: infinite;
  -ms-animation-iteration-count: infinite;
  -o-animation-iteration-count: infinite;
  animation-iteration-count: infinite;
  -moz-animation-timing-function: linear;
  -webkit-animation-timing-function: linear;
  -ms-animation-timing-function: linear;
  -o-animation-timing-function: linear;
  animation-timing-function: linear;
  -moz-animation-delay: 3.5s;
  -webkit-animation-delay: 3.5s;
  -ms-animation-delay: 3.5s;
  -o-animation-delay: 3.5s;
  animation-delay: 3.5s;
  opacity: 0;
}
@-webkit-keyframes flyfade {
  0% {
    -webkit-transform: translate(0px, 0px);
    opacity: 0;
  }
  25% {
    opacity: 1;
  }
  50% {
    -webkit-transform: translate(110px, 0px);
  }
  75% {
    opacity: 1;
  }
  100% {
    -webkit-transform: translate(220px, 0);
    opacity: 0;
  }
}
@-moz-keyframes flyfade {
  0% {
    -moz-transform: translate(0, 0px);
    opacity: 0;
  }
  25% {
    opacity: 1;
  }
  50% {
    -moz-transform: translate(110px, 0px);
    opacity: 1;
  }
  75% {
    opacity: 1;
  }
  100% {
    -moz-transform: translate(220px, 0);
    opacity: 0;
  }
}
@-o-keyframes flyfade {
  0% {
    -o-transform: translate(0, 0px);
    opacity: 0;
  }
  25% {
    opacity: 1;
  }
  50% {
    -o-transform: translate(110px, 0px);
    opacity: 1;
  }
  75% {
    opacity: 1;
  }
  100% {
    -o-transform: translate(220px, 0);
    opacity: 0;
  }
}
@keyframes flyfade {
  0% {
    transform: translate(0, 0px);
    opacity: 0;
  }
  25% {
    opacity: 1;
  }
  50% {
    transform: translate(110px, 0px);
    opacity: 1;
  }
  75% {
    opacity: 1;
  }
  100% {
    transform: translate(220px, 0);
    opacity: 0;
  }
}
#homepage [purpose='ship'] {
  -moz-animation-name: skid;
  -webkit-animation-name: skid;
  -ms-animation-name: skid;
  -o-animation-name: skid;
  animation-name: skid;
  -moz-animation-duration: 2.5s;
  -webkit-animation-duration: 2.5s;
  -ms-animation-duration: 2.5s;
  -o-animation-duration: 2.5s;
  animation-duration: 2.5s;
  -moz-animation-iteration-count: infinite;
  -webkit-animation-iteration-count: infinite;
  -ms-animation-iteration-count: infinite;
  -o-animation-iteration-count: infinite;
  animation-iteration-count: infinite;
  -moz-animation-timing-function: linear;
  -webkit-animation-timing-function: linear;
  -ms-animation-timing-function: linear;
  -o-animation-timing-function: linear;
  animation-timing-function: linear;
}
@-webkit-keyframes skid {
  0% {
    -webkit-transform: translate(0px, 0px);
  }
  10% {
    -webkit-transform: translate(-1px, -1px);
  }
  20% {
    -webkit-transform: translate(-2px, -2px);
  }
  30% {
    -webkit-transform: translate(-3px, -2px);
  }
  40% {
    -webkit-transform: translate(-4px, -1px);
  }
  50% {
    -webkit-transform: translate(-5px, 0px);
  }
  60% {
    -webkit-transform: translate(-4px, 1px);
  }
  70% {
    -webkit-transform: translate(-3px, 2px);
  }
  80% {
    -webkit-transform: translate(-2px, 2px);
  }
  90% {
    -webkit-transform: translate(-1px, 1px);
  }
  100% {
    -webkit-transform: translate(0, 0px);
  }
}
@-moz-keyframes skid {
  0% {
    -moz-transform: translate(0px, 0px);
  }
  10% {
    -moz-transform: translate(-1px, -1px);
  }
  20% {
    -moz-transform: translate(-2px, -2px);
  }
  30% {
    -moz-transform: translate(-3px, -2px);
  }
  40% {
    -moz-transform: translate(-4px, -1px);
  }
  50% {
    -moz-transform: translate(-5px, 0px);
  }
  60% {
    -moz-transform: translate(-4px, 1px);
  }
  70% {
    -moz-transform: translate(-3px, 2px);
  }
  80% {
    -moz-transform: translate(-2px, 2px);
  }
  90% {
    -moz-transform: translate(-1px, 1px);
  }
  100% {
    -moz-transform: translate(0, 0px);
  }
}
@-o-keyframes skid {
  0% {
    -o-transform: translate(0px, 0px);
  }
  10% {
    -o-transform: translate(-1px, -1px);
  }
  20% {
    -o-transform: translate(-2px, -2px);
  }
  30% {
    -o-transform: translate(-3px, -2px);
  }
  40% {
    -o-transform: translate(-4px, -1px);
  }
  50% {
    -o-transform: translate(-5px, 0px);
  }
  60% {
    -o-transform: translate(-4px, 1px);
  }
  70% {
    -o-transform: translate(-3px, 2px);
  }
  80% {
    -o-transform: translate(-2px, 2px);
  }
  90% {
    -o-transform: translate(-1px, 1px);
  }
  100% {
    -o-transform: translate(0, 0px);
  }
}
@keyframes skid {
  0% {
    transform: translate(0px, 0px);
  }
  10% {
    transform: translate(-1px, -1px);
  }
  20% {
    transform: translate(-2px, -2px);
  }
  30% {
    transform: translate(-3px, -2px);
  }
  40% {
    transform: translate(-4px, -1px);
  }
  50% {
    transform: translate(-5px, 0px);
  }
  60% {
    transform: translate(-4px, 1px);
  }
  70% {
    transform: translate(-3px, 2px);
  }
  80% {
    transform: translate(-2px, 2px);
  }
  90% {
    transform: translate(-1px, 1px);
  }
  100% {
    transform: translate(0, 0px);
  }
}
#homepage [purpose='more-info-text'] {
  -moz-animation-name: bob;
  -webkit-animation-name: bob;
  -ms-animation-name: bob;
  -o-animation-name: bob;
  animation-name: bob;
  -moz-animation-duration: 3.2s;
  -webkit-animation-duration: 3.2s;
  -ms-animation-duration: 3.2s;
  -o-animation-duration: 3.2s;
  animation-duration: 3.2s;
  -moz-animation-iteration-count: infinite;
  -webkit-animation-iteration-count: infinite;
  -ms-animation-iteration-count: infinite;
  -o-animation-iteration-count: infinite;
  animation-iteration-count: infinite;
  -moz-animation-timing-function: ease-in-out;
  -webkit-animation-timing-function: ease-in-out;
  -ms-animation-timing-function: ease-in-out;
  -o-animation-timing-function: ease-in-out;
  animation-timing-function: ease-in-out;
}
@-webkit-keyframes bob {
  0% {
    -webkit-transform: translate(0px);
  }
  50% {
    -webkit-transform: translatey(-7px);
  }
  100% {
    -webkit-transform: translatey(0px);
  }
}
@-moz-keyframes bob {
  0% {
    -moz-transform: translatey(0px);
  }
  50% {
    -moz-transform: translatey(-7px);
  }
  100% {
    -moz-transform: translatey(0px);
  }
}
@-o-keyframes bob {
  0% {
    -o-transform: translatey(0px);
  }
  50% {
    -o-transform: translatey(-7px);
  }
  100% {
    -o-transform: translatey(0px);
  }
}
@keyframes bob {
  0% {
    transform: translatey(0px);
  }
  50% {
    transform: translatey(-7px);
  }
  100% {
    transform: translatey(0px);
  }
}
#homepage [purpose='setup-step'] {
  padding-left: 240px;
}
@media (max-width: 991px) {
  #homepage [purpose='setup-step'] {
    padding-left: 0px;
  }
}
#account-overview [purpose='remove-button'] {
  color: #14acc2;
}
#account-overview [purpose='remove-button']:hover {
  color: #000;
}
.container {
  max-width: none;
  margin: 0 auto;
}
.header {
  background: white;
  border-radius: 15px;
  padding: 30px;
  margin-bottom: 20px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
}
.header {
  position: relative;
}
/* Collapsible header (accordion-like) */
.header {
  overflow: hidden;
  max-height: 800px;
  transition: max-height 0.28s ease;
}
.header.collapsed {
  max-height: 72px;
  /* enough for title row */
}
.header-actions .btn-toggle {
  background: transparent;
  border: none;
  color: #444;
  padding: 6px 8px;
  margin-right: 8px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 16px;
}
.header-actions .btn-fullscreen {
  background: transparent;
  border: none;
  color: #444;
  padding: 6px 8px;
  margin-right: 8px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 16px;
}
.header-actions .btn-fullscreen:focus {
  outline: none;
  box-shadow: 0 0 0 3px rgba(102, 126, 234, 0.12);
}
.header-actions .btn-toggle:focus {
  outline: none;
  box-shadow: 0 0 0 3px rgba(102, 126, 234, 0.12);
}
.header-actions {
  position: absolute;
  top: 18px;
  right: 18px;
  display: flex;
  gap: 8px;
  align-items: center;
}
.btn-scrape {
  padding: 8px 12px;
  background: linear-gradient(135deg, #10b981 0%, #06b6a4 100%);
  color: #fff;
  border: none;
  border-radius: 8px;
  cursor: pointer;
  font-weight: 600;
  box-shadow: 0 6px 18px rgba(16, 185, 129, 0.15);
}
.btn-scrape[disabled] {
  opacity: 0.6;
  cursor: not-allowed;
}
.header h1 {
  color: #333;
  font-size: 2.5em;
  margin-bottom: 10px;
}
.header p {
  color: #666;
  font-size: 1.1em;
}
/* Date filter layout and date range display */
.date-filter {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 12px;
  flex-wrap: wrap;
}
.date-filter label {
  color: #555;
  font-size: 0.95em;
  margin-right: 6px;
}
.date-filter .date-picker {
  padding: 8px 12px;
  border: 1px solid #e6e9f2;
  border-radius: 8px;
  background: #fff;
  min-width: 150px;
  box-shadow: inset 0 1px 0 rgba(16, 24, 40, 0.02);
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.date-filter .date-picker:focus {
  outline: none;
  border-color: #667eea;
  box-shadow: 0 4px 18px rgba(102, 126, 234, 0.08);
}
.date-filter button#applyDateFilter {
  padding: 8px 14px;
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  color: #fff;
  border: none;
  border-radius: 8px;
  cursor: pointer;
  font-weight: 600;
}
.date-filter button#applyDateFilter:hover {
  opacity: 0.95;
}
#dateRange {
  margin-top: 10px;
  color: #444;
  font-size: 0.95em;
  background: transparent;
}
#dateRange span {
  font-weight: 600;
  color: #222;
}
.upload-section {
  background: white;
  border-radius: 15px;
  padding: 30px;
  margin-bottom: 20px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
  text-align: center;
}
.upload-area {
  border: 3px dashed #667eea;
  border-radius: 12px;
  padding: 40px;
  cursor: pointer;
  transition: all 0.3s ease;
  background: #f8f9ff;
}
.upload-area:hover {
  border-color: #764ba2;
  background: #f0f2ff;
}
.upload-area.dragover {
  border-color: #43e97b;
  background: #e8fff3;
}
.upload-icon {
  font-size: 3em;
  margin-bottom: 15px;
}
.upload-text {
  color: #333;
  font-size: 1.2em;
  margin-bottom: 10px;
}
.upload-hint {
  color: #666;
  font-size: 0.9em;
}
.file-info {
  margin-top: 20px;
  padding: 15px;
  background: #e8fff3;
  border-radius: 8px;
  display: none;
}
.file-info.show {
  display: block;
}
.file-name {
  color: #10b981;
  font-weight: bold;
  font-size: 1.1em;
}
#fileInput {
  display: none;
}
.kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 20px;
  margin-bottom: 20px;
}
.kpi-card {
  background: white;
  border-radius: 15px;
  padding: 25px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
  transition: transform 0.3s ease;
}
.kpi-card:hover {
  transform: translateY(-5px);
}
.kpi-card .icon {
  width: 50px;
  height: 50px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  margin-bottom: 15px;
}
.kpi-card .label {
  color: #666;
  font-size: 0.9em;
  margin-bottom: 5px;
}
.kpi-card .value {
  color: #333;
  font-size: 2em;
  font-weight: bold;
}
.icon.blue {
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  color: white;
}
.icon.green {
  background: linear-gradient(135deg, #f093fb 0%, #f5576c 100%);
  color: white;
}
.icon.purple {
  background: linear-gradient(135deg, #4facfe 0%, #00f2fe 100%);
  color: white;
}
.icon.orange {
  background: linear-gradient(135deg, #43e97b 0%, #38f9d7 100%);
  color: white;
}
.tabs {
  background: white;
  border-radius: 15px;
  padding: 10px;
  margin-bottom: 20px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
  display: flex;
  gap: 10px;
  overflow-x: auto;
}
.tab-btn {
  padding: 12px 24px;
  border: none;
  background: transparent;
  color: #666;
  font-size: 1em;
  font-weight: 500;
  cursor: pointer;
  border-radius: 10px;
  transition: all 0.3s ease;
  white-space: nowrap;
}
.tab-btn:hover {
  background: #f0f0f0;
}
.tab-btn.active {
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  color: white;
}
.tab-content {
  display: none;
}
.tab-content.active {
  display: block;
}
.chart-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(500px, 1fr));
  gap: 20px;
  margin-bottom: 20px;
}
.chart-card {
  background: white;
  border-radius: 15px;
  padding: 25px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
}
.chart-card h3 {
  color: #333;
  margin-bottom: 20px;
  font-size: 1.3em;
}
.chart-container {
  position: relative;
  height: 350px;
}
.stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 15px;
  margin-top: 20px;
}
.stat-card {
  background: white;
  border-radius: 12px;
  padding: 20px;
  text-align: center;
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.05);
}
.stat-card .stat-label {
  color: #666;
  font-size: 0.85em;
  margin-bottom: 8px;
}
.stat-card .stat-value {
  font-size: 1.8em;
  font-weight: bold;
}
.stat-card.poda .stat-value {
  color: #10b981;
}
.stat-card.remocao .stat-value {
  color: #ef4444;
}
.stat-card.transplante .stat-value {
  color: #3b82f6;
}
.stat-card.plantio .stat-value {
  color: #f59e0b;
}
.dashboard-content {
  display: none;
}
.dashboard-content.show {
  display: block;
}
.loading {
  display: none;
  text-align: center;
  padding: 40px;
  color: white;
}
.loading.show {
  display: block;
}
.spinner {
  border: 4px solid #f3f3f3;
  border-top: 4px solid #667eea;
  border-radius: 50%;
  width: 50px;
  height: 50px;
  animation: spin 1s linear infinite;
  margin: 0 auto 20px;
}
@keyframes spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
@media (max-width: 768px) {
  .chart-grid {
    grid-template-columns: 1fr;
  }
  .header h1 {
    font-size: 1.8em;
  }
}
/* Floating FontAwesome spinner (bottom-right) */
.fa-floating-spinner {
  position: fixed;
  right: 20px;
  bottom: 20px;
  width: 56px;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0, 0, 0, 0.65);
  color: #fff;
  border-radius: 50%;
  z-index: 99999;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.25);
  pointer-events: none;
  transition: opacity 0.2s ease, transform 0.2s ease;
}
.fa-floating-spinner i {
  font-size: 20px;
}
/* Fullscreen mode for this page's container */
.container.fullscreen {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  z-index: 99999;
  background: #fff;
  padding: 24px;
  overflow: auto;
  border-radius: 0;
}
/* When fullscreen, ensure header is visible on top */
.container.fullscreen .header {
  position: relative;
  z-index: 100000;
}
/* Simple card-like styles for the left panel */
.file-panel {
  min-width: 260px;
  background: #fafafa;
  border: 1px solid #eee;
  border-radius: 8px;
  padding: 12px;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.03);
}
.panel-header {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.panel-header h4 {
  margin: 0;
  font-size: 1rem;
}
.search-input {
  width: 100%;
  padding: 8px;
  border-radius: 6px;
  border: 1px solid #ddd;
  background: #fff;
}
.panel-body {
  margin-top: 8px;
}
.files-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.file-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px;
  border-radius: 6px;
  cursor: pointer;
  border: 1px solid transparent;
}
.file-item:hover {
  background: #fff;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
  border-color: #e8e8e8;
}
.file-item .name {
  font-size: 0.95rem;
  color: #333;
}
.file-item .meta {
  font-size: 0.8rem;
  color: #888;
  margin-left: 8px;
}
.file-item.active {
  background: #eef6ff;
  border-color: #cfe6ff;
}
.btn-small {
  padding: 6px 8px;
  border-radius: 6px;
  border: 1px solid #cfd8e3;
  background: #fff;
  color: #333;
  cursor: pointer;
}
.viewer-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 8px;
}
.no-files {
  color: #666;
  padding: 12px;
}
@media (max-width: 500px) {
  #faq code {
    word-break: break-all;
  }
  #faq [purpose='placeholder'] {
    word-break: break-all;
  }
}
@font-face {
  font-family: "Code128";
  src: url("/fonts/code128.ttf") format("truetype");
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: "code128_1";
  src: url("/fonts/code128_1.ttf") format("truetype");
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: "PrecisionID C128 04 DEMO";
  src: url("/fonts/PrecisionID C128 04 DEMO.ttf") format("truetype");
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: "PrecisionID C128 22 DEMO";
  src: url("/fonts/PrecisionID C128 22 DEMO.ttf") format("truetype");
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: "PrecisionID C128 04 DEMO 2";
  src: url("/fonts/PrecisionID C128 04 DEMO.woff2") format("woff2");
}
.barcode {
  font-family: "PrecisionID C128 04 DEMO 2";
  font-size: 48px;
  white-space: pre;
}
