@charset "utf-8";

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    outline: none;
    list-style: none;
    text-decoration: none;
}

body {
    font-family: sans-serif; 
    min-height: 100vh;
   
    display: flex;
    flex-direction: column;
    justify-content: center;
    
    background-color: #292938;
    
}


img {
    /* para que una imagen nunca sea mayor que la caja que la contiene */
    max-width: 100%;
    height: auto;
}



ul {
    list-style: none; 
}


h5 {
    max-width: 7em;
}

header a {
    text-decoration: none;
}

a {
    text-decoration: none;
    color: white;
}

header,
footer {
    background-color: black;
    padding: 0 .25em;
}

/* para limitar el ancho de los contenidos y centrarlos */
.fila {
    max-width: 70rem;
    margin: 0 auto;
    padding: .5em;
    display: flex;
    justify-content: space-between;
    text-align: left;
    padding-left: 1em;
}

.material-icons {
    background: none; padding-right: .5rem }


.VSfecha {
    position: relative;
    z-index: 0;
        
    max-width: 25rem;
    margin: 0 auto;

}

.descriparch {
    color: white;
}

.videoresponsive{
    position: relative;
    margin: 0 auto;
    height: 0;
    padding-bottom: 56,25%
    
}

.vid {
    padding: 1em 1em 0 ;
    background-color: white;
    border-radius: 1em;
    margin: 1em;
}


.fecha{
    color: darkgoldenrod;
}


/*
----------------
encabezado
----------------
*/

header .fila {
    
    /* caja flexible */
    display: flex;
    
    /* elementos colocados en los extremos del eje principal */
    justify-content: flex-start;
    
    /* elementos centrados en el eje secundario */
    align-items: center;
}

header img, header h1{
    margin-right: 1em;
}


header {
    position: fixed;
    width: 100%;
    background-color:  black;
    top: 0;
    z-index: 9999;
}


#logo {
    display: block;
    height: 2em; 
}

#usuarioicono {
    position: fixed;
    right: 0;
    margin-right: 5em;
    
    background-color: transparent;
    border: none;
    outline: none;
    color: white;
    cursor: pointer;
    height: 2.5em;
    width: 2.5em;
}

#usuarioicono i {
    color: white;
    padding: 0;
    margin: auto;
}

#llamamenu {
    background-color: transparent;
    border: none;
    outline: none;
    color: white;
    cursor: pointer;
    height: 2.5em;
    width: 2.5em;
    z-index: 9999;

    /* caja flexible */
    display: flex;
}

#llamamenu i { 
    padding: 0;
    /* centrado en la horizontal y en la vertical */
    margin: auto;
}

#llamamenu {
    position: fixed;
    right: 0;
    margin-right: 2em;
}


/* menu desplegable */

header nav {
    background-color: black;
    color: white;
    margin-top: 2.9em;
    
    position: fixed;
    right: -50vw;
    top: 0;
    height: 100vh;
    min-width: 50vw;
    transition: all .3s ease;
    z-index: 9998;
}

/*header nav:target,*/
header nav.menuvisible {
    right: 0;
    transition: all .4s ease;
    margin-top: 2.9em;
}


.usuario img {
    
    margin: 1em;
    
    text-align: center;
    border-radius: 50%;
    
    width: 25vmin;
    height: 25vmin;
    max-width: 15em;
    max-height: 15em;
    border: 2px solid black;
}

.editarfoto {
    border: none;
    color: black;
    
    background-color: #fcbd2e;
    padding: 0.7em;
    border-radius: 50%;

}


header nav a {
    display: block;
    color: rgba(255,255,255,.75);
    text-decoration: none;
    padding: 1em;
}

header ul li {
    border-bottom: 0.01em solid dimgray;
}

header nav a:hover {
    color: white;
}

/*-- submenu deportes --*/

.fa-caret-down {
    float: right;
    margin-right: 1em;
}

/*-- estilo del submenu --*/

.abresubmenu {
    color: rgba(255,255,255,.75);
    text-decoration: none;
    padding: 1em;
}

.submenu li {
    color: rgba(255,255,255,.75);
    text-decoration: none;
    padding-left: 2em;
}

.abresubmenu:hover, .submenu a:hover {
    color: white;
}

.submenu {
    display: none;
    
    background-color: black;
    
    flex-direction: column;
}



/*
----------------
contenedor principal
----------------
*/

.contenedorprincipal {
    display: flex;
    flex-direction: column;
    align-items: center;
    
    text-align: center;
    margin-top: 4.7rem;
}

/*-- articulos de noticia en landing --*/



#contenido {
    min-height: 100%;
}

article {
    padding-bottom: 2em;
    background-color: white;
    border-radius: 1em;
    flex: 1;
    margin: 1em;
}

.noticias h3 {
    margin-top: 1em;
}

article p {
    text-align: left;
    padding: 1em;
}

article a {
    color: darkgoldenrod;
}

/*-- fin articulos --*/

/*---------------------------------------*/

h1 {
    color: darkgoldenrod;
}

h2 {
    color: darkgoldenrod;
    padding: .5em;
}

h3{
    padding: 1em;
    text-align: left;
}

h6{
    font-weight: 400;
    padding-bottom: 1em;
}


.contacto {
    display: flex;
    flex-direction: column;
    align-content: center;
    
    text-align: left;
    padding: 1.5em;     
    background-color: white;
    border-radius: 1em;
    
    
    width: 100%;
    
    margin-bottom: 5em;
    
    max-width: 70rem;
    
}

iframe {
    padding-bottom: 1em;
    width: 100%;
}

.mapa > * {
    padding: 1em 0 0 0;
}




/*
----------------
pagina login
----------------
*/

.columna_principal {
    margin: 2em 0;
    max-width: 70rem;
}

/* bordes */
form {
  max-width: 40rem;
  min-height: 32rem;
  padding-bottom: 2em;
    
  background-color: white;
  border-radius: 1em;
}

/* los inputs ocupan todo el espacio disponible */
input[type=text], input[type=password],
input[type=email],
input[type=date]
{
  width: 100%;
  padding: 1em 1em;
  margin: 1em 0;

  border: 1px solid #ccc;
  box-sizing: border-box;
  border-radius: 0.3em;
}

/* estilo de botones login */

button:hover {
  opacity: 0.8;
}

.container {
  padding: 1.5em;     
  background-color: white;
  border-radius: 1em;
}

#login {
  background-color: black;
  color: white;
  padding: 1em;
  margin: 1em 0;
  border: none;
  cursor: pointer;
  width: 100%;
  border-radius: 0.3em;
}

.cuentanueva {
    text-align: center;
    background-color: #fcbd2e;
    
    max-width: 10em;
    
    border-radius: 0.3em;
    margin: auto;
    padding: 0.5em;
}

.cuentanueva a {
    font-size: 10pt;
    text-decoration: none;
    color: black;
    
    padding: 0.5em;
}

/*---------------------------------------------------------------------*/

/*-- reservas --*/

#reservas {
    padding: 2em 2.5em;
    text-align: left;
    
    margin: 5em 1em;
}

textarea {
    width: 100%;
    min-height: 8em;  
}

/*--- informacion de la cuenta del usuario ---*/

#contenidocuenta {
    display: flex;
    flex-direction: column;
    align-items: center;
    
    width: 100%;
    
    padding: 0 1em 5em 1em;
}

#menucuenta {
    background-color: black;
    color: white;
    margin: 1em 0;
    max-width: 40rem;
    
    width: 100%;
}

#menucuenta ul li {
    border-bottom: 0.01em solid dimgray;
    
    padding: 0.5em 0;
}

#menucuenta li:hover {
    background-color: dimgray;
    
    cursor: pointer;
    transition: 0.3s;
}

#menucuenta ul {
    display: flex;
    flex-direction: row;
    }
    
#menucuenta li {
        flex-basis: 15em;
    }

.infousuario {
    margin: 2em 0.5em 0.5em;
}

#infousuario div {
    border-bottom: 0.01em solid dimgray;
}

.contenedorinfo {
  width: 100%;
    
  max-width: 40rem;
  padding-bottom: 2em;
    
  background-color: white;
  border-radius: 1em;
}

.infousuario .fila > *:first-child {
    width: 30%;
    text-align: right;
}

.infousuario .fila > *:last-child {
    width: 60%;
}

.infousuario img {
    border-radius: 50%;
    margin: 1em;
    height: 15vmin;
}

/*-- recibos --*/



.recibos {
    padding: 0.5em;
    text-align: left;
    overflow-x: auto;
}

.recibos th, .recibos tr  {
    background-color: ccc;

    padding: 1em;
}

.recibos td {
    background-color: #f2f2f2;
    padding: 1em;
    width: 25%;
}


.recibos a {
    color: darkgoldenrod;
}




/*
----------------
footer
----------------
*/

footer {
    display: flex;
    flex-direction: column;
    align-items: center;
    
    text-align: center;
    color: white;
    
    padding: 1em;
    font-size: 8pt;
}

footer > * {
    max-width: 70rem;
}

footer div p{ 

    padding-bottom: .5em;
}

/*-- iconos redes sociales --*/

#redes {
    display: flex;
    align-content: center;
    justify-content: center;
    
    width: 7rem;
}

#redes i {
    padding: 0;
    margin: auto;
}

#redes > * {
    padding: 0.2em;
}

.socialico a {
    color: white;
}

.socialico {
    font-size: 17pt;
}



/*
---------------------------------
 puntos de quiebre (breakpoints)
 para el diseño responsive
---------------------------------
*/


/* reglas que se aplicarán cuando la ventana del navegador mida igual o más de 560px */
@media (min-width: 70em) {
    

    header .fila {

        justify-content: space-between;
        align-items: center;
}
    
    header nav {
        margin-top: 0;
        background-color: transparent;
        outline: none;
        
        position: relative;
        right: auto;
        top: auto;
        height: auto;
        min-width: auto;
        
        flex: 1;
    }
    
    header nav ul {
        display: flex;
        justify-content: flex-end;
    }
    
    header nav ul li {
        border-bottom: none;
    }
    
    #llamamenu {
        display: none;
    }
    
    #usuarioicono {
        position: relative;
    }
    
    .submenu {
     position: absolute;    
        
     flex-direction: row;   
     margin-top: 3.5em;
    }
    
    .submenu li {
        padding: 0.5em;
    }
    
}

@media (min-width: 35em) {
    
.noticias, .archivo {
    display: flex;
    flex-direction: row; 
    flex-wrap: wrap;
    justify-content: space-around;
   }

.noticias {
    max-width: 70rem;
    }
    
.noticias article {
    display: flex;
    flex-direction: column;
    max-width: 50rem;
    }
    
.vid {
     display: flex;
    flex-direction: column;
    }
    

   
}

/*
----------------
FIN DE LOS MEDIA QUERIES
----------------
*/





