

/* las reglas generales */
#demomenu { /* este es el rectángulo que contendrá todo */
  margin: 0 auto 40px;
  position: relative; /* lo posicionamos de manera relativa */
  width: 150px;  /* definimos su ancho */
  z-index: 100; /* hacemos que quede por encima de las demás etiquetas */
}
#demomenu ul { /* reseteamos las lista quitándoles posibles propeidades */
  list-style-type: none;
  margin: 0;
  padding: 0;
}
#demomenu li { list-style-type: none; }
#demomenu a { /* establecemos las propiedades de los textos delos enlaces */
  color: #00573F;
  font-family: Tahoma;
  font-size: 16px;
  text-decoration: none;
  text-shadow: 1px 1px 1px #D7BD8A;
}
#demomenu a:hover { color: #000000; }

/* esta es la  lista visible */
#demomenu .visible {
  background-color: #fefefe;
  border: 2px solid #D7BD8A;
  border-radius: 2px;
  box-shadow: 0 0 5px #D7BD8A inset;
  cursor: pointer;
  padding: 3px 0;
  text-align: center;
  /* estas son las propiedades importantes */
  display: block;
  position: absolute;
  width: 150px;
}
#demomenu ul.visible li { /* el primer item no es un enlace así que definimos sus propeidades */
  color: #00573F;
  font-family: Tahoma;
  font-size: 17px;
  text-shadow: 1px 1px 1px #00000;
}

/* cada item que permanece oculto */
#demomenu ul.visible ul li {
  background-color: #ffffff;
  border-top: 2px solid #D7BD8A;
  padding: 0 0 5px;
  /* esta transición afectará al color de fondo de cada item */
  -moz-transition: all 1s;
  -webkit-transition: all 1s;
  -o-transition: all 1s;
  transition: all 1s;
}

/* la lista oculta */
#demomenu .novisible {
  display: block;
  padding: 0 10px;
  position: relative;
  top: 10px;
  /* con esto la mantenemos oculta */
  height: 0;
  overflow: hidden;
  /* la transición hará que se anime el cambio de altura */
  -moz-transition: all 1s;
  -webkit-transition: all 1s;
  -o-transition: all 1s;
  transition: all 1s;
}

/* cambia el color de fondo */
#demomenu ul.visible ul li:hover { background-color: #CDE; }

/* cambia la altura y por lo tanto, se hace visible */
#demomenu ul.visible:hover .novisible { height: 210px; }












#demomenu1 { /* reseteamos la lista quitándole posibles propeidades */
  list-style-type: none;
  margin: 0;
  padding: 0;
}
#demomenu1 li { /* cada item de la lista */
  background-color: #445566;
  border: 2px solid #AaBbCc;
  box-shadow: 0 0 5px #FFFF inset;
  border-radius: 0 10px 10px 0;
  color: #EEE;
  font-family: Tahoma;
  font-size: 24px;
  height: 32px;
  line-height: 32px;
  list-style-type: none;
  margin: 2px 0;
  position:relative;
  width: 100px;
  text-shadow: 1px 1px 1px #000;
  /* esta es la propiedad que se animará */
  padding-left: 10px;
  /* la transición  */
  -moz-transition: all 1s;
  -webkit-transition: all 1s;
  -o-transition: all 1s;
  transition: all 1s;
}
#demomenu1 li div { /* los enlaces interiores permanece ocultos */
  left: 10px;
  position: absolute;
  top: -3px;
  width: 200px;
  overflow: hidden;
  /* esta es la propiedad que se animará */
  opacity: 0;
  /* la transición  */
  -moz-transition: all 1s;
  -webkit-transition: all 1s;
  -o-transition: all 1s;
  transition: all 1s;
}

/* al poner el cursor encima, aumentamos el padding mostrando lo que hay debajo */
#demomenu1 li:hover { padding-left: 300px; }
#demomenu1 li:hover div { opacity: 1; }

#demomenu1 li div a { /* las propeidades de los enlaces ocultos */
  width: 200px;
  color: #FFFfff;
  font-size: 14px;
  margin: 0 5px;
  text-shadow: 1px 0 1px #FFFfff;
}
#demomenu1 li div a:hover {
  overflow: visible;
  width: 200px;
  color: #FFF;
  text-shadow: 1px 0 1px #000000;

}

