main {
    overflow: visible;
}
header {
    margin-bottom: 0;
}

#divCabeceraReserva {
    position: -webkit-sticky;
    position: sticky;
    z-index: 9;
    top: 0;
}
.stickyHeader-on #divCabeceraReserva {
    top: 20rem;
}
#divCabeceraReserva nav {
    background-color: #f4f3f3;  
    line-height: 1.2;
}
#divCabeceraReserva nav > div {
    display: -webkit-flex;
    display: flex;
}
#divCabeceraReserva nav > div > div + div {
    position: relative;
}
#divCabeceraReserva nav > div > div + div:before {   
    position: absolute;
}
#divCabeceraReserva nav .nav-tit {
    color: #4a4a4a;    
    font-weight: bold;
    line-height: 1.0;
    text-transform: uppercase;
}
#divCabeceraReserva nav .nav-tit + p {
    font-weight: bold;
}
#divCabeceraReserva nav .nav-precio {
    color: var(--corp);
    font-weight: bold;
    text-align: right;
}
#reserva {
    padding-top: 3.75rem;
    font-size: 3.5rem;
}
.section-tit {
    margin-bottom: 0;
    color: #f4f3f3;
    font-weight: 600;
    line-height: 1.0;
    text-align: center;
    text-transform: uppercase;
}
.section-sub {
    font-family: 'Libre Baskerville', serif;
    font-style: italic;
    font-weight: normal;
    line-height: 1.0;
    text-align: center;
    position: relative;        
}
.section-sub:after {
    content: '';
    width: 17.5rem;
    height: 0.5rem;
    margin: 5rem auto 0;
    background-color: black;
    display: block;
}
#reserva #calendario {
    max-width: 100rem;
    margin: 5rem auto 7.5rem;
    text-align: center;
}
#reserva #calendario table {
    width: 100%;
    text-transform: uppercase;
    table-layout: fixed;
}
#reserva #calendario .btn-calend {
    width: 100%;
    height: 8rem;
    background-image: url('../../images/iconos/angle-left-black.svg');
    background-size: cover;
    background-position: center center;
    display: block;
}
#reserva #calendario .btn-calend-right {
    transform: rotate(180deg);
}
#reserva #calendario thead th {
    background-color: #f4f3f3;
    font-size: 4rem;
    font-weight: bold;
    line-height: 1.0;
    letter-spacing: 0.1rem;
    text-transform: uppercase;
}
#reserva #calendario thead th:first-child {
    text-align: left;
}
#reserva #calendario thead th:last-child {
    text-align: right;
}
#reserva #calendario .dias th {
    font-size: 3.5rem;
    font-weight: bold;
    line-height: 1.0;
    color: var(--corp);
}
#reserva #calendario .dias th:last-child {
    color: #c10230;
}
#reserva #calendario tr th,
#reserva #calendario tr td {
    padding: 2rem 0;
    text-align: center;
    vertical-align: middle;
}
#reserva #calendario tr th {
    font-weight: 400;
    text-align: center;
}
#reserva #calendario tr td {
    color: #e6e6e6;
    font-size: 4rem;
}
#reserva #calendario tr td.activo {
    padding: 0;
    color: black;
}
#reserva #calendario tr td.activo span {
    border: 0.25rem solid transparent;
    border-radius: 1.25rem;
    display: inline-block;
}
#reserva #calendario tr td.hoy span {
    background-color: transparent;
    border-color: black;    
    color: black;
}
#reserva #calendario tr td.completo span {
    border-color: var(--corp);
    background-color: var(--corp);
    color: white;
}
#reserva #calendario tr td.hoy.completo span {
    border-color: black;
    background-color: var(--corp);
    color: white;
}
#reserva #calendario tr td.seleccionada span,
#reserva #calendario tr td.hoy.seleccionada span,
#reserva #calendario tr td.hoy.completo.seleccionada span{
    border-color: black;
    background-color: black;
    color: white;
}

#reserva #eventos .eventos-tit {
    margin-bottom: 3.75rem;    
    font-weight: bold;
    text-transform: uppercase;
}

#reserva #eventos .evento {    
    border: 0.25rem solid black; 
    font-weight: 600;
    text-transform: uppercase;
    line-height: 1.0;
    text-align: center;
}
#reserva #eventos .evento {
    cursor: not-allowed;
}
#reserva #eventos .evento-act {
    cursor: pointer;
}
#reserva #eventos .evento-sel,
#reserva #eventos .evento-act:hover {
    background-color: black;
    color: white;
}
#reserva #eventos .evento .evento-tit {
    padding-bottom: 1rem;
    margin-bottom: 1rem;
    border-bottom: 0.25rem solid black;
    font-weight: bold;
}
#reserva #eventos .evento-sel .evento-tit,
#reserva #eventos .evento-act:hover .evento-tit {
    border-color: white;
}
#reserva #eventos .evento .evento-ko {
    color: var(--corp);
}
#reserva #eventos .evento .evento-ko {
    color: var(--corp);
}
#reserva #eventos #leyenda > div {
    font-weight: 600;
    line-height: 1.2;
    letter-spacing: 0.2rem;
    text-transform: uppercase;
    position: relative;
}
#reserva #eventos #leyenda > div:before {
    content: '';
    border-radius: 0.5rem;
    border: 0.25rem solid transparent;
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
}
#reserva #eventos #leyenda .leyenda-completa:before {
    border-color: var(--corp);  
    background-color: var(--corp);    
}
#reserva #eventos #leyenda .leyenda-sinvisita:before {
    border-color: #d8d8d8; 
    background-color: #d8d8d8;
}
#reserva #eventos #leyenda .leyenda-seleccionada:before {
    border-color: black; 
    background-color: black;
}
#reserva #eventos #leyenda .leyenda-actual:before {
    border-color: black; 
    background-color: transparent;
}

#reserva #formEditarReserva .section-sub {
    margin-bottom: 9.5rem;
}
#reserva #formEditarReserva .form-titBanda {
    padding: 1rem 2.5rem;
    margin-bottom: 4rem;
    background-color: #f4f3f3;
    font-size: 3.5rem;
    font-weight: bold;
    text-transform: uppercase;
    letter-spacing: 0.5rem;
    line-height: 1.0;
}
#reserva #formEditarReserva .form-titBanda span {
    margin-right: 5rem;
    display: inline-block;
}
#reserva #formEditarReserva .dua-radio,
#formPrevisualizarReserva .dua-radio {
    margin: 1.25rem 0;
}
#reserva #formEditarReserva .dua-radio input {
    width: 3rem;
    height: 3rem;
}
#reserva #formEditarReserva .dua-radio label,
#formPrevisualizarReserva .dua-radio label {
    font-size: 3.5rem;
}
#reserva #formEditarReserva .form-radioVino {
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: flex-end;
    justify-content: flex-end;
    -webkit-aling-items: center;
    aling-items: center;
}
#reserva #formEditarReserva .form-radioVino > label {
    top: 50%;
    transform: translateY(-50%);
}
#reserva #formEditarReserva .form-radioVino .radio + .radio {
    /*margin-top: 0.5rem;*/
    margin-left: 6.5rem;
}
#reserva #formEditarReserva .form-checkboxOld + .form-checkboxOld {
    margin-top: -3rem;
}
#reserva #formEditarReserva .pedido-nota {
    padding-left: 6.75rem;    
    margin-top: 2.5rem;   
    font-weight: 600;
    position: relative;
}
#reserva #formEditarReserva .pedido-nota,
#reserva #formEditarReserva .pedido-nota small {
    font-size: 2.75rem; 
}
#reserva #formEditarReserva .pedido-nota:before {
    content: '';
    width: 5rem;
    height: 5rem;
    background-image: url('../../images/iconos/alert.svg');
    background-size: contain;
    background-position: left center;
    background-repeat: no-repeat;
    font-size: 5rem;
    line-height: 1.0;
    position: absolute;
    left: 0;
    top: 0;
}
#reserva #formEditarReserva .pedido-nota .alert-danger {
    padding: 0;
    border: none;
    background-color: transparent;
    color: var(--corp);
}
#reserva #formEditarReserva * + p small {
    margin-top: -2.5rem;
    display: block;
}
#reserva #formEditarReserva .flex-envio {
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: space-between;
    justify-content: space-between;
/*    -webkit-align-items: center;
    align-items: center;*/
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
}
#reserva #formEditarReserva .flex-envio > * {
    margin-top: 2.5rem;
}
#formPrevisualizarReserva .table {
    padding-bottom: 7.5rem;
    border-bottom: 0.25rem solid #f4f3f3;
}
#formPrevisualizarReserva .table tr th,
#formPrevisualizarReserva .table tr td {
    width: 50%;
    border: 0;
    line-height: 1.2;
    vertical-align: middle;
}
#formPrevisualizarReserva .table tr th {
    font-weight: 600;
    letter-spacing: 0.25rem;
    text-transform: uppercase;
}
#formPrevisualizarReserva .table tr td {
    font-weight: bold;
}
#formPrevisualizarReserva .table tr:nth-of-type(odd) th,
#formPrevisualizarReserva .table tr:nth-of-type(odd) td {
    background-color: #f4f3f3;
}
#formPrevisualizarReserva .table tr.tr-precio th {
    font-size: 4rem;
}
#formPrevisualizarReserva .table tr.tr-precio td {
    color: var(--corp);
    font-size: 6rem;
}
#formPrevisualizarReserva .section-titBanda {
    background-color: #f4f3f3;
    font-weight: bold;
    line-height: 1.2;
    letter-spacing: 0.25rem;
    text-transform: uppercase;
}
#formPrevisualizarReserva .modal-btns {
    display: -webkit-flex;
    display: flex;
}

@media (min-width: 768px) {
    #divCabeceraReserva nav {
        padding: 3.75rem;
        font-size: 3.5rem;
    }
    #divCabeceraReserva nav > div {
        width: 284.5rem;
        margin-left: auto;
        margin-right: auto;   
        -webkit-justify-content: space-between;
        justify-content: space-between;
    }    
    #divCabeceraReserva nav > div > div + div:before {
        content: '';
        width: 22rem;
        height: 0.5rem;
        background-color: #4a4a4a;
        right: calc(100% + 20rem);
        top: 1.5rem;
    }
    #divCabeceraReserva nav .nav-tit {
        margin-bottom: 2rem;
        letter-spacing: 0.2rem;
    }
    #divCabeceraReserva nav p {
        margin-bottom: 2rem;
    }
    #divCabeceraReserva nav .nav-precio {
        font-size: 7rem;
    }
    #reserva {    
        padding-bottom: 25rem;
    }
    .section-tit {
        margin-top: 10rem;       
        font-size: 15.5rem;
    }
    .section-sub {
        margin-top: -5rem;    
        font-size: 5rem;
        letter-spacing: 0.75rem;
    }
    #reserva #calendario thead th:nth-child(2) {
        font-size: 4.5rem;
    }
    #reserva #calendario tr td.activo span {
        width: 12rem;
        height: 12rem;
        line-height: 11.5rem;
    }
    #reserva #eventos {
        padding-top: 6.5rem;
        border-top: 0.25rem solid #d8d8d8;
    }
    #reserva #eventos .eventos-tit {       
        font-size: 4rem;        
        letter-spacing: 0.25rem;
        text-align: center;
    }
    #reserva #eventos #eventos-listado {
        margin-left: -2.5rem;
        margin-right: -2.5rem;
        display: -webkit-flex;
        display: flex;
        -webkit-justify-content: center;
        justify-content: center;
    }
    #reserva #eventos .evento {
        margin: 0 2.5rem;
    }
    #reserva #eventos .evento {
        padding: 2.5rem;   
        font-size: 3rem;       
        letter-spacing: 0.5rem;
    }
    #reserva #eventos #leyenda {
        margin-top: 8.5rem;
        display: -webkit-flex;
        display: flex;
        -webkit-justify-content: center;
        justify-content: center;
    }
    #reserva #eventos #leyenda > div {
        padding-left: 7.5rem;
        font-size: 2.5rem;
    }
    #reserva #eventos #leyenda > div + div {
        margin-left: 12rem;
    }
    #reserva #eventos #leyenda > div:before {    
        width: 4.25rem;
        height: 4.25rem;
    }
    #reserva #formEditarReserva {
        width: 180.75rem;
        margin: 50rem auto 0;    
    }
    #reserva #formEditarReserva .form-cont {
        padding: 0 12rem 10rem;
    }
    #formPrevisualizarReserva .table tr th,
    #formPrevisualizarReserva .table tr td {    
        padding: 2rem 10rem;
    }
    #formPrevisualizarReserva .table tr th {
        font-size: 3rem;
    }
    #formPrevisualizarReserva .table tr td {
        font-size: 3.5rem;
    }
    #formPrevisualizarReserva .section-titBanda {
        padding: 0.5rem 10rem;
        font-size: 3.5rem;
    }
    #formPrevisualizarReserva  .form-radioOld {
        margin-left: 10rem;
    }
    #formPrevisualizarReserva .modal-btns {
        -webkit-justify-content: space-between;
        justify-content: space-between;
    }
    #formPrevisualizarReserva .modal-btns {
        margin-top: 11rem;
    }
    #formPrevisualizarReserva .modal-btns > * {
        width: 40rem;
    }
}

@media (max-width: 767px) {  
    #divCabeceraReserva nav {        
        padding: 3.75rem;        
        font-size: 3rem;
    }
    #divCabeceraReserva nav > div {
        -webkit-align-items: center;
        align-items: center;
    }
    #divCabeceraReserva nav > div > div + div {
        padding-left: 2rem;
    }
    #divCabeceraReserva nav > div > div + div:before {
        content: '/';
        color: #d8d8d8;
        font-size: 3rem;
        position: absolute;
        left: 0.5rem;
        top: 0;
    }
    #divCabeceraReserva nav > div > div:last-of-type:before {
        display: none;
    }
    #divCabeceraReserva nav .nav-tit {  
        color: #d8d8d8;
        letter-spacing: 0.1rem;
    }
    #divCabeceraReserva nav .text-act .nav-tit,
    #divCabeceraReserva nav > div > .text-act:before {
        color: black;
    }    
    #divCabeceraReserva nav p {
        margin-bottom: 0;
    }   
    #divCabeceraReserva nav .nav-precio {
        padding-left: 2.5rem;
        margin-bottom: 0.25rem;
        font-size: 3.5rem;
    }
    #reserva {    
        padding-bottom: 10rem;
    }
    .section-tit {
        margin-top: 2.5rem;       
        font-size: 12rem;
    }
    .section-sub {
        margin-top: -3rem;    
        font-size: 4rem;
        letter-spacing: 0.5rem;
    }
    #reserva #calendario tr td.activo span {
        width: 9.5rem;
        height: 9.5rem;
        line-height: 9rem;
    }
    #reserva #eventos .eventos-tit {       
        font-size: 3rem;        
        letter-spacing: 0.2rem;
    }
    #reserva #eventos {
        position: relative;
    }
    #reserva #eventos #eventos-listado {        
        padding-left: 8rem;
    }
    #reserva #eventos .evento {
        width: 26rem;
        padding: 2rem;   
        font-size: 2.5rem;       
        letter-spacing: 0.2rem;
    }
    #reserva #eventos .evento + .evento {
        margin-top: 1.25rem;
    }
    #reserva #eventos #leyenda {
        position: absolute;
        left: 40rem;
        top: 8rem;
    }
    #reserva #eventos #leyenda > div {
        padding-left: 6rem;
        font-size: 2rem;
    }
    #reserva #eventos #leyenda > div + div {
        margin-top: 5rem;
    }
    #reserva #eventos #leyenda > div:before {    
        width: 3.5rem;
        height: 3.5rem;
    }
    #reserva #formEditarReserva {     
        margin-top: 10rem;    
    }
    #reserva #formEditarReserva .form-cont {
        padding: 0 1.25rem 5rem;
    }
    #formPrevisualizarReserva .table tr th,
    #formPrevisualizarReserva .table tr td {    
        padding: 1rem 2.5rem;
    }
    #formPrevisualizarReserva .table tr th {
        font-size: 2.5rem;
    }
    #formPrevisualizarReserva .table tr td {
        font-size: 3rem;
    }
    #formPrevisualizarReserva .section-titBanda {
        padding: 0.5rem 2.5rem;
        font-size: 3.5rem;
    }
    #formPrevisualizarReserva  .form-radioOld {
        margin-left: 2.5rem;
    }    
    #formPrevisualizarReserva .modal-btns {
        margin: 5rem -1.25rem 0;
    }
    #formPrevisualizarReserva .modal-btns > * {
        width: 50%;
        margin-left: 1.25rem;
        margin-right: 1.25rem;        
    }
}
