h1:focus{
    outline:none;
}
a:not(.nav-link) {
    text-decoration: none
}

a:hover:not(.nav-link) {
    text-decoration: underline
}

html, body {
    font-family: "Segoe UI", SegoeUI, "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-size: 16px;
    color: #333;
}
@media (min-width: 576px) {
    html, body {
        font-size: 14px;
    }
}

.btn-list {
    cursor: pointer;
    font-size: larger;
    -webkit-text-stroke-width: 0.04rem;
}

.valid.modified:not([type=checkbox]) {
    outline: none; /*1px solid #26b050;*/
}

.form-group label {
    font-weight: 500;
    margin-bottom: 5px;
    color: #828282;
}

#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;
    }
/* 
    below styles were copied from bootstrap 4.5.0 and renamed to be compatible with blazor
    - '.validation-message' == bootstrap '.invalid-feedback'
    - '.invalid' == bootstrap '.is-invalid'
*/
.validation-message {
    display: none;
    width: 100%;
    margin-top: 0.25rem;
    font-size: 80%;
    color: #dc3545;
}

.invalid ~ .validation-message, .invalid .validation-message {
    display: block;
}

.invalid .input-group.search:focus-within {
    border: 1px solid red !important;
    box-shadow: 0 0 0 .2rem rgba(220, 53, 69, 0.25);
}
/*
    .invalid .input-group.search:focus-within input {
        box-shadow: none;
    }
    */
.input-group.search:focus-within {
    border-color: transparent;
    outline: none;
    box-shadow: none;
}

.form-control.invalid {
    border-color: #dc3545;
    padding-right: calc(1.5em + 0.75rem);
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' stroke='%23dc3545' viewBox='0 0 12 12'%3e%3ccircle cx='6' cy='6' r='4.5'/%3e%3cpath stroke-linejoin='round' d='M5.8 3.6h.4L6 6.5z'/%3e%3ccircle cx='6' cy='8.2' r='.6' fill='%23dc3545' stroke='none'/%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: right calc(0.375em + 0.1875rem) center;
    background-size: calc(0.75em + 0.375rem) calc(0.75em + 0.375rem);
}

    .form-control.invalid:focus {
        border-color: #dc3545;
        box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.25);
    }

.invalid .input-group.search .form-control, .invalid .input-group.search .input-group-text {
    border: 1px solid red;
    background-image: none;
}

textarea.form-control.invalid {
    padding-right: calc(1.5em + 0.75rem);
    background-position: top calc(0.375em + 0.1875rem) right calc(0.375em + 0.1875rem);
}

.form-check-input.invalid ~ .form-check-label {
    color: #dc3545;
}

.form-check-input.invalid ~ .validation-message {
    display: block;
}

a:hover {
    cursor: pointer
}

a:active, a:focus {
    outline: none;
    text-decoration: none;
}

th {
    font-weight: 600;
}

    th a {
        color: #023e8a;
    }

td.td-button {
    padding-top: .375rem;
    padding-bottom: .375rem;
}

#list-wrap > a.btn.btn-primary.float-right {
    margin-bottom: .5rem;
}

.list-wrap-reservas {
    position: relative;
}

.solo-activas {
    margin-top: -1rem;
    margin-bottom: 1rem;
}

@media (min-width: 992px) {
    .solo-activas {
        margin-top: -4.5rem;
        margin-bottom: 4.5rem;
    }
}
/*Others*/
.btn-forms {
    min-width: 7.25rem;
    padding-left: 1.5rem !important;
    padding-right: 1.5rem !important;
}

h5.card-header, h5.modal-title {
    font-weight: 600;
    color: #5494c5;
    line-height: 2.5rem;
}

.icon-header {
    color: #5494c5;
    width: 2.5rem;
    display: flex;
    height: 2.5rem;
    margin-right: .5rem;
    border-radius: 1.5rem;
    justify-content: center;
    align-items: center;
    font-size: 1.55rem;
}

.modal-backdrop {
    background-color: white;
}

.counter {
    padding: .25rem .5rem;
    font-size: .875rem;
    line-height: 1.5;
    display: inline-block;
    font-weight: 400;
    color: #212529;
    text-align: center;
    vertical-align: middle;
}

h6.title-tabla {
    font-weight: 600;
}
/*
select {
    padding-right: 2rem;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAaUlEQVQ4je3OsQ2CUBQF0DMCVFIZOuMQOoALyAQwgszEHFBqpQlhGhtIKAQ/hJJTvntv8thtrsJpJj/3nUlXtDj+yFJ0uPz74oY3DqNbgk+fBcnwRIQYL9xDx4MCNRrkS8eDEo+1412gLyVhDCzpLRFXAAAAAElFTkSuQmCC') !important;
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 4 5'%3E%3Cpath fill='%23333' d='M2 0L0 2h4zm0 5L0 3h4z'/%3E%3C/svg%3E");
    background-size: .75rem .75rem;
    background-repeat: no-repeat;
    background-position: right .25rem center;
}
    */
.top-row a, .top-row .btn-link {
    color: white;
}

.custom-shadow {
    box-shadow: 0 .125rem .25rem 0 rgba(0,0,0,.15)
}

.custom-shadow-vertical {
    box-shadow: .125rem 0 .25rem 0 rgba(0,0,0,.15)
}

.page-header h5 {
    width: 100%;
    text-align: left;
    color: grey;
    font-size: 1.125rem;
    padding: 0 .5rem .5rem;
    border-bottom: 1px solid silver;
    font-weight: 100;
    letter-spacing: .2rem;
}

.modified.valid.out-line-none {
    outline: none;
}

.error404page h1 {
    font-size: 160px;
}

ul.properties {
    padding-left: .5rem;
}

    ul.properties span {
        margin-right: .5rem;
        font-weight: 700;
    }

    ul.properties li {
        list-style: none;
    }

a[aria-expanded=true] .bi-collapsed::before {
    content: "\f282";
}

a[aria-expanded=false] .bi-collapsed::before {
    content: "\f284";
}

input[type="radio"]:focus, input[type="radio"]:active {
    outline: 1px dotted !important;
}

@media(min-width:768px) {
    .mb-md-6, .my-md-6 {
        margin-bottom: 3.75rem !important;
    }
}
/*Guillermo, para mejorar un poco las tablas*/
.table-hover tbody tr:hover {
    color: #212529;
    background-color: #f5f8fd;
}

.table thead th {
    vertical-align: top;
    border-bottom: 2px solid #dee2e6;
    background: #f7f7f7;
}

th a:not(.blue) {
    color: #4a4a4a !important;
}

tr .btn-list:not(.flag), tr .btn {
    visibility: hidden;
}

tr:hover .btn-list, tr:hover .btn {
    visibility: visible;
}

.w-10 {
    width: 10%;
}

.w-20 {
    width: 20%;
}

.w-30 {
    width: 30%;
}

.w-40 {
    width: 40%;
}

@media(min-width:1200px) {
    .ws-10, .ws-15, .ws-20, .ws-30, .ws-35, .ws.w-40, .ws-50, .ws-75, .ws-100 {
        text-overflow: ellipsis;
        overflow: hidden;
        white-space: nowrap;
    }

    .ws-10 {
        width: 10ch;
    }

    .ws-15 {
        width: 15ch;
    }

    .ws-20 {
        width: 20ch;
    }

    .ws-30 {
        width: 30ch;
    }

    .ws-35 {
        width: 35ch;
    }

    .ws-40 {
        width: 40ch;
    }

    .ws-50 {
        width: 50ch;
    }

    .ws-75 {
        width: 50ch;
    }

    .ws-100 {
        width: 100ch;
    }
}

@media (min-width: 1400px) {
    .container {
        max-width: 1320px;
    }
}

.remove-error-default .dropdown-toggle.form-control.invalid, .remove-error-default .collapse .form-control.invalid, .remove-error-default .collapsing .form-control.invalid {
    border-color: #ced4da;
}

    .remove-error-default .dropdown-toggle.form-control.invalid:focus, .remove-error-default .collapse .form-control.invalid:focus {
        border-color: #34a6ff;
        outline: 0;
        box-shadow: 0 0 0 .2rem rgba(0,101,179,.25);
    }

    .remove-error-default .dropdown-toggle.form-control.invalid ~ .sufix-button::after {
        content: "*";
        color: red;
        margin-left: 2.25rem;
        margin-top: .365rem;
        display: block;
    }

.remove-error-default .validation-message {
    display: block;
}

.popover-body .close {
    float: none;
    text-align: right;
    cursor: pointer;
    line-height: 1rem;
}

fieldset {
    margin-top: 1rem;
    margin-bottom: 1rem;
    border: 1px solid #ddd;
    padding: 1rem;
}

legend {
    font-size: 1.5rem;
    float: none;
    width: auto;
}

.fieldset-short {
    max-width: 600px;
    margin: auto;
    padding-right: 60px;
}

.text-lang-input {
    margin-right: -2rem;
}

.form-group.row {
    margin-bottom: .5rem;
}

@media (min-width: 1200px) {
    .fieldset-short {
        margin-left: 150px;
    }
}

.table-hover {
    --bs-table-bg: transparent;
    --bs-table-hover-bg: transparent;
    --bs-table-active-bg: transparent;
}

.modal.body-overflow-visible .modal-dialog-scrollable .modal-body {
    overflow-y: visible;
}

.form-group {
    margin-bottom: 1rem;
}

input.form-control {
    color: #495057;
}

.form-row {
    display: flex;
    flex-wrap: wrap;
    margin-right: -5px;
    margin-left: -5px;
}
.legend-check-box label {
    float: right;
    margin-right: 2rem;
    font-size: 1rem;
    line-height: 2rem;
    cursor: pointer;
}

.legend-check-box input[type="checkbox"] {
    margin-right: .25rem;
}
.form-check.check-sexo .validation-message {
    margin-left: -10.5rem;
    width: 10rem;
}
.row{
    --bs-gutter-x:30px;
}
.input-group:not(.has-validation) > :not(:last-child):not(.dropdown-toggle):not(.dropdown-menu):not(.form-floating) {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
}
.chart-google rect[stroke-opacity] {
    display:none;
}
.chart-google path[fill-opacity="0.3"], .chart-google path[stroke-opacity="0.3"]
{
    display: none;
}
a.btn:hover {
    text-decoration: none;
}
.table > :not(caption) > * > * {
    color: #333;
}
.input-group.search .form-control:focus {
    border-color: transparent;
    box-shadow: none;
}
.form-check-input{
    border:1px solid gray;
}

