html {
  font-family: monospace;
  font-size: 12pt;
}

body {
  height: 100%;
  background-image: url(/img/lineal.svg);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: top left;
  background-attachment: fixed;
  opacity: 0;
  transition: opacity 2s;
}

a:before {
  content: "⋯ ";
}

a {
  text-decoration: none;
  color: unset;
  white-space: nowrap;
}

a.dotless:before {
  content: "";
}

a:hover {
  font-weight: bold;
}

div.logoheader {
  width: 80%;
  min-width: 80%;
  margin-left: 20%;
  padding-top: 5rem;
  position: fixed;
  top: 0px;
  left: 0px;
  background-color: #fff;
  opacity: 0.8;
}

body.subpage div.logoheader {
  width: 20%;
  min-width: 20%;
  right: 20px;
  left: unset;
}

body.subpage div.row.firstrow {
  min-height: 50px;
}

@media (max-width: 1000px) {
  body.subpage div.logoheader {
    width: 50%;
    min-width: 50%;
  }

  
}

div.logoheader img {
  opacity: 1;
  width: 98%;
}

@media (max-width: 670px) {
  div.logoheader {
    max-width: 70%;
    margin-left: 30%;
  }

  div.logoheader img {
    width: 80%;
  }
}

div.row {
  max-width: 70rem;
  width: 80%;
  margin-left: 20%;
  margin-top: 5rem;
}

div.row.row1 {
  margin-top: 30rem;
}

div.flex {
  display: flex;
  justify-content: space-between
}

div.column {
  width: 45%;
  min-width: 20rem;
  display: inline-block;
  vertical-align: top;
}

div.column {
  margin-right: 2rem;
}

div.column:last-child {
  margin-right: unset;
}

div.bottombar {
  background-color: #9E244A;
  color: #fff;
  width: 80%;
  position: fixed;
  bottom: 0px;
  right: 0px;
  margin-top: 10px;
  margin-bottom: 10px;
  padding-left: 10px;
  display: flex;
  align-items: center;
  height: 25px;
}

div.row.row1 {
  margin-top: 40rem;
}

@media (max-width: 1700px) {
  div.row.row1 {
    margin-top: 35rem;
  }
}

@media (max-width: 900px) {
  div.row.row1 {
    margin-top: 20rem;
  }
}

@media (max-width: 800px) {
  div.row.row1 {
    margin-top: 18rem;
  }

  div.row {
    margin-top: 2rem;
    width: 70%;
    margin-left: 30%;
  }
}

@media (max-width: 500px) {
  html {
    font-size: 10pt;
  }

  div.logoheader {
    padding-top: 1rem;
  }

  div.row.row1 {
    margin-top: 10rem;
  }

  div.row {
    margin-top: 2rem;
    width: 70%;
    margin-left: 30%;
  }

  div.column {
    width: 95%;
    min-width: unset;
  }

  div.bottombar {
    margin-bottom: 5px;
    height: 12px;
  }
}

table.cv tr {
  vertical-align: top;
}

table.cv td {
  padding-bottom: 20px;
  padding-right: 20px;
}

table.cv td:first-child {
  text-align: right;
  font-weight: bold;
  width: 8rem;
  max-width: 8rem;
}

table.cv td:nth-child(2) {
  width: 50%;
}

table.cv td div {
  position: relative;
}

span.ibox {
  font-family: sans-serif;
  font-weight: bold;
  font-size: 80%;
  display: inline-block;
  border-radius: 100%;
  background-color: #000;
  color: #fff;
  width: 0.6rem;
  height: 0.6rem;
  padding: 2px;
  text-align: center;
  line-height: 0.75;
  position: absolute;
  top: -3px;
  cursor: pointer;
}

span.ibsp {
  width: 1rem;
}

div#ibox {
  display: none;
  position: absolute;
  background-color: #eee;
  border: 1px solid #ccc;
  z-index: 999;
  padding: 10px;
  border-radius: 10px;
  margin-right: 10px;
}

div#ibox.active {
  display: block;
}

div#ibox div.iboxcloser {
  position: absolute;
  top: 0px;
  right: 10px;
  cursor: pointer;
  font-size: 150%;
}

div#ibox p {
  margin-top: 0px;
  margin-bottom: 0px;
}