/*!*******************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-14.use[1]!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-14.use[2]!./src/composables/tour-styles.css ***!
  \*******************************************************************************************************************************************************************************/
.driver-popover-primary {
  background-color: rgb(var(--v-theme-primary)) !important;
  color: white !important;
  border: none !important;
}

.driver-popover-primary .driver-popover-title {
  color: white !important;
  font-weight: 600 !important;
}

.driver-popover-primary .driver-popover-description {
  color: rgba(255, 255, 255, 0.9) !important;
}

.driver-popover-primary .driver-popover-footer {
  border-top: 1px solid rgba(255, 255, 255, 0.2) !important;
}

.driver-popover-primary .driver-popover-btn {
  background-color: rgba(255, 255, 255, 0.2) !important;
  color: white !important;
  border: 1px solid rgba(255, 255, 255, 0.3) !important;
}

.driver-popover-primary .driver-popover-btn:hover {
  background-color: rgba(255, 255, 255, 0.3) !important;
}

.driver-popover-primary .driver-popover-btn.driver-popover-btn-primary {
  background-color: white !important;
  color: rgb(var(--v-theme-primary)) !important;
  border: none !important;
}

.driver-popover-primary .driver-popover-btn.driver-popover-btn-primary:hover {
  background-color: rgba(255, 255, 255, 0.9) !important;
}

.driver-popover-primary .driver-popover-progress-text {
  color: rgba(255, 255, 255, 0.8) !important;
}

.driver-popover-primary .driver-popover-close-btn {
  color: white !important;
  opacity: 0.8;
}

.driver-popover-primary .driver-popover-close-btn:hover {
  opacity: 1;
}

/* Responsive styles for mobile devices */
@media (max-width: 960px) {
  .driver-popover {
    max-width: calc(100vw - 32px) !important;
    margin: 16px !important;
    font-size: 14px !important;
  }

  .driver-popover-title {
    font-size: 16px !important;
    line-height: 1.4 !important;
    margin-bottom: 8px !important;
  }

  .driver-popover-description {
    font-size: 14px !important;
    line-height: 1.5 !important;
    margin-bottom: 12px !important;
  }

  .driver-popover-footer {
    padding: 12px 16px !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
  }

  .driver-popover-btn {
    padding: 10px 16px !important;
    font-size: 14px !important;
    min-width: auto !important;
    flex: 1 1 auto !important;
  }

  .driver-popover-navigation-btns {
    display: flex !important;
    gap: 8px !important;
    width: 100% !important;
  }

  .driver-popover-progress-text {
    font-size: 12px !important;
    width: 100% !important;
    text-align: center !important;
    margin-bottom: 8px !important;
  }

  /* Ensure popover doesn't go off-screen on mobile */
  .driver-popover-container {
    max-width: 100vw !important;
    left: 0 !important;
    right: 0 !important;
    padding: 0 16px !important;
  }
}

/* Extra small devices */
@media (max-width: 600px) {
  .driver-popover {
    max-width: calc(100vw - 24px) !important;
    margin: 12px !important;
    padding: 16px !important;
  }

  .driver-popover-title {
    font-size: 15px !important;
  }

  .driver-popover-description {
    font-size: 13px !important;
  }

  .driver-popover-btn {
    padding: 8px 12px !important;
    font-size: 13px !important;
  }
}


/*!***********************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/vue-loader/dist/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/vue-loader/dist/index.js??ruleSet[0].use[0]!./src/components/LaborCostCalculator.vue?vue&type=style&index=0&id=364c517f&scoped=true&lang=css ***!
  \***********************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.v-btn-toggle[data-v-364c517f] {
  display: flex;
  flex-wrap: wrap;
}
.v-btn-toggle .v-btn[data-v-364c517f] {
  flex: 1 1 auto;
  min-width: 0;
}

/*!****************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/vue-loader/dist/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/vue-loader/dist/index.js??ruleSet[0].use[0]!./src/components/LoggedInHome.vue?vue&type=style&index=0&id=74165614&scoped=true&lang=css ***!
  \****************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.stat-card[data-v-74165614] {
  cursor: pointer;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  border: 1px solid rgba(0, 0, 0, 0.05);
}
.stat-card[data-v-74165614]:hover {
  transform: translateY(-8px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12) !important;
  border-color: rgba(var(--v-theme-primary), 0.3);
}
.tip-card[data-v-74165614] {
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  border: 1px solid rgba(0, 0, 0, 0.05);
}
.tip-card[data-v-74165614]:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12) !important;
}
.gap-3[data-v-74165614] {
  gap: 12px;
}
.h-100[data-v-74165614] {
  height: 100%;
}
@media (max-width: 600px) {
.stat-card[data-v-74165614] {
    min-height: 120px;
}
}

/*!*****************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/vue-loader/dist/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/vue-loader/dist/index.js??ruleSet[0].use[0]!./src/components/LoggedOutHome.vue?vue&type=style&index=0&id=46d2e3eb&scoped=true&lang=css ***!
  \*****************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.hero-section[data-v-46d2e3eb] {
  min-height: 80vh;
  display: flex;
  align-items: center;
  position: relative;
  overflow: hidden;
  padding: 0;
}
.hero-background[data-v-46d2e3eb] {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  border-radius: 30px;
  will-change: transform;
  transform: translateZ(0);
}
.hero-overlay[data-v-46d2e3eb] {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(to right, 
    rgba(255,255,255,0.95) 0%,
    rgba(255,255,255,0.8) 40%,
    rgba(255,255,255,0) 50%,
    rgba(255,255,255,0) 100%
  );
}
.z-index-1[data-v-46d2e3eb] {
  position: relative;
  z-index: 2;
}
.hero-content[data-v-46d2e3eb] {
  padding: 4rem 5%;
  position: relative;
  margin: 0;
}
@media (max-width: 960px) {
.hero-overlay[data-v-46d2e3eb] {
    background: linear-gradient(to bottom,
      rgba(255,255,255,0.95) 0%,
      rgba(255,255,255,0.8) 100%
    );
}
}
.feature-card[data-v-46d2e3eb] {
  height: 100%;
  text-align: center;
  transition: transform 0.3s ease;
  border: 1px solid var(--color-background);
  border-radius: 30px;
  background: var(--color-white);
}
.feature-card[data-v-46d2e3eb]:hover {
  transform: translateY(-10px);
  border-color: var(--color-primary);
}
.primary-text[data-v-46d2e3eb] {
  color: var(--color-primary);
  font-weight: var(--app-font-weight-bold);
  font-style: italic;
}
.white-text[data-v-46d2e3eb] {
  color: var(--color-white) !important;
}
.step-card[data-v-46d2e3eb] {
  border: 1px solid var(--color-background);
  border-radius: 30px;
  background: var(--color-white);
  height: 100%;
  transition: transform 0.3s ease;
}
.step-card[data-v-46d2e3eb]:hover {
  transform: translateY(-10px);
  border-color: var(--color-primary);
}
.bg-transparent[data-v-46d2e3eb] {
  background: transparent !important;
}
.v-footer[data-v-46d2e3eb] {
  border-top: 1px solid var(--color-background);
}
.v-list-item[data-v-46d2e3eb] {
  min-height: 36px;
}
.cta-section .cta-text[data-v-46d2e3eb] {
  color: var(--color-white) !important;
}
@media (max-width: 960px) {
.hero-content h1[data-v-46d2e3eb] {
    font-size: 2.5rem !important;
    line-height: 1.2;
}
.hero-content .text-h4[data-v-46d2e3eb] {
    font-size: 1.5rem !important;
}
h2.text-h2[data-v-46d2e3eb] {
    font-size: 2rem !important;
}
h3.text-h4[data-v-46d2e3eb] {
    font-size: 1.5rem !important;
}
}
@media (max-width: 600px) {
.hero-content h1[data-v-46d2e3eb] {
    font-size: 2rem !important;
    line-height: 1.2;
}
.hero-content .text-h4[data-v-46d2e3eb] {
    font-size: 1.25rem !important;
}
h2.text-h2[data-v-46d2e3eb] {
    font-size: 1.75rem !important;
}
h3.text-h4[data-v-46d2e3eb] {
    font-size: 1.375rem !important;
}
.text-h4[data-v-46d2e3eb] {
    font-size: 1.25rem !important;
}
}

/*!*************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/vue-loader/dist/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/vue-loader/dist/index.js??ruleSet[0].use[0]!./src/components/AppFooter.vue?vue&type=style&index=0&id=fdb56dc8&scoped=true&lang=css ***!
  \*************************************************************************************************************************************************************************************************************************************************************************************************************************************************/

.v-footer[data-v-fdb56dc8] {
  border-top: 1px solid var(--color-background);
}
.v-list-item[data-v-fdb56dc8] {
  min-height: 36px;
}
.bg-transparent[data-v-fdb56dc8] {
  background: transparent !important;
}

/*!********************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/vue-loader/dist/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/vue-loader/dist/index.js??ruleSet[0].use[0]!./src/App.vue?vue&type=style&index=0&id=7ba5bd90&lang=css ***!
  \********************************************************************************************************************************************************************************************************************************************************************************************************************/

:root {
  /* Font Variables */
  --app-font-family: 'Google Sans Flex', sans-serif;
  --app-font-weight-light: 300;
  --app-font-weight-regular: 400;
  --app-font-weight-bold: 700;

  /* Color Palette */
  --color-primary: #1976D2;     /* Verde - Primary */
  --color-accent: #FF9800;      /* Naranja - Accent */
  --color-background: #F5F5F5;  /* Gris Claro - Background */
  --color-white: #FFFFFF;       /* Blanco */
  --color-text: #212121;        /* Negro - Text */

  /* Max font sizes to prevent text from becoming too large on high-resolution displays */
  --max-font-size-base: 16px;
  --max-font-size-h1: 3.5rem;
  --max-font-size-h2: 2.75rem;
  --max-font-size-h3: 2.25rem;
  --max-font-size-h4: 1.5rem;
  --max-font-size-h5: 1.25rem;
  --max-font-size-h6: 1.125rem;
  --max-font-size-subtitle: 1rem;
  --max-font-size-body: 1rem;
  --max-font-size-button: 0.875rem;
  --max-font-size-caption: 0.75rem;
}
html {
  font-size: clamp(14px, 1vw, var(--max-font-size-base));
}
body {
  font-size: clamp(14px, 1vw, var(--max-font-size-base));
}
.app-root {
  font-family: var(--app-font-family);
  font-weight: var(--app-font-weight-light);
  color: var(--color-text);
  font-size: clamp(14px, 1vw, var(--max-font-size-base));
}
.logo a,
.logo-link {
  text-decoration: none;
  color: inherit;
  display: flex;
  align-items: center;
}
.logo {
  display: flex;
  align-items: center;
  padding-left: 0 !important;
}
.logo-img {
  width: auto;
  height: auto;
  max-height: 40px;
  max-width: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  display: block;
}
@media (max-width: 960px) {
.logo-img {
    max-height: 32px;
}
.logo {
    padding-left: 4px !important;
}
}

/* Override Vuetify's default typography with Google Sans Flex */
body,
html,
.v-application,
.v-application *,
.v-btn,
.v-text-field,
.v-select,
.v-textarea,
.v-card,
.v-list-item,
.v-toolbar,
.v-app-bar {
  font-family: var(--app-font-family) !important;
}

/* Limit maximum font sizes for typography classes */
.text-h1 {
  font-family: var(--app-font-family) !important;
  font-size: clamp(1.5rem, 4vw, var(--max-font-size-h1)) !important;
}
.text-h2 {
  font-family: var(--app-font-family) !important;
  font-size: clamp(1.375rem, 3.5vw, var(--max-font-size-h2)) !important;
}
.text-h3 {
  font-family: var(--app-font-family) !important;
  font-size: clamp(1.25rem, 3vw, var(--max-font-size-h3)) !important;
}
.text-h4 {
  font-family: var(--app-font-family) !important;
  font-size: clamp(1.125rem, 2.5vw, var(--max-font-size-h4)) !important;
}
.text-h5 {
  font-family: var(--app-font-family) !important;
  font-size: clamp(1rem, 2vw, var(--max-font-size-h5)) !important;
}
.text-h6 {
  font-family: var(--app-font-family) !important;
  font-size: clamp(0.9375rem, 1.75vw, var(--max-font-size-h6)) !important;
}
.text-subtitle-1,
.text-subtitle-2 {
  font-family: var(--app-font-family) !important;
  font-size: clamp(0.875rem, 1.5vw, var(--max-font-size-subtitle)) !important;
}
.text-body-1,
.text-body-2 {
  font-family: var(--app-font-family) !important;
  font-size: clamp(0.875rem, 1.25vw, var(--max-font-size-body)) !important;
}
.text-button {
  font-family: var(--app-font-family) !important;
  font-size: clamp(0.8125rem, 1vw, var(--max-font-size-button)) !important;
}
.text-caption,
.text-overline {
  font-family: var(--app-font-family) !important;
  font-size: clamp(0.6875rem, 0.875vw, var(--max-font-size-caption)) !important;
}

/* Limit maximum sizes for other common elements */
.v-btn {
  font-size: clamp(0.8125rem, 1vw, var(--max-font-size-button)) !important;
  border-radius: 30px !important;
}
.v-text-field input,
.v-select .v-select__selection {
  font-size: clamp(0.875rem, 1.25vw, var(--max-font-size-body)) !important;
}
.v-list-item-title {
  font-size: clamp(0.875rem, 1.25vw, var(--max-font-size-body)) !important;
}
.v-list-item-subtitle {
  font-size: clamp(0.8125rem, 1vw, 0.875rem) !important;
}
.v-card-title {
  font-size: clamp(1rem, 2vw, var(--max-font-size-h5)) !important;
}
.v-card-subtitle {
  font-size: clamp(0.875rem, 1.5vw, var(--max-font-size-subtitle)) !important;
}

/* Limit icon sizes on very large screens */
.v-icon {
  max-width: 48px;
  max-height: 48px;
}
@media (min-width: 1920px) {
html {
    font-size: var(--max-font-size-base);
}
body {
    font-size: var(--max-font-size-base);
}
}
.v-app-bar .v-btn {
  text-transform: none;
  font-weight: 400;
  letter-spacing: 0.5px;
}
.v-main {
  display: flex;
}
.v-container {
  max-width: 1440px;
  margin: 0 auto;
  padding: 24px;
}
.v-navigation-drawer {
  top: 64px !important; /* Height of v-app-bar */
  z-index: 1;
}
@media (max-width: 960px) {
.v-navigation-drawer {
    top: 56px !important; /* Height of v-app-bar on mobile */
}
.v-app-bar .v-btn {
    min-width: 40px !important;
    padding: 0 8px !important;
}
}
.custom-drawer .v-list-item {
  min-height: 35px;
}
.custom-drawer .menu-item {
  font-weight: 400 !important;
}
.custom-drawer .selected-item {
  font-weight: 700 !important;
}
.custom-drawer .v-list-item__prepend {
  margin-inline-end: 8px !important;
}
.custom-drawer .toggle-button {
  margin-bottom: 8px;
}

/* Override Vuetify's default padding */
.custom-drawer .v-list {
  padding: 8px 4px !important;
}
.custom-drawer .v-list-item__content {
  padding: 0 !important;
}

/* Add this to your existing styles */
.custom-drawer .v-list-item__prepend > .v-icon ~ .v-list-item__spacer {
  width: 10px !important;
}
.custom-drawer .v-list-item__prepend > .v-tooltip ~ .v-list-item__spacer {
  width: 10px !important;
}

/* Add to your existing styles */
.custom-drawer .v-list-item--nav .v-list-item-title {
  font-weight: unset !important;
  font-size: 0.9375rem !important; /* text-body-1 size */
  line-height: 1.5rem !important;
}
.custom-drawer .selected-item .v-list-item-title {
  font-weight: 500 !important;
  font-size: 0.9375rem !important;
  line-height: 1.5rem !important;
}
.v-field {
  border-radius: 12px !important;
}
.activation-item {
  background: rgb(var(--v-theme-primary)) !important;
  margin: 12px 16px !important;
  border-radius: 12px !important;
  font-weight: 700 !important;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
  position: relative;
  overflow: hidden;
  min-height: 48px !important;
}
.custom-drawer.v-navigation-drawer--rail .activation-item {
  margin: 12px 8px !important;
  justify-content: center !important;
  min-width: 48px !important;
  width: 48px !important;
  padding: 0 !important;
}
.custom-drawer.v-navigation-drawer--rail .activation-item :deep(.v-list-item__prepend) {
  margin-inline-end: 0 !important;
  margin-inline-start: 0 !important;
  width: 100% !important;
  justify-content: center !important;
  align-items: center !important;
  display: flex !important;
}
.custom-drawer.v-navigation-drawer--rail .activation-item :deep(.v-list-item__spacer) {
  display: none !important;
}
.custom-drawer.v-navigation-drawer--rail .activation-item :deep(.v-icon) {
  margin: 0 auto !important;
}
.custom-drawer.v-navigation-drawer--rail .activation-item :deep(.v-list-item__content) {
  display: none !important;
}
.activation-item-selected {
  background: rgb(var(--v-theme-accent)) !important;
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.25) !important;
}
.activation-item::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.3), transparent);
  transition: left 0.5s;
}
.activation-item:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.2) !important;
}
.activation-item:hover::before {
  left: 100%;
}
.activation-item,
.activation-item-selected,
.activation-item.text-primary,
.activation-item-selected.text-primary {
  color: white !important;
}
.activation-item :deep(.v-list-item-title),
.activation-item-selected :deep(.v-list-item-title),
.activation-item :deep(.v-list-item-title span),
.activation-item-selected :deep(.v-list-item-title span),
.activation-item-selected.v-list-item :deep(.v-list-item-title),
.activation-item-selected.v-list-item :deep(.v-list-item-title span),
.v-list-item.activation-item-selected :deep(.v-list-item-title),
.v-list-item.activation-item-selected :deep(.v-list-item-title span),
.activation-item.text-primary :deep(.v-list-item-title),
.activation-item-selected.text-primary :deep(.v-list-item-title) {
  color: white !important;
  font-size: 1rem !important;
  font-weight: 700 !important;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
}
.activation-item :deep(.v-list-item-subtitle),
.activation-item-selected :deep(.v-list-item-subtitle),
.activation-item :deep(.v-list-item-subtitle span),
.activation-item-selected :deep(.v-list-item-subtitle span),
.activation-item-selected.v-list-item :deep(.v-list-item-subtitle),
.activation-item-selected.v-list-item :deep(.v-list-item-subtitle span),
.v-list-item.activation-item-selected :deep(.v-list-item-subtitle),
.v-list-item.activation-item-selected :deep(.v-list-item-subtitle span),
.activation-item.text-primary :deep(.v-list-item-subtitle),
.activation-item-selected.text-primary :deep(.v-list-item-subtitle) {
  color: rgba(255, 255, 255, 0.95) !important;
  font-weight: 500 !important;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
}
.activation-item :deep(.v-icon),
.activation-item-selected :deep(.v-icon),
.activation-item :deep(.v-list-item__prepend .v-icon),
.activation-item-selected :deep(.v-list-item__prepend .v-icon),
.activation-item-selected.v-list-item :deep(.v-icon),
.activation-item-selected.v-list-item :deep(.v-list-item__prepend .v-icon),
.v-list-item.activation-item-selected :deep(.v-icon),
.v-list-item.activation-item-selected :deep(.v-list-item__prepend .v-icon),
.activation-item.text-primary :deep(.v-icon),
.activation-item-selected.text-primary :deep(.v-icon),
.activation-item.text-primary :deep(.v-list-item__prepend .v-icon),
.activation-item-selected.text-primary :deep(.v-list-item__prepend .v-icon) {
  color: white !important;
  filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.1));
}
.activation-item :deep(.v-list-item__content),
.activation-item-selected :deep(.v-list-item__content),
.activation-item-selected.v-list-item :deep(.v-list-item__content),
.v-list-item.activation-item-selected :deep(.v-list-item__content) {
  color: white !important;
}
.activation-item-selected.v-list-item :deep(*),
.v-list-item.activation-item-selected :deep(*),
.activation-item.text-primary :deep(*),
.activation-item-selected.text-primary :deep(*) {
  color: white !important;
}

/* Login button styles */
.login-button {
  color: white !important;
}
.login-button :deep(.v-btn__content) {
  color: white !important;
}

/* User menu styles */
.user-menu-card {
  border-radius: 12px !important;
  overflow: hidden;
}
.user-menu-item {
  cursor: pointer;
  transition: background-color 0.2s ease;
}
.user-menu-item:hover {
  background-color: rgba(0, 0, 0, 0.04);
}

/* Tooltip styles for rail menu */
.custom-drawer .v-tooltip .v-overlay__content {
  font-weight: 500 !important;
  font-size: 0.875rem !important;
  padding: 8px 12px !important;
  border-radius: 8px !important;
  box-shadow: 0 4px 12px #FF9800 !important;
  animation: tooltipFadeIn 0.2s ease-out !important;
}
@keyframes tooltipFadeIn {
from {
    opacity: 0;
    transform: translateX(-4px);
}
to {
    opacity: 1;
    transform: translateX(0);
}
}

