﻿
:root {
    --primary-color: #0D3C55;
    --secondary-color: #032D43;
    --white-speed: #FCFCFC;
    --modal-blue: #0078D7;
}

html, body {
    font-family: 'Cabin', sans-serif;
    font-size: 14px;
    color: #222222;
    background-color: var(--white-speed);
    overflow: hidden;
}

.form-label, .col-form-label {
    font-family: 'Cabin', sans-serif;
    font-size: 14px;
    color: #222222;
}

a, .btn-link {
    color: #5189a7;
}

span, label, h1, h2, h3, h4, h5, h6, text, p {
    cursor: context-menu;
}

button span {
    cursor: pointer !important;
}

.nav-principal .nav-item {
    text-transform: uppercase;
}

.nav-separator {
    width: 1px;
    background-color: #d8ddef;
    margin-right: 5px;
    margin-left: 5px;
    margin-top: 5px;
    margin-bottom: 5px;
    height: 20px;
}

.nav-separator-tacho {
    width: 2px;
    background-color: #222222;
    margin-top: -30px;
    margin-bottom: -3px;
    height: 30px;
    position: relative;
}

.nav-separator-card {
    width: 1px;
    background-color: #222222;
    margin-bottom: -3px;
    position: relative;
}

.nav-separator-driver-tacho {
    width: 2px;
    background-color: #222222;
    margin-top: -53px;
    margin-bottom: -3px;
    height: 52px;
    position: relative;
}

.navbar-principal {
    background-color: var(--primary-color);
    font-size: 12px;
}

.navbar-brand {
    color: var(--white-speed) !important;
}

.navbar-nav .dropdown-menu {
    position: absolute;
}

.accordion-container {
    overflow-y: auto;
}

.side-options-container {
    height: 10vh;
    display: flex;
    flex-direction: row;
    justify-content: space-around;
    padding: 0.5rem;
    transition: left 0.4s ease-in-out;
}

.side-option {
    padding: 10px;
    align-items: center;
    width: 20vw;
    text-align: center;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

    .side-option.disabled {
        opacity: 0.4;
    }

        .side-option.disabled:hover {
            background-color: transparent;
        }

    .side-option > i {
        font-size: 16px;
    }

    .side-option > span {
        font-size: 11px;
    }

    .side-option:hover {
        background-color: var(--primary-color);
    }

.menu-header-sidebar {
    background: var(--primary-color);
    border: none;
    height: 8vh;
    color: var(--white-speed);
    font-size: 24px;
    cursor: pointer;
    position: sticky;
    top: 0;
    display: flex;
    align-items: center;
    border-bottom: 1px solid #ffffff33;
    z-index: 10;
}

.menu-footer-sidebar {
    background: #003d55;
    border: none;
    color: var(--white-speed);
    font-size: 4vw;
    cursor: pointer;
    height: 10vh;
    display: flex;
    align-items: center;
    border-top: 1px solid #ffffff33;
}

.dropdown-menu {
    z-index: 1010 !important;
}

.opacity-50{
    opacity: .5;
}

.tabbar {
    position: fixed;
    bottom: 0;
    width: 100%;
    background: linear-gradient(360deg, var(--primary-color) 30%, var(--secondary-color) 70%);
    color: white;
    display: flex;
    justify-content: space-around;
    padding: 10px 0;
    z-index: 1000;
}

    .tabbar div {
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 4px; /* Espacio entre imagen y texto */
    }

    .tabbar img {
        width: 24px; /* Tamaño consistente para imágenes */
        height: 24px;
        display: block; /* Elimina espacio fantasma debajo de la imagen */
    }

    .tabbar span {
        font-size: 13px;
        text-align: center;
    }

/* Vertical (portrait) */
@media (orientation: portrait) {
    .tabbar {
        height: 10vh;
        /* Otros estilos específicos para vertical */
    }
}

/* Horizontal (landscape) */
@media (orientation: landscape) {
    .tabbar {
        height: 15vh;
        /* Otros estilos específicos para horizontal */
    }
}

.navbar-nav {
    flex-direction: row !important;
}

.logo img {
    display: inline-block;
    margin-right: 20px;
    position: relative;
    top: -6px;
}

.logo p {
    display: inline-block;
    margin: 0;
    font-size: 16px;
    line-height: 18px;
    position: relative;
    top: 4px;
}

.nav-link {
    font-size: 12px !important;
    font-weight: 400 !important;
    color: var(--white-speed) !important;
    padding: 16px 0;
    width: 120px;
    text-align: center;
    padding-left: 5px !important;
    padding-right: 5px !important;
}

    .nav-link.active {
        border-bottom: 3px solid #FF9900 !important;
        color: #FF9900 !important;
    }

.nav-principal-item img {
    margin-right: 5px !important;
    max-width: 16px;
    max-height: 16px;
}

.nav-link-notifications {
    width: auto;
}

.nav-link-user {
    width: 60px;
    border-radius: 15px;
    background-color: #00000080 !important;
    padding: 0 12px !important;
    height: 40px;
    margin-top: 7px;
}

.navbar-collapse.show {
    background-color: var(--primary-color);
    z-index: 9999;
}

    .navbar-collapse.show .nav-link {
        padding-left: 30px !important;
    }

.content {
    padding-top: 1.1rem;
}

#blazor-error-ui {
    background: lightyellow;
    bottom: 0;
    box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2);
    display: none;
    left: 0;
    padding: 0.6rem 1.25rem 0.7rem 1.25rem;
    position: fixed;
    width: 100%;
    z-index: 1000;
}

    #blazor-error-ui .dismiss {
        cursor: pointer;
        position: absolute;
        right: 0.75rem;
        top: 0.5rem;
    }

.form-control {
    /*padding: 4px;*/
    border: 1px solid #DAEBF3;
    background-color: var(--white-speed);
    color: #222222;
    font-size: 13px !important;
    height: 30px;
}

    .form-control::placeholder {
        color: #A7BBC4;
    }

    .form-control[disabled] {
        background-color: #F2F6F8;
        color: #5189A7;
        font-size: 14px;
    }

    .form-control:focus {
        box-shadow: none;
        border-color: #a7bbc4;
    }

h1 {
    color: var(--primary-color);
    font-size: 18px;
    margin-top: 20px;
    margin-bottom: 30px;
}

h2 {
    color: #5189A7;
    font-size: 16px;
    margin-bottom: 17px;
    font-weight: 600;
}

h3 {
    color: #5189A7;
    font-size: 14px;
    margin-bottom: 8px;
    font-weight: 600;
}

.card {
    border: 1px solid #DAEBF3;
    border-radius: 6px;
}

.mobile-notifications > .card {
    border-radius: 0 !important;
}


.form-switch {
    padding-left: 2em !important;
}

    .form-switch .form-check-label {
        height: 30px;
        padding-top: 8px;
        margin-left: 10px;
    }

    .form-switch .form-check-input {
        height: 22px;
        width: 40px;
        margin-top: 6px;
        cursor: pointer;
        background-color: #A7BBC4;
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3E%3Ccircle r='3' fill='%23fff'/%3E%3C/svg%3E");
        border-color: #a7bbc4;
    }

        .form-switch .form-check-input:checked {
            background-color: #FF9900;
        }

.version-details {
    display: none;
    margin-left: 20px;
}

    .version-details.hidden {
        display: none;
    }

    .version-details.visible {
        display: block;
    }

.version-title {
    cursor: pointer;
    user-select: none;
}

.floating-sublist {
    width: fit-content;
    border: var(--rz-listbox-border);
    background-color: var(--white-speed);
    padding: 0;
    z-index: 1000;
}

.active-menu {
    font-weight: bold !important;
    color: #FF9900 !important;
}

.tree-container {
    display: flex;
    flex-direction: column;
    height: calc(100vh - 100px);
    width: 22vw;
    min-width: 324px !important;
    background-color: var(--white-speed);
    position: fixed;
    bottom: 0;
    z-index: 1000;
    border-top-right-radius: 6px;
    border-bottom-right-radius: 6px;
    border-top: 1px solid #DAEBF3;
    border-bottom: 1px solid #DAEBF3;
    border-right: 1px solid #DAEBF3;
    overflow: hidden;
    padding: 5px;
    margin-top: auto;
    transition: left 0.4s linear;
}

    .tree-container.open {
        left: 0;
    }

    .tree-container.close {
        left: -22vw;
    }

.box-left-panel-settings {
    position: relative;
    overflow-y: auto;
    flex: 1;
    overflow-x: hidden;
}

.tree-container-services {
    display: flex;
    flex-direction: column;
    height: calc(100vh - 113px);
    width: calc(30vw);
    background-color: var(--white-speed);
    position: fixed;
    bottom: 0;
    z-index: 1000;
    border-top-right-radius: 6px;
    border-bottom-right-radius: 6px;
    border-top: 1px solid #DAEBF3;
    border-bottom: 1px solid #DAEBF3;
    border-right: 1px solid #DAEBF3;
    overflow: hidden;
    padding: 5px;
    margin-top: auto;
    min-width: 456px !important;
    transition: left 0.4s linear;
}

    .tree-container-services.open {
        left: 0;
    }

    .tree-container-services.close {
        left: -30vw;
    }

.box-left-panel-settings .box-item {
    box-shadow: inset 0 -1px 0 rgb(0 0 0 / 13%);
}

    .box-left-panel-settings .box-item .fas {
        margin-top: 2px;
        font-size: 12px;
    }

    .box-left-panel-settings .box-item label {
        font-size: 12px;
        color: var(--primary-color);
    }

    .box-left-panel-settings .box-item div[draggable="true"] {
        width: 100%;
    }


.accordion-item:first-of-type .accordion-button {
    width: 100%;
    padding: 0 3px !important;
    font-size: 12px;
    color: var(--primary-color);
    font-weight: 400;
}

.accordion-button:not(.collapsed) {
    background-color: transparent;
}

.accordion-button.collapsed {
    background-color: transparent !important;
}

.btn-group-list {
    padding: 5px 5px 5px 5px !important;
    font-size: 12px !important;
    color: var(--primary-color) !important;
    font-family: 'Cabin', sans-serif !important;
}

.hide-box-left-panel-settings {
    position: fixed;
    width: 30px;
    height: 80px;
    top: 50vh;
    z-index: 1000;
    cursor: pointer;
    transition: left 0.4s linear;
    background-color: var(--white-speed);
    border-top-right-radius: 10px;
    border-bottom-right-radius: 10px;
    border-top: 1px solid #DAEBF3;
    border-right: 1px solid #DAEBF3;
    border-bottom: 1px solid #DAEBF3;
    text-align: center;
    color: #2a77e7;
    padding-top: 30px;
    transition: left 0.4s linear;
}

    .hide-box-left-panel-settings.open {
        left: calc(22vw - 1px);
    }

    .hide-box-left-panel-settings.close {
        left: 0;
    }

.hide-box-left-panel-ranking {
    position: fixed;
    width: 30px;
    height: 80px;
    margin-left: -1px;
    top: 50vh;
    z-index: 1000;
    cursor: pointer;
    background-color: var(--white-speed);
    border-top-right-radius: 10px;
    border-bottom-right-radius: 10px;
    border-top: 1px solid #DAEBF3;
    border-right: 1px solid #DAEBF3;
    border-bottom: 1px solid #DAEBF3;
    text-align: center;
    color: #2a77e7;
    padding-top: 30px;
    transition: left 0.4s linear;
}

    .hide-box-left-panel-ranking.open {
        left: calc(22vw);
    }

    .hide-box-left-panel-ranking.close {
        left: 0;
    }

.hide-box-left-panel-services {
    position: fixed;
    width: 30px;
    height: 80px;
    top: 50vh;
    z-index: 1000;
    cursor: pointer;
    transition: left 0.4s linear;
    background-color: var(--white-speed);
    border-top-right-radius: 10px;
    border-bottom-right-radius: 10px;
    border-top: 1px solid #DAEBF3;
    border-right: 1px solid #DAEBF3;
    border-bottom: 1px solid #DAEBF3;
    text-align: center;
    color: #2a77e7;
    padding-top: 30px;
}

    .hide-box-left-panel-services.open {
        left: calc(30vw - 1px);
    }

    .hide-box-left-panel-services.close {
        left: 0;
    }

@media all and (max-width: 1600px) {
    .hide-box-left-panel-services {
        left: 455px;
    }

    .hide-box-left-panel-settings {
        left: 323px;
    }

    .hide-box-left-panel-ranking {
        left: 324px;
    }

    .hide-box-right-panel-settings {
        right: 323px !important;
    }

    .tacho-time-container {
        left: 340px !important;
        right: 328px !important;
    }
}

.hide-box-right-panel-settings {
    position: fixed;
    width: 30px;
    height: 80px;
    top: 50vh;
    z-index: 1000;
    cursor: pointer;
    transition: right 0.4s linear;
    background-color: var(--white-speed);
    border-top-left-radius: 10px;
    border-bottom-left-radius: 10px;
    border-top: 1px solid #DAEBF3;
    border-left: 1px solid #DAEBF3;
    border-bottom: 1px solid #DAEBF3;
    text-align: center;
    color: #2a77e7;
    padding-top: 30px;
    float: right;
}

    .hide-box-right-panel-settings.open {
        right: calc(20vw - 1px);
    }

    .hide-box-right-panel-settings.close {
        right: 0 !important;
    }

.hide-box-down-panel-settings {
    position: fixed;
    width: 80px;
    height: 30px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 1000;
    cursor: pointer;
    transition: bottom 0.4s linear;
    background-color: var(--white-speed);
    border-top-left-radius: 10px;
    border-top-right-radius: 10px;
    border-top: 1px solid #DAEBF3;
    border-left: 1px solid #DAEBF3;
    border-right: 1px solid #DAEBF3;
    text-align: center;
    color: #2a77e7;
    padding-top: 5px;
    float: right;
}

    .hide-box-down-panel-settings.open {
        bottom: calc(30vh - 1px);
    }

    .hide-box-down-panel-settings.close {
        bottom: 0 !important;
    }
/*.hide-box-down-panel-settings-one {
    position: fixed;
    width: 80px;
    height: 30px;
    left: 50%;
    transform: translateX(-50%);
    bottom: calc(10vw - 1px);
    z-index: 1000;
    cursor: pointer;
    transition: bottom 0.2s linear;
    background-color: var(--white-speed);
    border-top-left-radius: 10px;
    border-top-right-radius: 10px;
    border-top: 1px solid #DAEBF3;
    border-left: 1px solid #DAEBF3;
    border-right: 1px solid #DAEBF3;
    text-align: center;
    color: #2a77e7;
    padding-top: 5px;
    float: right;
}*/

.form-control-sf {
    background-color: var(--white-speed);
    border: none;
    border-bottom: 1px solid #A7BBC4;
}

.input-group-text-sf {
    background-color: var(--white-speed);
    border: none;
    border-bottom: 1px solid #A7BBC4;
    padding: 0rem 0.5rem !important;
}

.followmap-toggle {
    display: flex;
    justify-content: center;
    margin-bottom: 0.5rem;
    margin-top: -0.5rem;
}

.btn-nav-notifications {
    padding: 10px 0;
    top: 3px;
}

.box-calculate-route {
    position: fixed;
    bottom: 0;
    right: 0;
    width: 30vw;
    height: calc(100vh - 100px);
    z-index: 1002;
    background-color: #fff;
    border-top-left-radius: 5px;
    border-bottom-left-radius: 5px;
    padding: 2rem;
    border-left: 2px solid #DAEBF3;
}

.calculate-route-header {
    margin: -2rem -2rem 1rem;
    padding: 1rem 2rem;
    display: flex;
    outline: 2px solid var(--primary-color);
    justify-content: space-between;
    border-top-left-radius: 5px;
    background-color: var(--primary-color) !important;
}

.btn-sf-secondary-icon.active, .btn-sf-secondary-icon:active {
    color: #5189a7 !important;
    background-color: var(--white-speed) !important;
    border-color: transparent !important;
}

.btn-sf-secondary.active, .btn-sf-secondary:active {
    color: #5189a7 !important;
    background-color: var(--white-speed) !important;
    border-color: #5189a7 !important;
}

.btn-sf-primary.active, .btn-sf-primary:active {
    color: #FF9900 !important;
    background-color: var(--white-speed) !important;
    border-color: #FF9900 !important;
}

.btn-sf-info:active {
    color: #5189a7 !important;
    background-color: var(--white-speed) !important;
    border-color: #5189a7 !important;
}

.btn-sf-info.disabled {
    color: white !important;
    background-color: #5189a7 !important;
    border-color: #5189a7 !important;
}

.btn-sf-primary {
    color: var(--white-speed);
    background-color: #FF9900;
    border-radius: 5px;
    text-align: center;
    width: 110px;
    height: 35px;
    font-weight: 600;
}

    .btn-sf-primary:hover {
        color: var(--white-speed);
        background-color: #e77c25;
        transition: background-color 0.5s;
    }

.btn-sf-secondary {
    color: #5189a7;
    background-color: var(--white-speed);
    border: 1px solid #5189a7;
    border-radius: 5px;
    text-align: center;
    width: 110px;
    height: 35px;
    font-weight: 600;
}

.btn-sf-secondary-icon {
    color: #5189a7;
    text-align: center;
    font-size: 18px !important;
}

.btn-sf-secondary:hover {
    color: #5189a7;
    border-color: #5189a7;
    /*background-color: #5189a72b;*/
    background-color: #DAEBF3 !important;
}

.btn-sf-secondary-icon:hover {
    color: #5189a7;
}

.btn-sf-secondary-icon:active {
    color: transparent !important;
}

.btn-sf-secondary-icon.btn:disabled {
    color: #5189a7;
    border-color: transparent;
}

.btn-sf-secondary.btn:disabled {
    color: #5189a7;
    border: 1px solid #5189a7;
}

.btn-sf-primary.btn:disabled {
    color: white;
    background-color: #ff9900;
}

.btn-sf-info {
    color: white;
    background-color: #5189a7;
    border-radius: 5px;
    text-align: center;
    width: 110px;
    height: 35px;
    font-weight: 600;
}

    .btn-sf-info:hover {
        color: white;
        background-color: #326079;
        transition: background-color 0.5s;
    }

.btn-grid-icon {
    color: black !important;
    padding: 0px !important;
    box-shadow: none !important;
    background-image: none !important;
    transform: scale(0.8) !important;
    font-size: 18px !important;
}

.cursor-pointer {
    cursor: pointer;
}

.cursor-default {
    cursor: default;
}

.cursor-text {
    cursor: text;
}

.sf-text-blue {
    color: #5189a7;
}

.w-200 {
    width: 200px !important;
}

.modal-title {
    color: var(--primary-color);
    font-size: 17px;
    font-weight: 600;
}

.btn-menu-nav {
    background-color: #041F2E;
    color: var(--white-speed);
    border-radius: 6px;
    border: 1px solid var(--primary-color);
}

    .btn-menu-nav .dropdown-item {
        color: var(--white-speed);
        font-weight: 600;
        font-size: 13px;
    }

        .btn-menu-nav .dropdown-item:hover {
            color: var(--white-speed);
            font-weight: 600;
            font-size: 13px;
            background-color: #1a3c4e;
        }

        .btn-menu-nav .dropdown-item.disabled {
            color: #ccc;
        }

.dropdown-divider {
    border-top: 1px solid var(--primary-color) !important;
}

.dropdown-item.active, .dropdown-item:active {
    color: #ff9900;
    background-color: #041f2e;
}

.sf-label-form {
    font-size: 12px;
    color: var(--primary-color);
    font-weight: 600;
    display: block;
}

.accordion {
    width: 100%;
    padding: 0;
    /*margin: auto;*/
}

.mobile-accordion {
    border-radius: 0 !important;
    background: transparent !important;
}

    .mobile-accordion .accordion-item {
        border-radius: 0 !important;
        background: transparent !important;
    }

    .mobile-accordion .accordion-header {
        border-radius: 0 !important;
        background: transparent !important;
    }

    .mobile-accordion ::after {
        filter: invert(1);
        margin-right: 8px;
    }

.accordion-item {
    border: none !important;
    background-color: var(--white-speed) !important;
}

.accordion-header {
    border: none;
    box-shadow: inset 0 -1px 0 rgb(0 0 0 / 13%);
    padding-bottom: 0;
}

    .accordion-header h5 {
        margin: 0;
    }

.accordion-body {
    padding: 0 !important;
}

#submenu {
    width: 100%;
    height: 32px;
    background-color: var(--secondary-color);
}

    #submenu nav {
        background-color: var(--secondary-color);
    }

.navbar {
    padding: 0;
}

.h-30 {
    height: 30px;
}

.h-80 {
    height: 80px;
}

.navbar .l-option {
    font-size: 11px;
    color: var(--white-speed);
    display: block;
    padding: 0.5rem 1rem;
    cursor: pointer;
}

.navbar .update-info {
    font-size: 12px;
    color: var(--white-speed);
    display: block;
    padding: 0.5rem 0;
    cursor: default;
    color: #FF9900;
}

.navbar .l-option-disabled {
    font-size: 11px;
    color: #ccc;
    display: block;
    padding: 0.5rem 1rem;
    pointer-events: none;
}

.tag-disabled {
    pointer-events: none !important;
    opacity: 0.4;
}

.btn-sf-icon {
    width: 35px;
    height: 35px;
    border-radius: 35px;
    font-size: 0.8rem;
}

.form-check-label {
    font-family: 'Cabin', sans-serif;
    font-size: 13px;
    color: #222222;
}

.btn-submenu-nav {
    background-color: #041F2E;
    color: var(--white-speed);
    border-radius: 6px;
    border: 1px solid var(--primary-color);
    z-index: 10000;
}

    .btn-submenu-nav .disabled {
        color: #ccc !important;
    }

    .btn-submenu-nav .dropdown-item {
        color: var(--white-speed);
        font-weight: 400;
        font-size: 12px;
    }

        .btn-submenu-nav .dropdown-item:hover {
            color: var(--white-speed);
            font-weight: 400;
            font-size: 12px;
            background-color: #1a3c4e;
        }

.ddl-group .dropdown-toggle::after {
    display: none;
}

.drag-drop-data-grid td {
    border-top: 1px solid black !important;
    border-bottom: 1px solid black !important;
}

.box-item-title {
    color: #5189A7 !important;
    font-size: 14px;
    font-weight: 600;
}

    .box-item-title i {
        font-size: 16px;
    }

.no-shadow {
    box-shadow: none !important;
}

.accordion-button:not(.collapsed) {
    box-shadow: none;
}

.mini-title {
    font-size: 13px;
    color: var(--primary-color);
    font-weight: 600;
    margin: 15px 0 0 0;
}

.box-item-detail-list .list-item-show-info {
    position: absolute;
    opacity: 0;
    z-index: 9999;
    right: 10px;
    width: fit-content;
}

.box-item-detail-list:hover .list-item-show-info {
    opacity: 1;
}

.h4-title {
    margin: 1rem 0 1rem 1rem !important;
    font-size: 16px !important;
    color: #5189A7 !important;
    font-weight: 600 !important;
}

.report-list-group {
    opacity: 1 !important;
    font-weight: bold !important;
    background-color: #2A5E7A !important;
}

    .report-list-group:hover {
        opacity: 1 !important;
        font-weight: bold !important;
        background-color: #2A5E7A !important;
    }

.draggable {
    border: 1px solid #ccc;
    border-radius: 5px;
    margin: 1rem;
    padding: 1rem;
    display: inline-block;
    cursor: move;
}

.drop-target {
    border: 1px solid #DAEBF3;
    margin: 1rem;
    padding: 1rem;
    display: inline-block;
}

.list-services {
    margin: 0 !important;
    border-radius: 3px;
    width: 100%;
    padding: 5px 0px 5px 5px;
    justify-content: end;
    display: inline-grid;
}

.list-services-expanded {
    margin: 0 !important;
    border-radius: 3px;
    width: 100%;
    padding: 5px 5px 5px 5px;
}

.list-services-tree-expanded {
    overflow-y: auto;
    max-height: calc(100vh - 290px);
    border-radius: 3px;
    border: 1px solid #DAEBF3;
    margin-right: 0.1rem;
    margin-left: 0.1rem;
    height: 100vh;
}

.list-services-expanded-tree {
    margin: 0 !important;
    border-radius: 3px;
    width: 100%;
    padding: 5px 30px 5px 5px;
}


.list-services .service-item {
    background-color: #DAEBF3 !important;
    border-radius: 2px !important;
    border: 1px solid #DAEBF3;
    color: var(--primary-color) !important;
    padding: 5px;
    margin: 0 0 5px 0;
    width: calc(26vw) !important;
}

.list-services-expanded .service-item {
    background-color: #DAEBF3 !important;
    border-radius: 2px !important;
    border: 1px solid #DAEBF3;
    color: var(--primary-color) !important;
    padding: 5px;
    margin: 0 0 5px 0;
}

.list-services-expanded-tree .service-item-expanded {
    background-color: #DAEBF3 !important;
    border-radius: 2px !important;
    border: 1px solid #DAEBF3;
    color: var(--primary-color) !important;
    padding: 5px;
    margin: 0 0 5px 25px;
    width: 100%;
}

.service-card {
    box-shadow: none !important;
    margin-left: 0px !important;
    margin-right: 0px !important;
    border-radius: 8px !important;
}

.service-card-draw {
    background-color: #CFE2F3 !important;
}

.service-card-pending {
    background-color: #D9D9D9 !important;
}

.service-card-breaked {
    background-color: #E6D9F9 !important;
}

.service-card-issued {
    background-color: #F4F9C2 !important;
}

.service-card-canceled {
    background-color: #E57373 !important;
}

.service-card-started {
    background-color: #FFE1B2 !important;
}

.service-card-finished {
    background-color: #D9F2D9 !important;
}

.category-button {
    width: 100%;
    font-size: 12px !important;
}

    .category-button .span {
        font-size: 12px !important;
    }

    .category-button:hover {
        color: #1e2125;
        background-color: #e9ecef;
    }

@media all and (max-width: 1600px) {
    .list-services .service-item {
        background-color: #DAEBF3 !important;
        border-radius: 2px !important;
        border: 1px solid #DAEBF3;
        color: var(--primary-color) !important;
        padding: 5px;
        margin: 0 0 5px 0;
        width: 395px !important;
    }
}

.segment-selected {
    background-color: lightblue;
    padding-top: 0;
    padding-bottom: 0;
}

.label-selected {
    background-color: lightblue;
    padding-top: 0;
    padding-bottom: 0;
}

.vehicle-tree-no-available {
    background-color: lightgray;
    padding-top: 0;
    padding-bottom: 0;
}

.label-selected-mobile {
    background-color: #006181;
}

.box-item .fa {
    margin-top: 3px;
    margin-right: 3px;
}

.v-widgetrouting {
    width: 440px !important;
    position: absolute !important;
    left: calc(99vw - 440px) !important;
    top: 13vh !important;
}

    .v-widgetrouting .options {
        height: max-content;
    }

    .v-widgetrouting .report {
        max-height: 728px !important;
        position: absolute !important;
        left: 45px !important;
    }

    .v-widgetrouting .closeBtn {
        display: none !important;
    }

.no-arrow-logo {
    border-top-color: transparent !important;
}

.pop-up-container {
    width: 460px;
    /* Afegit per substituir el padding del content, ja que altres pop-up de cercalia es veien afectats*/
    margin: -10px -20px !important;
    padding: 0px 0px 5px 0px !important;
}

    .pop-up-container .accordion {
        margin: 0 !important;
    }

.pop-up-container-mobile {
    width: 96vw;
    /* Afegit per substituir el padding del content, ja que altres pop-up de cercalia es veien afectats*/
    margin: -10px -20px !important;
    padding: 0px 0px 5px 0px !important;
}

    .pop-up-container-mobile .accordion {
        margin: 0 !important;
    }

.driver-link:hover {
    color: red;
}

.v-control-button {
    font-size: 22px !important;
    align-items: center !important;
    width: 30px;
    justify-content: center;
    background-color: var(--white-speed) !important;
}

    .v-control-button > span {
        cursor: pointer !important;
    }

    .v-control-button > i {
        height: 30px;
        align-content: center;
    }

    .v-control-button > span > span {
        cursor: pointer !important;
    }

@media all and (min-width: 1000px) {
    .v-control-button {
        width: 40px;
    }
}

#box-map-extra-options-mobile .v-control-button.enabled {
    border-left: 3px solid var(--mdc-theme-primary) !important;
    border-bottom: 0 !important;
}

.menu-toggle {
    background: none;
    border: none;
    color: var(--white-speed);
    font-size: 8vw;
    cursor: pointer;
}

.width-icon-profile{
    width: 1.5rem;
}

.form-check-tree {
    display: block !important;
    min-height: 1.5rem !important;
    padding-left: 0 !important;
    margin-bottom: .125rem !important;
    width: 100% !important;
}

.form-check-tree.mobile {
    display: block !important;
    min-height: 3vh !important;
    padding-left: 0 !important;
    margin-bottom: .125rem !important;
    width: 100% !important;
}

.tree-header {
    padding-right: 1em !important;
}

.form-check-tree-check {
    padding-left: 0.5rem !important;
    width: 24px !important;
    padding-right: 1.5rem;
}

    .form-check-tree-check.mobile {
        padding-left: 1rem !important;
        width: 24px !important;
        padding-right: 2rem !important;
    }

.accordion-button::after {
    right: 5px;
    position: absolute;
}

.form-check-input {
    width: 12px;
    height: 12px;
}

    .form-check-input:checked {
        background-color: #ffb240 !important;
        border-color: #ccc !important;
    }

.form-check-input.mobile {
    width: 5vw;
    height: 5vw;
    margin-top: 0;
}

.form-check-input-radius {
    width: 14px !important;
    height: 14px !important;
}

    .form-check-input-radius:checked {
        background-color: #ffb240 !important;
        border-color: #ccc !important;
    }

.detail-tree-pop-up {
    position: absolute;
    border: 2px solid var(--modal-blue);
    border-radius: 6px;
    left: 22vw;
    z-index: 1000;
    background: var(--white-speed);
    max-width: 500px;
}

@media only screen and (max-width: 1450px) {
    .detail-tree-pop-up {
        left: 315px;
    }
}

.table-forecast thead {
    display: none !important;
}

.table-forecast td {
    padding: 3px 0 !important;
}

    .table-forecast td span {
        font-size: 13px !important;
    }

    .table-forecast td:first-child {
        padding: 3px 7px !important;
    }

.table-forecast-mobile thead {
    display: none !important;
}

.table-forecast-mobile td {
    padding: 3px 0 !important;
}

    .table-forecast-mobile td span {
        font-size: 11px !important;
    }

    .table-forecast-mobile td:first-child {
        padding: 3px 7px !important;
    }

.table-forecast-mobile .rz-grid-table-fixed {
    table-layout: auto !important;
}

.d-sm-block-sf {
    display: inline-block;
}

.user-selected {
    font-weight: 700;
    color: orange;
}

.hide-box-bottom-panel-settings {
    display: none;
}

/* Definición de la animación de parpadeo */
@keyframes blink-animation {
    0% {
        opacity: 1;
    }

    50% {
        opacity: 0.5;
    }

    100% {
        opacity: 1;
    }
}

/* Animación de parpadeo */
.blink {
    animation: blink-animation 2s infinite ease-in-out;
    /* Opcional: Will-change ayuda al navegador a optimizar el renderizado */
    will-change: opacity;
}

@media only screen and (max-width: 600px) {
    #submenu {
    }

        #submenu .navbar-nav {
            display: block;
        }

        #submenu ul li {
            float: left;
        }

    .box-left-panel-settings {
        width: 100%;
        height: calc(100vh - 90px);
        bottom: 0;
    }

    .hide-box-left-panel-settings {
        display: none;
    }

    .hide-box-left-panel-ranking {
        display: none;
    }

    .hide-box-right-panel-settings {
        display: none;
    }

    .hide-box-down-panel-settings {
        display: none;
    }

    .navbar-nav {
        display: flex;
        align-items: center;
        flex-direction: row !important;
    }

    .nav-link {
        width: 100%;
        text-align: left;
    }

    .full-content-detail .content-detail {
        margin-left: 0;
        padding: 20px;
        width: 100%;
        overflow-y: auto;
    }

    .hidden-md {
        display: none !important;
    }

    .detail-mobile-xl {
        width: 700px !important;
    }

    .full-content-detail .content-detail .detail {
        max-height: max-content;
    }

    .d-sm-block-sf {
        display: block;
    }

    .h-100-sm {
        height: 100vh;
    }

    .pt-sm-0 {
        padding-top: 0;
    }

    .hide-box-bottom-panel-settings {
        display: block;
        position: fixed;
        left: calc(50% - 40px);
        width: 80px;
        height: 30px;
        bottom: 0;
        z-index: 1000;
        cursor: pointer;
        background-color: var(--white-speed);
        border-top-right-radius: 10px;
        border-top-left-radius: 10px;
        border-top: 1px solid #DAEBF3;
        border-right: 1px solid #DAEBF3;
        border-left: 1px solid #DAEBF3;
        text-align: center;
        color: #2a77e7;
        padding-top: 5px;
    }

    .control-interface-container {
        display: none !important;
    }

    .cercalia-logo {
        bottom: 0 !important;
    }
}

.btn {
    padding: .200rem .5rem !important;
    font-size: 13px;
}

    .btn.disabled {
        border: 1px solid transparent;
    }

.btn-icon-circle {
    transform: scale(1.2);
    border: 1px solid;
    border-radius: 50%;
    width: 35px;
    height: 35px;
    align-items: center;
    justify-content: center;
    display: flex;
}

    .btn-icon-circle:hover {
        border-color: #5189a7 !important;
        background-color: #5189a72b !important;
    }

.no-x-gutter {
    --bs-gutter-x: 0 !important;
}

.row-red td, .row-red td .rz-cell-data {
    background-color: #FFE4E1 !important;
}

.row-yellow td, .row-yellow td .rz-cell-data {
    background-color: #FFF9C4 !important;
}

.row-none td, .row-none td .rz-cell-data {
    background-color: transparent !important;
}

.row-green td, .row-green td .rz-cell-data {
    background-color: lightgreen !important;
    color: var(--white-speed) !important;
}

.row-selected-grid-red {
    outline-offset: -2px;
    outline: 2px solid #FF7070;
}

.row-selected-grid-yellow {
    outline-offset: -2px;
    outline: 2px solid #E5E543;
}

.row-selected-grid-none {
    outline-offset: -2px;
    outline: 2px solid #ADD8E6;
}

.row-selected-grid-green {
    outline-offset: -2px;
    outline: 2px solid #58A55D;
}

.maintenance-grid table {
    border-collapse: collapse !important;
}

td.red-text span.rz-cell-data {
    color: #f95151 !important;
}

.btn-speed {
    color: var(--white-speed) !important;
    background-color: #FF9900 !important;
    border-radius: 5px;
    width: 100%;
    text-align: center;
    padding: 12px 0 !important;
}

    .btn-speed.active, .btn-speed:active {
        color: #FF9900 !important;
        background-color: var(--white-speed) !important;
        border-color: #FF9900 !important;
    }

    .btn-speed:hover {
        color: var(--white-speed) !important;
        background-color: #e77c25 !important;
        transition: background-color 0.5s;
    }

.btn-cancel {
    color: #5189a7;
    background-color: var(--white-speed);
    border: 1px solid #5189a7;
    border-radius: 5px;
    text-align: center;
    font-weight: 600;
    padding: 12px 0 !important;
}

    .btn-cancel:hover {
        color: #5189a7;
        border-color: #5189a7;
        background-color: #5189a72b;
    }

    .btn-cancel:active {
        color: #5189a7 !important;
        background-color: var(--white-speed) !important;
        border-color: #5189a7 !important;
    }

.block-ui {
    position: fixed;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    z-index: 9999;
    background: rgba(0, 0, 0, 0);
}

.loader {
    position: fixed;
    left: 0;
    top: 86px;
    width: 100%;
    height: calc(100vh - 86px);
    z-index: 9999;
    background: rgba(0, 0, 0, 0.5);
}

    .loader::before {
        content: ""; /*"Cargando...";*/
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        color: white;
        font-size: 24px;
        font-family: Arial, sans-serif;
    }

.map-label-green .mapboxgl-popup-content, .map-label-green-closed .mapboxgl-popup-content, .map-label-green-sensor .mapboxgl-popup-content {
    background-color: #44f814;
    text-align: center;
    font-weight: 700;
}

.map-label-red .mapboxgl-popup-content, .map-label-red .mapboxgl-popup-content .text {
    color: var(--white-speed);
    background-color: #ff0000;
    text-align: center;
    font-weight: 700;
}

.map-label-red .maplibregl-popup-tip.mapboxgl-popup-tip, .map-label-green-closed .maplibregl-popup-tip.mapboxgl-popup-tip, .map-label-green-sensor .maplibregl-popup-tip.mapboxgl-popup-tip,
.map-label-end .maplibregl-popup-tip.mapboxgl-popup-tip {
    display: none;
}

.map-label-overlay .maplibregl-popup-tip.mapboxgl-popup-tip {
    border-top-color: #8bf5fe;
}

.map-label-start .maplibregl-popup-tip.mapboxgl-popup-tip {
    border-top-color: #ff35f9;
}

.map-label-overlay .maplibregl-popup-content.mapboxgl-popup-content {
    color: #000;
    background-color: #8bf5fe;
}

.map-label-start .maplibregl-popup-content.mapboxgl-popup-content {
    color: var(--white-speed) !important;
    background-color: #ff35f9 !important;
    font-weight: 700 !important;
}

.map-label-end .maplibregl-popup-content.mapboxgl-popup-content {
    color: var(--white-speed) !important;
    background-color: #33339b !important;
    font-weight: 700 !important;
}

.map-label-red::after {
    content: "";
    position: absolute;
    top: -5px;
    left: 47%;
    width: 0;
    height: 0;
    border-left: 5px solid transparent;
    border-right: 5px solid transparent;
    border-bottom: 5px solid red;
}

.map-label-green-sensor::after {
    content: "";
    position: absolute;
    bottom: -5px;
    left: 0;
    width: 0;
    height: 0;
    border-left: 5px solid transparent;
    border-right: 5px solid transparent;
    border-top: 5px solid #44f814;
}

.map-label-green-closed::after {
    content: "";
    position: absolute;
    bottom: -5px;
    right: 0;
    width: 0;
    height: 0;
    border-left: 5px solid transparent;
    border-right: 5px solid transparent;
    border-top: 5px solid #44f814;
}


.map-label-end::after {
    content: "";
    position: absolute;
    top: 20px;
    left: calc(50% - 5px);
    width: 0;
    height: 0;
    border-left: 5px solid transparent;
    border-right: 5px solid transparent;
    border-top: 5px solid #33339b;
}

.mapboxgl-popup-content-logo {
    box-shadow: 0 0px 0px 0px rgba(0, 0, 0, 0), 0 0px 0px 0 rgba(0, 0, 0, 0), 0 0px 0px 0 rgba(0, 0, 0, 0) !important;
    background: rgba(0, 0, 0, 0) !important;
    box-shadow: 0 0px 0px rgba(0, 0, 0, 0) !important;
}

.label-service-green .maplibregl-popup-content.mapboxgl-popup-content {
    color: #000;
    background-color: #8ec22e;
}

.label-service-red .maplibregl-popup-content.mapboxgl-popup-content {
    color: #000;
    background-color: #db3d3d;
}

.label-service-orange .maplibregl-popup-content.mapboxgl-popup-content {
    color: #000;
    background-color: #fccc57;
}

.sf-input-numeric {
    width: 7rem !important;
}

.sf-input-numeric-format {
    width: 120px !important;
}

/* typical phone screen resolution */
@media only screen and (max-width : 667px) {
    .sf-input-numeric-format {
        width: 100px !important;
    }
}

.span-work-duration {
    font-size: 14px;
    font-weight: 700;
    color: #01409e;
}

.span-work-duration-map {
    font-size: 14px;
    font-weight: 350;
    color: #01409e;
}

#box-map-extra-options {
    /*position: absolute !important;*/
    right: 20px;
    top: 20px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    min-width: 440px;
}

#box-map-extra-options-mobile {
    right: 3vw;
    bottom: 5vh;
    background-color: var(--white-speed);
    padding: 5px;
    border-radius: 10px;
    z-index: 20;
}

#box-map-extra-geo-mobile {
    right: 16vw;
    bottom: 5vh;
    background-color: var(--white-speed);
    padding: 5px;
    border-radius: 10px;
    z-index: 20;
}

.custom-map-toolbar {
    background-color: var(--white-speed);
    display: flex !important;
}

    .custom-map-toolbar .v-control-button:hover .v-tooltip {
        display: block !important;
    }

    .custom-map-toolbar select, .custom-map-toolbar input {
        color: #4caf50;
        font-size: 11px;
    }

    .custom-map-toolbar input {
        text-align: right;
    }

.override-box-options-cercalia {
    position: relative !important;
    top: auto !important;
    right: auto !important;
}

.container-toolbar-map {
    width: auto;
    overflow: hidden;
    white-space: nowrap;
    position: relative;
    z-index: 888;
}

    .container-toolbar-map .header-toolbar-map {
        cursor: pointer;
        display: inline-block;
        position: absolute;
        top: 6px;
        left: -15px;
        background-color: var(--white-speed);
        border-top-left-radius: 5px;
        border-bottom-left-radius: 5px;
        width: 15px;
        height: 30px;
        border-top: 1px solid #4caf50;
        border-bottom: 1px solid #4caf50;
        border-left: 1px solid #4caf50;
    }

        .container-toolbar-map .header-toolbar-map::after {
            content: '<';
            transition: transform 0.3s ease-in-out;
            color: #4caf50;
            top: 7px;
            position: relative;
            left: 4px;
        }

    .container-toolbar-map .content-toolbar-map {
        display: inline-block;
        transform: translateX(100%);
        transition: transform 0.3s ease-in-out;
        position: relative;
    }

    .container-toolbar-map.active .content-toolbar-map {
        transform: translateX(0);
    }

    .container-toolbar-map.active .header-toolbar-map::after {
        content: '>';
    }

button.btn-close {
    position: relative;
    background: none;
    background-color: transparent;
    border: none;
    padding: 0;
    cursor: pointer;
    opacity: 0.8;
}

    button.btn-close:before, button.btn-close:after {
        position: absolute;
        content: ' ';
        height: 17px !important;
        width: 3px !important;
        background-color: var(--white-speed);
        top: 20%;
        left: 45%;
        border-radius: 5px !important;
    }

    button.btn-close.btn-blue:before, button.btn-close.btn-blue:after {
        background-color: var(--primary-color);
        height: 22px;
    }

    button.btn-close:before {
        transform: rotate(45deg);
        width: 3px;
    }

    button.btn-close:after {
        transform: rotate(-45deg);
        width: 3px;
    }

    button.btn-close:hover {
        opacity: 1;
    }

.content-detail-1-block-fix {
    height: calc(100vh - 168px) !important;
}

.rz-data-grid-taco {
    max-height: calc(100vh - 380px) !important;
    overflow-y: auto;
}

.box-label-vehicle {
    padding: 3px;
}

    .box-label-vehicle .box-label-img {
        width: 40px;
        height: 40px;
        float: left;
        margin-right: 10px;
        background-size: contain;
        background-repeat: no-repeat;
        background-position: center;
    }

    .box-label-vehicle .box-label-img-tacho {
        width: 25px;
        height: 30px;
        float: left;
        margin-right: 5px;
        background-size: contain;
        background-repeat: no-repeat;
        background-position: center;
    }

    .box-label-vehicle .box-label-info {
        float: left;
    }

        .box-label-vehicle .box-label-info p {
            margin: 0;
            padding: 0;
        }

        .box-label-vehicle .box-label-info hr {
            margin: 5px 0;
            padding: 0;
        }

.grd-fuel {
    max-height: 230px;
    overflow-y: auto;
}

.item-trailer .fa-info-circle {
    position: absolute;
    right: 16px;
    z-index: 9999;
}

.item-trailer .fa-eye {
    position: absolute;
    right: 33px;
    z-index: 9999;
}

.item-trailer .fa-comment {
    position: absolute;
    right: 56px;
    z-index: 9999;
}

.item-trailer .fa-compass {
    position: absolute;
    right: 77px;
    z-index: 9999;
}

.item-trailer .fa-globe {
    position: absolute;
    right: 98px;
    z-index: 9999;
}

.fa-compass {
    top: 3px !important;
}

.btn-day {
    width: 40px;
    height: 40px;
    border-radius: 40px;
    text-align: center;
    font-size: 14px;
    padding-top: 8px;
    cursor: pointer;
    display: inline-block;
    margin-right: 6px;
    margin-bottom: 10px;
}

.btn-day-enabled {
    background-color: #5189A7;
    color: #fff;
}

.btn-day-disabled {
    background-color: #F2F6F8;
    color: #A7BBC4;
}

.btn-service-image {
    border: 1px solid #DAEBF3;
    border-radius: 5px;
    color: #DAEBF3;
    width: 50px;
    height: 50px;
    font-size: 14px;
    display: flex;
    justify-content: center;
    align-items: center;
}

    .btn-service-image.selected {
        border: 1px solid #5189A7;
        color: #5189A7;
        cursor: pointer;
    }

.box-service-image {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 600px;
    width: 100%;
}

    .box-service-image img {
        width: 100%;
        max-height: 600px;
    }

/* Cruz para visualizar el semi vinculado a la tractora */

.accordion-button.accordion-button-trailer::after {
    background-image: url('data:image/svg+xml,<svg width="100" height="100" xmlns="http://www.w3.org/2000/svg"> <rect width="0" height="0" fill="white" /> <line x1="50" y1="25" x2="50" y2="75" stroke="rgba(12, 99, 228, 1)" stroke-width="5"/> <line x1="25" y1="50" x2="75" y2="50" stroke="rgba(12, 99, 228, 1)" stroke-width="5"/> </svg>');
}

/* Guión para ocultar el semi vinculado a la tractora */

.accordion-button.accordion-button-trailer:not(.collapsed)::after {
    background-image: url('data:image/svg+xml,<svg width="100" height="100" xmlns="http://www.w3.org/2000/svg"> <rect width="0" height="0" fill="white" /> <line x1="25" y1="50" x2="75" y2="50" stroke="rgba(12, 99, 228, 1)" stroke-width="5"/> </svg>');
}

/* Ojo para visualizar y ocultar el password en la pantalla del login */

.input-group-addon {
    position: absolute;
    right: 0;
    top: 0;
    bottom: 0;
    display: flex;
    align-items: center;
    padding: 0px 10px;
}

/* Resumen de ruta en el mapa */

.summary-container {
    display: flex;
    flex-direction: column;
    height: calc(100vh - 100px);
    width: calc(20vw);
    min-width: 324px !important;
    background-color: var(--white-speed);
    position: fixed;
    bottom: 0;
    z-index: 1000;
    border-top-left-radius: 6px;
    border-bottom-left-radius: 6px;
    border-top: 1px solid rgb(218, 235, 243);
    border-bottom: 1px solid rgb(218, 235, 243);
    border-left: 1px solid rgb(218, 235, 243);
    overflow: hidden auto;
    padding: 10px 10px 10px 10px;
    min-height: calc(100vh - 100px);
    margin-top: auto;
    transition: right 0.4s linear;
}

    .summary-container.open {
        right: 0;
    }

    .summary-container.close {
        right: -20vw;
    }

.header-route-summary {
    display: flex;
    justify-content: space-between;
    flex-shrink: 0;
    background-color: #103c54;
    color: white;
    padding: 10px;
    font-weight: bold;
    border-radius: 5px 5px 5px 5px;
    font-size: 14px;
    position: sticky;
    top: 0px;
    left: 0px;
    z-index: 10;
}

.route-summary {
    font-size: 11px;
    line-height: 14px;
    position: relative;
}

.scroll-container {
    overflow-y: auto;
    overflow-x: hidden;
    flex: 1;
}

.segment {
    display: flex;
    justify-content: space-between;
    padding: 5px;
    border-top: 1px solid #ccc;
    transition: background-color 0.3s;
    height: 85px;
    cursor: pointer;
}

    .segment:hover {
        background-color: #f1f1f1;
    }

.segment-mobile {
    display: flex;
    justify-content: space-between;
    padding: 5px;
    height: 14vh;
    font-size: clamp(9px, 2.8vw, 18px);
}

.segment-mobile-list {
    display: flex;
    justify-content: space-between;
    height: 14vh;
    font-size: clamp(9px, 2.8vw, 18px);
}

.segment-stop {
    padding: 5px;
    border-top: 1px solid #ccc;
    transition: background-color 0.3s;
    height: auto;
    cursor: pointer;
}

    .segment-stop:hover {
        background-color: #f1f1f1;
    }

.segment-stop-mobile {
    display: flex;
    padding: 5px;
    justify-content: space-between;
    height: 11vh;
    align-items: center;
    cursor: pointer;
    font-size: 11px;
}

.segment-date {
    height: 40px;
    align-items: center;
    display: flex;
    background-color: #003d55;
    color: var(--white-speed);
    padding: 5px;
    border-top: 1px solid var(--white-speed);
}

.segment-date-mobile {
    position: absolute;
    width: 100%;
    height: 6vh;
    z-index: 1098;
    align-items: center;
    display: flex;
    background-color: #003d55;
    color: var(--white-speed);
    padding: 0.5rem;
}

.ot-segment {
    align-items: center;
    padding: 5px;
    border-top: 1px solid var(--white-speed);
    transition: background-color 0.3s;
    cursor: pointer;
    font-size: 12px;
}

    .ot-segment:hover {
        background-color: #f1f1f1;
    }

.ot-segment-one {
    align-items: center;
    padding: 5px;
    border-top: 1px solid #ccc;
    cursor: default;
    font-size: 12px;
}

.command-list:hover {
    background-color: #f1f1f1;
}

.legend-item {
    font-size: 12px;
    display: flex;
    align-items: center;
    gap: 5px;
}

.legend-color {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    border: 1px solid #000;
}

.label-selected:hover {
    background-color: lightblue;
}

.segment-selected:hover {
    background-color: lightblue;
}

.final-summary {
    padding: 5px 10px 10px 10px;
    position: sticky;
    width: 100%;
    bottom: 1px;
    background: var(--white-speed);
    font-size: 12px;
}

    .final-summary .section-title {
        display: flex;
        align-items: center;
    }

    .final-summary .title-text {
        font-weight: bold;
        margin-right: 10px;
        white-space: nowrap;
    }

    .final-summary .title-line {
        flex-grow: 1;
        /*border: 0;*/
    }

    .final-summary .drivers {
        padding: 0px 0px 10px 10px;
        margin-left: 10px;
    }

.travel-route-icon {
    height: 75px;
    position: absolute;
    right: 50%;
}

.travel-route-icon-mobile {
    height: 12vh;
    position: absolute;
    right: 50%;
}

.route-duration, .route-distance {
    flex: 1;
    text-align: left;
    font-weight: bold;
}

.route-ubication {
    flex: 1;
    text-align: left;
    position: absolute;
}

.route-hour {
    flex: 1;
    position: absolute;
    margin-left: 5px;
    text-align: left;
}


/*.tacho-time-container-one {
    display: flex;
    flex-direction: column;
    height: calc(10vw);
    min-height: 300px;
    background-color: var(--white-speed);
    position: fixed;
    left: calc(22vw + 5px);
    right: calc(20vw + 5px);
    bottom: 0px;
    z-index: 1000;
    border-top-left-radius: 6px;
    border-top-right-radius: 6px;
    border-bottom-left-radius: 6px;
    border-bottom-right-radius: 6px;
    border-top: 1px solid rgb(218, 235, 243);
    border-right: 1px solid rgb(218, 235, 243);
    border-left: 1px solid rgb(218, 235, 243);
    overflow: hidden auto;
    padding: 10px 10px 5px 10px;
    min-height: 190px;
    margin-top: auto;
}*/

.tacho-time-container {
    display: flex;
    flex-direction: column;
    height: 30vh;
    background-color: var(--white-speed);
    position: fixed;
    left: calc(22vw + 5px);
    right: calc(20vw + 5px);
    bottom: 0px;
    z-index: 1000;
    border-top-left-radius: 6px;
    border-top-right-radius: 6px;
    border-bottom-left-radius: 6px;
    border-bottom-right-radius: 6px;
    border-top: 1px solid rgb(218, 235, 243);
    border-right: 1px solid rgb(218, 235, 243);
    border-left: 1px solid rgb(218, 235, 243);
    overflow: hidden auto;
    padding: 10px 10px 10px 10px;
    min-height: 30vh;
    margin-top: auto;
    transition: bottom 0.4s linear;
}

    .tacho-time-container.open {
        bottom: 0;
    }

    .tacho-time-container.close {
        bottom: -30vh;
        min-height: 0 !important;
    }

.tacho-time-date {
    display: flex;
    justify-content: space-between;
    flex-shrink: 0;
    padding: 10px;
    position: sticky;
    top: 0px;
    left: 0px;
    z-index: 10;
    align-items: baseline;
}

.tacho-time-block {
    position: relative;
}

.status-button {
    border-radius: 20px;
    width: 8rem;
    padding: 6px 12px;
    font-size: 12px;
    transition: opacity 0.3s ease;
}

.unselect {
    opacity: 0.6 !important;
}

    .unselect.disabled {
        opacity: 0.2 !important;
    }

/* Colores por tipo */
.route-speed, .route-speed:hover, .route-speed:active {
    background-color: #ff5733 !important;
    color: var(--white-speed) !important;
}

.route-fuel, .route-fuel:hover, .route-fuel:active {
    background-color: #873e23 !important;
    color: var(--white-speed) !important;
}

.route-warning, .route-warning:hover, .route-warning:active {
    background-color: #FE9900 !important;
    color: var(--white-speed) !important;
}

.route-alarm, .route-alarm:hover, .route-alarm:active {
    background-color: #ff3333 !important;
    color: var(--white-speed) !important;
}

.route-sensor, .route-sensor:hover, .route-sensor:active {
    background-color: #0479cc !important;
    color: var(--white-speed) !important;
}

.box-summary-date {
    position: absolute;
    top: 55px;
    right: 10px;
}

.tree-container-chain {
    display: flex;
    flex-direction: column;
    height: calc(100vh - 100px);
    width: calc(30vw);
    background-color: var(--white-speed);
    position: fixed;
    bottom: 0;
    z-index: 1000;
    border-top-right-radius: 6px;
    border-bottom-right-radius: 6px;
    border-top: 1px solid #DAEBF3;
    border-bottom: 1px solid #DAEBF3;
    border-right: 1px solid #DAEBF3;
    overflow-y: auto;
    padding: 5px;
    overflow-x: hidden;
    transition: left 0.4s linear;
}

    .tree-container-chain.open {
        left: 0;
    }

    .tree-container-chain.close {
        left: -30vw;
    }

    .tree-container-chain .box-item {
        box-shadow: inset 0 -1px 0 rgb(0 0 0 / 13%);
    }

        .tree-container-chain .box-item .fas {
            margin-top: 2px;
            font-size: 12px;
        }

        .tree-container-chain .box-item label {
            font-size: 12px;
            color: var(--primary-color);
        }


.hide-box-left-panel-settings-chain {
    position: fixed;
    width: 30px;
    height: 80px;
    top: 50vh;
    z-index: 1000;
    cursor: pointer;
    transition: left 0.4s linear;
    background-color: var(--white-speed);
    border-top-right-radius: 10px;
    border-bottom-right-radius: 10px;
    border-top: 1px solid #DAEBF3;
    border-right: 1px solid #DAEBF3;
    border-bottom: 1px solid #DAEBF3;
    text-align: center;
    color: #2a77e7;
    padding-top: 30px;
}

    .hide-box-left-panel-settings-chain.open {
        left: calc(30vw - 2px);
    }

    .hide-box-left-panel-settings-chain.close {
        left: 0;
    }

.sp-ddl-filter {
    width: 140px !important;
    border-left: 1px solid #DAEBF3 !important;
}

    .sp-ddl-filter .btn.dropdown-toggle {
        width: 140px !important;
        padding: 8px !important;
        text-align: left !important;
        color: var(--primary-color) !important;
        font-size: 13px !important;
    }

    .sp-ddl-filter .dropdown-toggle::after {
        float: right !important;
        top: 10px !important;
        position: relative !important;
    }

.ddl-filter-selected {
    background-color: var(--primary-color) !important;
}

    .ddl-filter-selected, .ddl-filter-selected i {
        color: var(--white-speed) !important;
    }

.btn-submenu-nav-sp {
    border: 1px solid #DAEBF3 !important;
    padding-top: 5px !important;
    width: 140px !important;
}

    .btn-submenu-nav-sp .dropdown-item {
        font-size: 11px !important;
        padding-top: 7px !important;
        padding-bottom: 7px !important;
        cursor: pointer !important;
    }


    .btn-submenu-nav-sp .dropdown-item-large {
        font-size: 13px !important;
    }

    .btn-submenu-nav-sp .dropdown-item-title {
        color: #5189A7 !important;
        font-size: 8px !important;
        padding-top: 15px !important;
    }

.bor-bottom-blue {
    border-bottom: 1px solid #DAEBF3 !important;
}

.list-item-show-info {
    position: relative;
    opacity: 0;
    z-index: 9999;
    right: 20px;
    margin-top: 2px;
}

.service-item:hover .list-item-show-info {
    opacity: 1;
}

.service-item-expanded:hover .list-item-show-info {
    opacity: 1;
}

.consignment-note-article-card {
    border-bottom: 3px solid #DAEBF3;
    border-left: 3px solid #DAEBF3;
    border-right: 3px solid #DAEBF3;
    border-radius: 0px 0px 10px 10px !important;
    box-shadow: none !important;
    margin-left: 90px;
    margin-right: 70px;
    padding-top: 10px !important;
    padding-bottom: 10px !important;
}

.slash-icon-red {
    background-color: transparent !important;
    font-size: 20px !important;
    color: red;
    padding-top: 0px !important;
}

    .slash-icon-red:hover {
        color: red !important;
    }

.label-vehicle-blue .maplibregl-popup-content.mapboxgl-popup-content {
    background-color: #64B5F6;
    color: white;
}

.label-vehicle-orange .maplibregl-popup-content.mapboxgl-popup-content {
    background-color: #FFA726;
    color: white;
}

/*.label-vehicle-orange > .maplibregl-popup-tip.mapboxgl-popup-tip {
    border-color: #FFA726;
}*/

.label-vehicle-green .maplibregl-popup-content.mapboxgl-popup-content {
    background-color: #81C784;
    color: white;
}

.label-vehicle-red .maplibregl-popup-content.mapboxgl-popup-content {
    background-color: #F74A4A;
    color: white;
}

/* Colores para las lineas de ayuda de los servicios */
.label-service-pastel-red .maplibregl-popup-content.mapboxgl-popup-content {
    color: #000;
    background-color: #FFB3BA;
}

.label-service-pastel-orange .maplibregl-popup-content.mapboxgl-popup-content {
    color: #000;
    background-color: #FFDFBA;
}

.label-service-pastel-yellow .maplibregl-popup-content.mapboxgl-popup-content {
    color: #000;
    background-color: #EFEF8E;
}

.label-service-pastel-green .maplibregl-popup-content.mapboxgl-popup-content {
    color: #000;
    background-color: #BAFFC9;
}

.label-service-pastel-blue .maplibregl-popup-content.mapboxgl-popup-content {
    color: #000;
    background-color: #BAE1FF;
}

.label-service-pastel-pink .maplibregl-popup-content.mapboxgl-popup-content {
    color: #000;
    background-color: #FFB3E6;
}

.label-service-pastel-lavender .maplibregl-popup-content.mapboxgl-popup-content {
    color: #000;
    background-color: #C9C9FF;
}

.label-service-pastel-rose .maplibregl-popup-content.mapboxgl-popup-content {
    color: #000;
    background-color: #D4A5A5;
}

.label-service-pastel-blush .maplibregl-popup-content.mapboxgl-popup-content {
    color: #000;
    background-color: #FFD1DC;
}

.label-service-pastel-mint .maplibregl-popup-content.mapboxgl-popup-content {
    color: #000;
    background-color: #B5EAD7;
}

.label-service-pastel-lilac .maplibregl-popup-content.mapboxgl-popup-content {
    color: #000;
    background-color: #F3D1F4;
}

.label-service-pastel-lemon .maplibregl-popup-content.mapboxgl-popup-content {
    color: #000;
    background-color: #F9F9A8;
}

.label-service-pastel-skyblue .maplibregl-popup-content.mapboxgl-popup-content {
    color: #000;
    background-color: #D1F7FF;
}

.label-service-pastel-violet .maplibregl-popup-content.mapboxgl-popup-content {
    color: #000;
    background-color: #E6E0FF;
}

.label-service-pastel-peach .maplibregl-popup-content.mapboxgl-popup-content {
    color: #000;
    background-color: #FDE0C5;
}

.z-index-10 {
    z-index: 10;
}

.red-error {
    color: red !important;
}

/* Loader minimapa */

#mini-loader {
    position: relative;
    width: 100%;
    height: 80vh;
    z-index: 9999;
    background: rgba(0, 0, 0, 0.5);
    display: grid;
    place-content: center;
    color: #000;
}

.cargando {
    position: relative;
    color: var(--white-speed);
    margin-top: 2em;
    letter-spacing: 0.08em;
    text-transform: uppercase
}

.mini-contenedor-loader {
    width: 180px;
    height: 30px;
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    justify-content: space-between;
    margin: 0 auto;
}

    .mini-contenedor-loader div {
        width: 30px;
        height: 30px;
        background-color: var(--white-speed);
        animation: salto 1s alternate infinite;
    }

        .mini-contenedor-loader div:nth-child(2) {
            animation-delay: 0.20s;
        }

        .mini-contenedor-loader div:nth-child(3) {
            animation-delay: 0.40s;
        }

        .mini-contenedor-loader div:nth-child(4) {
            animation-delay: 0.60s;
        }

.mini-loader {
    position: fixed;
    left: 0;
    top: 86px;
    width: 100%;
    height: calc(100vh - 86px);
    z-index: 9999;
    background: rgba(0, 0, 0, 0.5);
}

    .mini-loader::before {
        content: ""; /*"Cargando...";*/
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        color: white;
        font-size: 24px;
        font-family: Arial, sans-serif;
    }

#search {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
}

@media (min-width: 1850px) {
    #search {
        flex-wrap: nowrap;
    }
}

.no-nav-item {
    min-height: calc(100vh - 55px) !important;
    max-height: calc(100vh - 55px) !important;
}

.no-nav-item-mobile {
    min-height: 100vh !important;
    max-height: 100vh !important;
}

.card-layout {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
    width: 100%;
    transition: padding-left 0.4s linear;
}

.grid-card {
    min-width: 250px;
    flex: 1;
    display: flex;
    flex-direction: column;
    padding: 1rem !important;
    border: 1px solid #DAEBF3;
    border-radius: 6px;
}

.pop-up-assign-vehicle span {
    border: none;
    font-size: 13px;
    text-align: center;
    margin: 0px;
}

.floating-edit-controls {
    position: absolute;
    top: 12vh;
    right: 2vw;
    z-index: 801;
    display: flex;
    gap: 1rem;
}

    .floating-edit-controls .btn {
        border-radius: 12px;
        width: 50px;
        height: 50px;
        font-size: 18px;
    }

.accordion-mobile {
    min-height: 5vh;
    box-shadow: inset 0 -1px 0 rgb(0 0 0 / 13%);
}

.hyper-link {
    color: dodgerblue;
    font-style: italic;
    text-decoration: underline;
    cursor: pointer;
}

.sf-label-form:has(+ input[required]):after,
.sf-label-form:has(+ select[required]):after,
.sf-label-form:has(+ textarea[required]):after,
.sf-label-form:has(+ .rz-dropdown[required]):after,
.sf-label-form:has(+ .input-group input[required]):after,
.sf-label-form:has(+ .input-group select[required]):after,
.sf-label-form:has(+ .input-group textarea[required]):after,
.sf-label-form:has(+ .sf-required):after {
    content: " *";
    color: #d32f2f;
    font-weight: 600;
}
