@keyframes bgPosition {
  100% {
    background-position: 3rem; } }

*,
*::after,
*::before {
  margin: 0;
  padding: 0;
  box-sizing: inherit; }

html {
  font-size: 62.5%; }

body {
  box-sizing: border-box; }

::selection {
  background-color: #36cbff;
  color: #eee; }

.row {
  max-width: 114rem;
  margin: 0 auto; }
  .row:not(:last-child) {
    margin-bottom: 8rem; }
  .row::after {
    content: "";
    display: table;
    clear: both; }
  .row [class^='col-'] {
    float: left; }
    .row [class^='col-']:not(:last-child) {
      margin-right: 6rem; }
  .row .col-1-of-2 {
    width: calc((100% - 6rem) / 2); }
  .row .col-1-of-3 {
    width: calc((100% - 2 * 6rem) / 3); }
  .row .col-2-of-3 {
    width: calc(2 * ((100% - 2 * 6rem) / 3) + 6rem); }
  .row .col-1-of-4 {
    width: calc((100% - 3 * 6rem) / 4); }
  .row .col-2-of-4 {
    width: calc(2 * ((100% - 3 * 6rem) / 4) + 6rem); }
  .row .col-3-of-4 {
    width: calc(3 * ((100% - 3 * 6rem) / 4) + (2 * 6rem)); }

body {
  font-family: "Lato", sans-serif;
  font-weight: 400;
  line-height: 1.7;
  color: #777; }

.primary-heading {
  color: #fff;
  text-transform: uppercase; }
  .primary-heading--name {
    display: block;
    font-size: 6.2rem;
    font-weight: 300;
    letter-spacing: 1.3rem;
    white-space: nowrap; }
  .primary-heading--sub {
    display: block;
    font-weight: 400;
    letter-spacing: 0.5rem; }

.secondary-heading {
  width: 60%;
  font-size: 4rem;
  text-transform: uppercase;
  font-weight: 700;
  display: inline-block;
  letter-spacing: 1rem; }
  .secondary-heading--blue {
    background-image: radial-gradient(at top center, #36cbff 30%, #06729a 60%);
    -webkit-background-clip: text;
    color: transparent;
    background-position: -15rem 0;
    transition: background-position 1s linear; }
  .secondary-heading--white {
    color: #eee; }

.terciary-heading {
  width: 30rem;
  font-size: 2rem;
  font-weight: 700;
  display: inline-block;
  letter-spacing: 0.3rem; }
  .terciary-heading--blue {
    background-image: radial-gradient(at top center, #36cbff 25%, #06729a 55%);
    -webkit-background-clip: text;
    color: transparent;
    background-position: -8rem 0;
    transition: background-position 1s linear; }
  .terciary-heading--white {
    color: #eee; }

.u-center-text {
  text-align: center !important; }

.u-margin-top-big {
  margin-top: 8rem !important; }

.u-margin-bottom-xsmall {
  margin-bottom: 1rem !important; }

.u-margin-bottom-big {
  margin-bottom: 8rem !important; }

.u-padding-bottom-big {
  padding-bottom: 8rem !important; }

.about__image {
  margin: 4rem;
  width: 27rem;
  height: 27rem;
  float: left;
  -webkit-shape-outside: circle(50% at 50% 50%);
  shape-outside: circle(50% at 50% 50%);
  -webkit-clip-path: circle(50% at 50% 50%);
  clip-path: circle(50% at 50% 50%);
  position: relative;
  background-image: radial-gradient(at left top, #36cbff 25%, #06729a 55%);
  transition: 2s; }

.about__photo {
  position: absolute;
  margin: 1rem;
  width: 25rem;
  height: 25rem;
  float: left;
  -webkit-shape-outside: circle(50% at 50% 50%);
  shape-outside: circle(50% at 50% 50%);
  -webkit-clip-path: circle(50% at 50% 50%);
  clip-path: circle(50% at 50% 50%);
  transition: 2s; }

.about__text {
  font-size: 2rem;
  text-align: justify; }

.about:hover .about__text > .terciary-heading {
  background-position: 0 0; }

.about:hover .about__image {
  transform: rotate(90deg) scale(1.05); }

.about:hover .about__photo {
  transform: rotate(-90deg); }

.details__items {
  padding: 2rem;
  padding-top: 1rem; }
  .details__items:hover .details__items--icon {
    transform: scale(1.1); }
  .details__items:hover .details__items--text {
    width: 100%;
    background-image: radial-gradient(at top center, #36cbff 25%, #06729a 55%);
    -webkit-background-clip: text;
    color: transparent;
    background-position: -3rem;
    animation: bgPosition 1.5s linear 1 both; }
  .details__items--icon {
    font-size: 2rem;
    border-radius: 5px;
    background-image: linear-gradient(to right bottom, #36cbff, #06729a);
    color: transparent;
    float: left;
    transition: 1s ease-in-out; }
    .details__items--icon-social:not(:first-child) {
      margin-left: 2rem; }
  .details__items--text {
    font-size: 1.8rem;
    margin-left: 2rem; }
    .details__items--text-small {
      font-size: 1.6rem; }

.details:hover .terciary-heading {
  background-position: 0 0; }

.education {
  padding: 0 15rem;
  display: flex;
  flex-direction: column;
  align-items: center; }
  .education__group {
    margin: 3rem;
    min-width: 57rem;
    padding: 1rem;
    border-width: 2px;
    border-style: solid;
    border-image: linear-gradient(to right bottom, #06729a 15%, #36cbff 30%, #06729a 50%) 72 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    transition: transform 0.4s linear; }
    .education__group:hover {
      border-image: linear-gradient(to left bottom, #06729a 15%, #36cbff 30%, #06729a 50%) 72 1;
      transform: scale(1.05); }
    .education__group:hover .terciary-heading {
      background-position: 13rem 0; }
    .education__group:nth-child(even) {
      align-self: flex-end; }
    .education__group:nth-child(odd) {
      align-self: flex-start; }
  .education__date {
    align-self: left;
    font-size: 1.4rem; }
  .education__type {
    width: 100%;
    text-align: center; }
  .education__school {
    font-size: 2rem;
    text-decoration: none;
    color: #777; }

.skills__list {
  list-style: none;
  padding: 2rem 4rem; }

.skills__item {
  font-size: 1.8rem;
  color: #eee;
  border-radius: 3rem;
  text-align: left;
  padding: 1rem 4rem;
  position: relative;
  transition: all .6s ease-in-out; }
  .skills__item:hover {
    background-color: rgba(255, 255, 255, 0.1);
    box-shadow: inset 2px 2px 5px rgba(0, 0, 0, 0.1);
    color: #FFF; }

.skills__rating-5 {
  width: 15rem;
  height: 1rem;
  background-image: linear-gradient(to right bottom, #fff 55%, #777 99%);
  color: transparent;
  border-radius: 1rem;
  position: absolute;
  right: 4.5rem;
  top: 50%;
  transform: translateY(-50%); }
  .skills__rating-5::after {
    content: "";
    width: 7.5rem;
    height: 1rem;
    border-radius: 1rem;
    display: inline-block;
    transform: translateY(-120%);
    background-image: linear-gradient(to right bottom, #36cbff, #06729a);
    color: transparent; }

.skills__rating-6 {
  width: 15rem;
  height: 1rem;
  background-image: linear-gradient(to right bottom, #fff 55%, #777 99%);
  color: transparent;
  border-radius: 1rem;
  position: absolute;
  right: 4.5rem;
  top: 50%;
  transform: translateY(-50%); }
  .skills__rating-6::after {
    content: "";
    width: 9rem;
    height: 1rem;
    border-radius: 1rem;
    display: inline-block;
    transform: translateY(-120%);
    background-image: linear-gradient(to right bottom, #36cbff, #06729a);
    color: transparent; }

.skills__rating-7 {
  width: 15rem;
  height: 1rem;
  background-image: linear-gradient(to right bottom, #fff 55%, #777 99%);
  color: transparent;
  border-radius: 1rem;
  position: absolute;
  right: 4.5rem;
  top: 50%;
  transform: translateY(-50%); }
  .skills__rating-7::after {
    content: "";
    width: 10.5rem;
    height: 1rem;
    border-radius: 1rem;
    display: inline-block;
    transform: translateY(-120%);
    background-image: linear-gradient(to right bottom, #36cbff, #06729a);
    color: transparent; }

.skills__rating-8 {
  width: 15rem;
  height: 1rem;
  background-image: linear-gradient(to right bottom, #fff 55%, #777 99%);
  color: transparent;
  border-radius: 1rem;
  position: absolute;
  right: 4.5rem;
  top: 50%;
  transform: translateY(-50%); }
  .skills__rating-8::after {
    content: "";
    width: 12rem;
    height: 1rem;
    border-radius: 1rem;
    display: inline-block;
    transform: translateY(-120%);
    background-image: linear-gradient(to right bottom, #36cbff, #06729a);
    color: transparent; }

.skills__rating-9 {
  width: 15rem;
  height: 1rem;
  background-image: linear-gradient(to right bottom, #fff 55%, #777 99%);
  color: transparent;
  border-radius: 1rem;
  position: absolute;
  right: 4.5rem;
  top: 50%;
  transform: translateY(-50%); }
  .skills__rating-9::after {
    content: "";
    width: 13.5rem;
    height: 1rem;
    border-radius: 1rem;
    display: inline-block;
    transform: translateY(-120%);
    background-image: linear-gradient(to right bottom, #36cbff, #06729a);
    color: transparent; }

.skills__rating-10 {
  width: 15rem;
  height: 1rem;
  background-image: linear-gradient(to right bottom, #fff 55%, #777 99%);
  color: transparent;
  border-radius: 1rem;
  position: absolute;
  right: 4.5rem;
  top: 50%;
  transform: translateY(-50%); }
  .skills__rating-10::after {
    content: "";
    width: 15rem;
    height: 1rem;
    border-radius: 1rem;
    display: inline-block;
    transform: translateY(-120%);
    background-image: linear-gradient(to right bottom, #36cbff, #06729a);
    color: transparent; }

.courses {
  padding: 0 15rem;
  display: flex;
  flex-direction: column;
  align-items: center; }
  .courses__group {
    margin: 3rem;
    min-width: 57rem;
    padding: 1rem;
    border-width: 2px;
    border-style: solid;
    border-image: linear-gradient(to right bottom, #ddd 15%, #f7f7f7 30%, #ddd 50%) 72 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    transition: transform 0.4s linear; }
    .courses__group:hover {
      border-image: linear-gradient(to left bottom, #f7f7f7 15%, #ddd 30%, #f7f7f7 50%) 72 1;
      transform: scale(1.05); }
    .courses__group:hover .terciary-heading {
      background-position: 13rem 0; }
    .courses__group:nth-child(even) {
      align-self: flex-end; }
    .courses__group:nth-child(odd) {
      align-self: flex-start; }
  .courses__date {
    align-self: left;
    font-size: 1.4rem;
    color: #ddd; }
  .courses__type {
    width: 100%;
    text-align: center; }
  .courses__school {
    font-size: 2rem;
    text-decoration: none;
    color: #ddd; }
  .courses__link-icon {
    fill: #fff;
    width: 3rem;
    height: 3rem; }

.projects {
  padding: 0 5rem;
  display: flex;
  justify-content: space-around;
  flex-wrap: wrap; }
  .projects__group {
    flex: 0 0 calc(100% / 3); }
    .projects__group:hover .projects__footer {
      transform: translateY(0);
      opacity: 1;
      transition: all 2s ease 1s; }
    .projects__group:hover .projects__link {
      transform: translateY(0);
      opacity: 1;
      transition: all 2s ease 1s; }
    .projects__group:hover .projects__figure::before {
      opacity: 0;
      top: 100%;
      transition: all 2s ease, top 0.1s ease 2s; }
    .projects__group:hover .projects__text {
      opacity: 0;
      top: 200%;
      transition: all 3s ease; }
  .projects__figure {
    margin: 3rem;
    max-height: 50rem;
    overflow: hidden;
    position: relative;
    box-shadow: 0.3rem 0.3rem 1rem rgba(0, 0, 0, 0.4);
    border-radius: 5px;
    display: flex;
    flex-direction: column; }
    .projects__figure::before {
      content: "";
      position: absolute;
      top: -50%;
      left: -50%;
      height: 200%;
      width: 200%;
      border-radius: 100rem;
      background: radial-gradient(at left top, rgba(54, 203, 255, 0.9) 20%, rgba(54, 203, 255, 0.9) 30%, rgba(6, 114, 154, 0.9) 50%);
      transition: all 3s ease 0.4s, top 0.1s ease; }
  .projects__image-container {
    overflow: auto; }
  .projects__image {
    width: 100%;
    height: 90%;
    margin-bottom: 10%; }
  .projects__text {
    font-size: 1.5rem;
    text-align: justify;
    color: #f7f7f7;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: rgba(0, 0, 0, 0.6);
    width: 90%;
    height: 90%;
    padding: 2rem;
    border-radius: 5px;
    transition: all 3s ease 0.4s; }
  .projects__list {
    padding: 1rem; }
    .projects__list-items:not(:first-child) {
      padding-top: 0.5rem; }
    .projects__list-items:not(:last-child) {
      padding-bottom: 0.5rem; }
  .projects__footer {
    position: absolute;
    bottom: 0;
    left: 0;
    height: 10%;
    width: 100%;
    background: radial-gradient(at right top, rgba(54, 203, 255, 0.9), rgba(6, 114, 154, 0.9));
    display: flex;
    justify-content: center;
    align-items: center;
    opacity: 0;
    transform-origin: bottom;
    transition: all 1s ease; }
  .projects__link {
    background: rgba(0, 0, 0, 0.6);
    padding: 0.6rem 35%;
    text-decoration: none;
    color: #f7f7f7;
    font-size: 1.6rem;
    white-space: nowrap;
    border-radius: 5px;
    transform: translateY(5rem);
    opacity: 0; }

.header {
  height: 90vh;
  width: 100%;
  background: linear-gradient(to right bottom, #0292c4, #06729a);
  position: relative; }
  .header__text-box {
    position: absolute;
    top: 50%;
    left: 40%;
    transform: translate(-50%, -50%); }

.section-profile:hover div > .secondary-heading--blue {
  background-position: 10rem 0; }

.section-skills {
  height: 100%;
  width: 100%;
  background: linear-gradient(to right bottom, #0292c4, #06729a); }

.section-education:hover div > .secondary-heading--blue {
  background-position: 10rem 0; }

.section-courses {
  height: 100%;
  width: 100%;
  background: linear-gradient(to right bottom, #0292c4, #06729a); }

.section-projects:hover div > .secondary-heading--blue {
  background-position: 10rem 0; }

.section-projects:hover .projects__figure::before {
  transform: rotate(90deg); }
