* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html, body {
    font-family: 'Heebo', sans-serif;
    font-size: 16px;
}

/* body::before {
    content: '';
    position: fixed;
    bottom: -20%;
    right: 0;
    width: 120%;
    height: 120%;
    background: linear-gradient(rgb(var(--red-color)), rgb(var(--pink-color)));
    clip-path: circle(30% at right 70%);
}

body::after {
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(45deg, rgb(var(--blue-color)), rgb(var(--light-blue-color)));
    clip-path: circle(20% at 10% 10%);
    z-index: -1;
} */

.c-background {
    position: fixed;
    top: 0;
    right: 0;
    height: 100dvh;
    width: 100%;
    background-color: rgba(var(--background-float-color), .5);
    opacity: 0;
    pointer-events: none;
    transition: .3s;
    z-index: 49;
}
.c-background--active {
    opacity: 1;
    pointer-events: all;
}

.c-app {
    position: relative;
    display: flex;
    flex-direction: column;
    height: 100dvh;
    width: 100%;
    font-size: 1rem;
    background-color: rgb(var(--secondary-color), .9);
    color: rgb(var(--text-color));
    scroll-behavior: smooth;
    transition: .1s;
    overflow: hidden;
    overflow-y: auto;
    cursor: default;
    /* z-index: 1; */
}

.c-app::before {
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    background-image: url(data:image/png;base64,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);
    opacity: .5;
    pointer-events: none;
}

.c-scroll-top {
    position: fixed;
    bottom: 1rem;
    right: 1rem;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    height: 3rem;
    width: 3rem;
    border-radius: 50%;
    transform: scale(0);
    transition: transform .3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    background-color: rgb(var(--accent-color), .9);
    pointer-events: none;
    color: #fff;
    box-shadow: 0 2px 1px -1px #0003, 0 1px 1px #00000024, 0 1px 3px #0000001f;
    cursor: pointer;
    z-index: 5;
}
.c-scroll-top:hover {
    background-color: rgb(var(--accent-color), 1);
}

.c-scroll-top--visible {
    transform: scale(1);
    pointer-events: all;
}

.c-scroll-top__img {
    width: 100%;
}

/* ========== HEADER ========== */

.c-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 40px;
    width: 100%;
}

.c-header__info {
    display: flex;
    align-items: center;
    justify-content: space-between;
    max-width: 1200px;
    margin: 0 auto;
    width: 100%;
}

.c-header__title {
    position: relative;
    font-family: 'Fredoka One', cursive;
    display: flex;
    align-items: center;
    color: rgb(var(--title-color));
    font-size: 2.5em;
    text-transform: uppercase;
}

/* ========== CONTENT ========== */

.c-content {
    display: flex;
    flex-wrap: wrap;
    width: 100%;
    z-index: 1;
}

.c-section {
    display: flex;
    min-height: 100dvh;
    width: 100%;
    overflow: hidden;
    padding: 2rem;
}

.c-section--introduction {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    width: 100%;
}

.c-content__introduction-info {
    font-size: 1.5em;
}

.c-content__profile {
    position: relative;
}

.c-content__profile-img {
    height: 20rem;
    width: 20rem;
    border-radius: 50%;
    /* background: linear-gradient(45deg, transparent, transparent, rgb(var(--pink-color), 1), rgb(var(--purple-color), 1), rgb(var(--blue-color), 1), rgb(var(--blue-marine-color), 1)); */
    padding: .15rem;
    padding-bottom: .3rem;
    padding-left: .3rem;
    margin: 40px 0;
    object-fit: cover;
    background-position-y: center;
}

.c-connections {
    position: absolute;
    bottom: 2rem;
    right: 2.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    color: rgb(var(--accent-color));
}

.c-connections__item {
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    width: 3rem;
    height: 3rem;
    font-size: 1.5rem;
    margin-right: -.8rem;
    box-shadow: -3px 3px 5px rgba(0, 0, 0, 0.15);
    background-color: rgb(var(--accent-color), 1);
    color: #fff;
    transition: transform .2s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.c-connections__item:hover {
    box-shadow: -3px 3px 10px rgba(0, 0, 0, 0.3);
    transform: scale(1.1);
    z-index: 1;
}

.c-content__buttons {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
}

/* CONTAINER */

.c-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
}

.c-container__title {
    text-align: center;
    font-weight: 500;
    font-size: 1.3em;
    margin-bottom: 1.5rem;
}

.c-container__content {
    position: relative;
    display: flex;
    width: 100%;
}

.c-container__info {
    display: flex;
    flex-direction: column;
    height: 100%;
    padding: 40px;
    font-size: 1.1em;
    font-weight: 500;
}

.c-container__item {
    margin-bottom: 1,5rem;
    color: rgb(var(--text-color--light));
}
.c-container__item__title {
    color: rgb(var(--title-color));
    font-weight: 500;
}

.c-container__item li {
    display: flex;
    align-items: center;
}

.c-container__item li > div {
    min-height: .7rem;
    min-width: .7rem;
    border-radius: 50%;
    margin-right: 10px;
}

.c-form {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 100%;
    text-align: center;
    z-index: 1;
}

.c-form__img {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    min-width: 100%;
    width: 50rem;
    opacity: .1;
    pointer-events: none;
}

.c-form__item {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    margin-top: 2rem;
    width: 40%;
}

.c-form__item__label {
    position: absolute;
    font-weight: 500;
    transition: top .2s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    pointer-events: none;
}

.c-form__item__icon {
    position: absolute;
    top: -1rem;
    display: flex;
    align-items: center;
    margin-right: 10px;
    border-radius: 50%;
    font-size: .875em;
    background-color: rgb(var(--secondary-color), .9);
    color: rgb(var(--text-color--light));
    padding: 8px 10px;
    pointer-events: none;
    z-index: 2;
}

.c-form__item__input,
.c-form__item__textarea {
    position: relative;
    display: flex;
    align-items: center;
    font-size: .9rem;
    padding: 1rem 2rem;
    background-color: rgb(var(--secondary-color));
    box-shadow: var(--field-shadow);
    color: rgb(var(--text-color));
    border-radius: 3rem;
    width: 100%;
    z-index: 1;
}

.c-form__item__textarea {
    /* padding: 1rem; */
    min-height: 10em;
    resize: none;
    border-radius: .5rem;
}

.item-focus-effect:focus + .c-form__item__label,
.item-focus-effect:valid + .c-form__item__label {
    top: 0;
    background-color: rgb(var(--secondary-color), .7);
    border-radius: 3rem;
}

.c-btn-send {
    position: absolute;
    bottom: -2.5rem;
    right: 1rem;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    padding: 1rem;
    padding-top: 3rem;
    background-color: rgb(var(--accent-color), .9);
    box-shadow: var(--field-shadow);
    color: rgb(var(--title-color--inverted));
    transition: bottom .2s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    border-radius: .5rem;
}
.c-btn-send:hover {
    filter: brightness(1.2);
    bottom: -3.5rem;
}

.c-btn-send__text {
    border-radius: 3rem .3rem .5rem 3rem;
    margin-right: .3rem;
}
.c-btn-send__icon {
    padding: 1rem;
    border-radius: .5rem 3rem 3rem .5rem;
    background-color: rgb(var(--accent-color), .5);
    transition: .2s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.c-btn-send:hover .c-btn-send__icon {
    transform: scale(.9);
    background-color: rgb(var(--accent-color), .9);
}

/* GITHUB */

.c-github {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    padding: 40px;
    margin-bottom: 1rem;
    border-left: solid 1px rgb(var(--border-color));
}
.c-github__skills {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    margin-bottom: .5rem;
}

.c-github__graphics__item {
    width: 100%;
}

/* DECORATIONS */

.c-clouds-group {
    position: absolute;
    top: 0;
    left: 0;
    pointer-events: none;
}

.c-clouds-group__item {
    position: absolute;
    filter: drop-shadow(0px 3px 3px rgba(0, 0, 0, .05));
    width: 100%;
    opacity: .1;
}

.c-clouds-group__item__img {
    width: 100%;
}

.c-clouds-group__item--1 {
    top: 0rem;
    left: 0rem;
    width: 5rem;
    animation: clouds 10s cubic-bezier(0.215, 0.610, 0.355, 1) infinite alternate;
    z-index: 1;
}

.c-clouds-group__item--2 {
    top: -2rem;
    left: 1rem;
    width: 10rem;
    opacity: .6;
    animation: clouds 5s cubic-bezier(0.455, 0.03, 0.515, 0.955) infinite alternate;
    z-index: 2;
}

.c-clouds-group__item--3 {
    top: -3rem;
    left: 5rem;
    width: 3rem;
    opacity: .7;
    animation: clouds 7s linear infinite alternate;
    z-index: -1;
}
.c-clouds-group__item--4 {
    top: -1rem;
    left: 10rem;
    width: 5rem;
    opacity: .4;
    animation: clouds 7s cubic-bezier(0.455, 0.03, 0.515, 0.455) infinite alternate;
    z-index: -1;
}

.c-rain-group {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    z-index: -1;
}

.c-rain__drop {
    position: absolute;
    top: 3rem;
    width: 2%;
    filter: drop-shadow(0px 3px 3px rgba(0, 0, 0, .05));
    opacity: .1;
}

.c-rain__drop--1 {
    left: 5%;
    opacity: .1;
    width: 4%;
    animation: rain 1s cubic-bezier(0.215, 0.610, 0.355, 1) infinite;
}
.c-rain__drop--2 {
    top: 5rem;
    left: 50%;
    width: 3%;
    animation: rain 3s cubic-bezier(0.455, 0.03, 0.515, 0.955) infinite;
}
.c-rain__drop--3 {
    top: 4rem;
    left: 30%;
    width: 2%;
    animation: rain .5s linear infinite;
}
.c-rain__drop--4 {
    top: 2rem;
    left: 20%;
    width: 1%;
    animation: rain 3s cubic-bezier(0.25, 0.46, 0.45, 0.94) infinite;
}

.c-clouds-group--form-bottom-position {
    top: auto;
    left: auto;
    right: 5rem;
    bottom: 5rem;
}

/* ========== MEDIA ========== */

@media (max-width: 1000px) {

    .c-nav {
        display: none;
    }

    .c-sidebar-btn {
        display: block;
    }
}

@media (max-width: 768px) {

    .c-app {
        font-size: .8rem;
    }

    .c-header {
        padding: 20px;
    }

    .c-container {
        padding: 0;
    }
    .c-section {
        padding: 1rem;
    }

    .c-github {
        padding: 0rem;
    }

    .c-content__profile-img {
        height: 12.5rem;
        width: 12.5rem;
    }

    .c-form__item {
        width: 100%;
    }

    /* .c-github__graphics {
        grid-template-columns: 1fr;
    } */
}