@import url("https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Rambla:ital,wght@0,400;0,700;1,400;1,700&display=swap");

:root {
    --border: 240 3.7% 15.9%;
    --background_special: linear-gradient(
        to right,
        rgb(46, 179, 168),
        rgb(113, 107, 215)
    );
    --background_cards: #1f2937;
    --text-color: #f3f4f6;
    --text-color-minicard_one: #2cceba;
    --text-color-minicard_two: #2ccfbb;
    --minicard_one: #122b39;
    --minicard_two: #153c48;
    --color_icons: #ffffffc2;
}

html {
    scroll-behavior: smooth;
    background-color: #0f172a;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100%25'%3E%3Cdefs%3E%3ClinearGradient id='a' gradientUnits='userSpaceOnUse' x1='0' x2='0' y1='0' y2='100%25' gradientTransform='rotate(0,683,316)'%3E%3Cstop offset='0' stop-color='%230F172A'/%3E%3Cstop offset='1' stop-color='%230F172A'/%3E%3C/linearGradient%3E%3Cpattern patternUnits='userSpaceOnUse' id='b' width='452' height='376.7' x='0' y='0' viewBox='0 0 1080 900'%3E%3Cg fill-opacity='0.01'%3E%3Cpolygon fill='%23444' points='90 150 0 300 180 300'/%3E%3Cpolygon points='90 150 180 0 0 0'/%3E%3Cpolygon fill='%23AAA' points='270 150 360 0 180 0'/%3E%3Cpolygon fill='%23DDD' points='450 150 360 300 540 300'/%3E%3Cpolygon fill='%23999' points='450 150 540 0 360 0'/%3E%3Cpolygon points='630 150 540 300 720 300'/%3E%3Cpolygon fill='%23DDD' points='630 150 720 0 540 0'/%3E%3Cpolygon fill='%23444' points='810 150 720 300 900 300'/%3E%3Cpolygon fill='%23FFF' points='810 150 900 0 720 0'/%3E%3Cpolygon fill='%23DDD' points='990 150 900 300 1080 300'/%3E%3Cpolygon fill='%23444' points='990 150 1080 0 900 0'/%3E%3Cpolygon fill='%23DDD' points='90 450 0 600 180 600'/%3E%3Cpolygon points='90 450 180 300 0 300'/%3E%3Cpolygon fill='%23666' points='270 450 180 600 360 600'/%3E%3Cpolygon fill='%23AAA' points='270 450 360 300 180 300'/%3E%3Cpolygon fill='%23DDD' points='450 450 360 600 540 600'/%3E%3Cpolygon fill='%23999' points='450 450 540 300 360 300'/%3E%3Cpolygon fill='%23999' points='630 450 540 600 720 600'/%3E%3Cpolygon fill='%23FFF' points='630 450 720 300 540 300'/%3E%3Cpolygon points='810 450 720 600 900 600'/%3E%3Cpolygon fill='%23DDD' points='810 450 900 300 720 300'/%3E%3Cpolygon fill='%23AAA' points='990 450 900 600 1080 600'/%3E%3Cpolygon fill='%23444' points='990 450 1080 300 900 300'/%3E%3Cpolygon fill='%23222' points='90 750 0 900 180 900'/%3E%3Cpolygon points='270 750 180 900 360 900'/%3E%3Cpolygon fill='%23DDD' points='270 750 360 600 180 600'/%3E%3Cpolygon points='450 750 540 600 360 600'/%3E%3Cpolygon points='630 750 540 900 720 900'/%3E%3Cpolygon fill='%23444' points='630 750 720 600 540 600'/%3E%3Cpolygon fill='%23AAA' points='810 750 720 900 900 900'/%3E%3Cpolygon fill='%23666' points='810 750 900 600 720 600'/%3E%3Cpolygon fill='%23999' points='990 750 900 900 1080 900'/%3E%3Cpolygon fill='%23999' points='180 0 90 150 270 150'/%3E%3Cpolygon fill='%23444' points='360 0 270 150 450 150'/%3E%3Cpolygon fill='%23FFF' points='540 0 450 150 630 150'/%3E%3Cpolygon points='900 0 810 150 990 150'/%3E%3Cpolygon fill='%23222' points='0 300 -90 450 90 450'/%3E%3Cpolygon fill='%23FFF' points='0 300 90 150 -90 150'/%3E%3Cpolygon fill='%23FFF' points='180 300 90 450 270 450'/%3E%3Cpolygon fill='%23666' points='180 300 270 150 90 150'/%3E%3Cpolygon fill='%23222' points='360 300 270 450 450 450'/%3E%3Cpolygon fill='%23FFF' points='360 300 450 150 270 150'/%3E%3Cpolygon fill='%23444' points='540 300 450 450 630 450'/%3E%3Cpolygon fill='%23222' points='540 300 630 150 450 150'/%3E%3Cpolygon fill='%23AAA' points='720 300 630 450 810 450'/%3E%3Cpolygon fill='%23666' points='720 300 810 150 630 150'/%3E%3Cpolygon fill='%23FFF' points='900 300 810 450 990 450'/%3E%3Cpolygon fill='%23999' points='900 300 990 150 810 150'/%3E%3Cpolygon points='0 600 -90 750 90 750'/%3E%3Cpolygon fill='%23666' points='0 600 90 450 -90 450'/%3E%3Cpolygon fill='%23AAA' points='180 600 90 750 270 750'/%3E%3Cpolygon fill='%23444' points='180 600 270 450 90 450'/%3E%3Cpolygon fill='%23444' points='360 600 270 750 450 750'/%3E%3Cpolygon fill='%23999' points='360 600 450 450 270 450'/%3E%3Cpolygon fill='%23666' points='540 600 630 450 450 450'/%3E%3Cpolygon fill='%23222' points='720 600 630 750 810 750'/%3E%3Cpolygon fill='%23FFF' points='900 600 810 750 990 750'/%3E%3Cpolygon fill='%23222' points='900 600 990 450 810 450'/%3E%3Cpolygon fill='%23DDD' points='0 900 90 750 -90 750'/%3E%3Cpolygon fill='%23444' points='180 900 270 750 90 750'/%3E%3Cpolygon fill='%23FFF' points='360 900 450 750 270 750'/%3E%3Cpolygon fill='%23AAA' points='540 900 630 750 450 750'/%3E%3Cpolygon fill='%23FFF' points='720 900 810 750 630 750'/%3E%3Cpolygon fill='%23222' points='900 900 990 750 810 750'/%3E%3Cpolygon fill='%23222' points='1080 300 990 450 1170 450'/%3E%3Cpolygon fill='%23FFF' points='1080 300 1170 150 990 150'/%3E%3Cpolygon points='1080 600 990 750 1170 750'/%3E%3Cpolygon fill='%23666' points='1080 600 1170 450 990 450'/%3E%3Cpolygon fill='%23DDD' points='1080 900 1170 750 990 750'/%3E%3C/g%3E%3C/pattern%3E%3C/defs%3E%3Crect x='0' y='0' fill='url(%23a)' width='100%25' height='100%25'/%3E%3Crect x='0' y='0' fill='url(%23b)' width='100%25' height='100%25'/%3E%3C/svg%3E");
    background-attachment: fixed;
    background-size: cover;
    background-repeat: no-repeat;
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    transition: all 0.5s;
    font-family: "Inter", serif;
    color: var(--text-color);
}

body {
    font-optical-sizing: auto;
    margin: auto;
}

[id] {
    scroll-margin-top: 80px;
}

.icon {
    color: var(--color_icons);
}

p {
    font-size: 14px;
    font-weight: 300;
    line-height: 1.5;
}

h1,
h2 {
    font-family: "Rambla", sans-serif;
}

h2 {
    font-size: 20px;
}

a {
    text-decoration: none;
    color: var(--text-color);
    list-style: none;
}

/* ---------------------------------- Header ----------------------------------- */

header {
    display: flex;
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    background-color: rgba(15, 23, 42, 0.6);
    border-bottom: 1px solid rgba(128, 128, 128, 0.2);
    justify-content: space-between;
    align-items: center;
    padding: 0.7% 10%;
    position: sticky;
    top: 0;
    z-index: 99999999;
    box-sizing: border-box;
}

#name_header {
    margin: 0;
    display: flex;
    align-items: center;
    gap: 10px;
    color: var(--text-color);
    font-size: 20px;
    font-weight: 700;
    cursor: default;
}

#logo_header {
    display: flex;
    background-image: linear-gradient(
        to right bottom,
        rgb(45, 212, 191),
        rgb(99, 102, 241)
    );
    border-radius: 9999px;
    align-items: center;
    justify-content: center;
    min-width: 37px;
    min-height: 37px;
}

#logo_header img {
    width: 25px;
    height: 25px;
}

header nav ul {
    display: flex;
    align-items: center;
    gap: 10px;
}

header nav li {
    border-radius: 6px;
    text-decoration: none;
    list-style: none;
    transition: all 0.3s;
    cursor: pointer;
    box-sizing: border-box;
    display: flex;
}

header nav li a {
    text-align: center;
    padding: 10px;
    color: #f3f4f6;
    font-weight: 300;
    font-size: 13px;
    box-sizing: border-box;
}

header nav li:hover {
    background-color: #172031;
}

#theme-contact_header {
    display: flex;
    gap: 15px;
    align-items: center;
    justify-content: center;
}

#theme-contact_header .icon_header {
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color_icons);
    font-size: 1rem;
    border-radius: 9999px;
    padding: 7px;
    cursor: pointer;
    transition: all 0.5s;
    box-sizing: content-box;
    border: solid 1px rgba(255, 255, 255, 0.02);
    backdrop-filter: blur(21px);
    -webkit-backdrop-filter: blur(21px);
    background: linear-gradient(
        15deg,
        rgba(255, 255, 255, 0.02),
        rgba(255, 255, 255, 0.02)
    );
}

#theme-contact_header .icon_header:hover {
    background-color: var(--background_cards);
    border-radius: 9999px;
}

#theme-contact_header button {
    background-image: var(--background_special);
    padding: 11px;
    border-radius: 6px;
    color: var(--text-color);
    border: none;
    cursor: pointer;
    font-weight: 600;
}

#theme-contact_header button:hover {
    background-image: linear-gradient(
        to right,
        rgb(13, 148, 136),
        rgb(79, 70, 229)
    );
    box-shadow: 0px 0px 60px #1f4c65;
}

/* ---------------------------------- Main ----------------------------------- */

main {
    scroll-snap-type: y mandatory;
    padding: 0 10.5%;
    box-sizing: border-box;
    overflow: hidden;
}

section {
    scroll-snap-align: start;
    margin-top: 12%;
}

.special_font {
    font-family: "Rambla", sans-serif;
}

.presentation_section {
    display: flex;
    flex-direction: column;
    gap: 17px;
    justify-content: center;
    align-items: center;
    margin: 0 10% 6.4% 10%;
    text-align: center;
    color: var(--text-color);
}

.mininame_section {
    background-color: var(--minicard_one);
    color: var(--text-color-minicard_one);
    border-radius: 9999px;
    padding: 5px 10px;
    font-size: 12px;
    width: min-content;
    white-space: nowrap;
    font-weight: 600;
    cursor: default;
    border: solid 1px rgba(255, 255, 255, 0.02);
    backdrop-filter: blur(21px);
    -webkit-backdrop-filter: blur(21px);
    background: linear-gradient(
        15deg,
        rgba(255, 255, 255, 0.05),
        rgba(255, 255, 255, 0.05)
    );
    transition: all 0.5s;
}

.mininame_section:hover {
    background: linear-gradient(
        15deg,
        rgba(255, 255, 255, 0.05),
        rgba(255, 255, 255, 0.1)
    );
    color: var(--text-color-minicard_two);
    transition: all 0.5s;
}

#icon_see_down {
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0 auto;
    cursor: default;
    opacity: 0.2;
}

/* ---------------------------------- Principal Presentation ----------------------------------- */

.content_presentation {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin: 9% 0;
    box-sizing: border-box;
}

#text_presentation {
    display: flex;
    flex-direction: column;
    animation: slide-in-left 1.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) both;
    animation-delay: 1s;
    box-sizing: border-box;
}

#name_presentation {
    font-size: 2.5rem;
    font-weight: 700;
    color: var(--text-color);
    margin: 10px 0 16px 0;
    display: flex;
    line-height: 1.2;
}

#name_as_color,
.buttons_about_me h2 {
    color: transparent;
    background-clip: text;
    background-image: var(--background_special);
}

#text_presentation p {
    font-size: 16px;
    width: 75%;
}

#buttons_presentation {
    display: flex;
    gap: 15px;
    margin-top: 30px;
}

#buttons_presentation button {
    display: flex;
    padding: 10px;
    border-radius: 6px;
    color: var(--text-color);
    align-items: center;
    justify-content: center;
    border: none;
    cursor: pointer;
    font-weight: 600;
    transition: 0.6s;
    margin-right: 15px;
    gap: 10px;
}

#buttons_presentation button .icon {
    width: 17px;
}

#bttn_see_projects {
    background-image: var(--background_special);
    box-shadow: 0px 0px 60px #1f4c65;
    -webkit-box-reflect: below 7px
        linear-gradient(to bottom, rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.1));
}

#bttn_see_projects:hover {
    transition: all 0.5s;
    background-image: linear-gradient(
        to right,
        rgb(13, 148, 136),
        rgb(79, 70, 229)
    );
    box-shadow: 0px 0px 60px #1f4c65;
}

#bttn_download_cv {
    backdrop-filter: blur(15px);
    background: rgba(0, 0, 0, 0.5);
    border: 1px solid rgba(128, 128, 128, 0.2) !important;
}

#buttons_presentation button:hover {
    box-shadow: 0px 0px 60px #1f4c65;
    -webkit-box-reflect: below 7px
        linear-gradient(to bottom, rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.1));
}

#social-networks_presentation {
    margin-top: 40px;
    display: flex;
    gap: 15px;
}

.icon_socialNetwork {
    color: var(--color_icons);
    background-color: var(--background_cards);
    font-size: 24px;
    border-radius: 500px;
    padding: 5px;
    box-sizing: content-box;
}

.icon_socialNetwork:hover {
    transform: scale(1.1);
    background-color: #172031;
}

#photo_presentation {
    background: var(--color_icons);
    border-radius: 100%;
    width: 290px !important;
    height: 290px !important;
    overflow: hidden;
    margin-right: 20px;
    box-shadow: 0px 0px 100px #1f4c65;
    animation: slide-in-right 1.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) both;
    animation-delay: 1s;
}

#photo_presentation img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* ------------------------------------------ About Me ------------------------------------------ */

#about_me {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

#content_about_me {
    display: flex;
    flex-direction: column;
    gap: 5%;
    align-items: center;
    justify-content: center;
    width: 100%;
}

#text_about_me {
    display: flex;
    flex-direction: column;
    width: 50%;
    animation: slide-in-left 1.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) both;
    animation-delay: 2s;
}

#text_about_me p {
    padding: 10px 0;
}

#cards_about_me {
    display: flex;
    gap: 15px;
    margin-top: 30px;
}

.cards_about_me {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
    border-radius: 6px;
    padding: 12px 15px;
    width: 50%;
    background-color: var(--background_cards);
    cursor: default;
    border: solid 1px rgba(255, 255, 255, 0.02);
    backdrop-filter: blur(21px);
    -webkit-backdrop-filter: blur(21px);
    margin-top: -10px;
}

.cards_about_me p {
    padding: 0 !important;
    margin: 0 !important;
    text-align: center;
}

#skills_about_me {
    display: flex;
    flex-direction: column;
    width: 50%;
    gap: 10px;
    animation: slide-in-right 1.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) both;
    animation-delay: 2s;
}

#skills_description {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

#skills_titles {
    background-color: #27272a;
    border-radius: 6px;
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 10px;
    padding: 4px;
    justify-content: space-between;
    align-items: center;
}

#skills_titles p {
    text-align: center;
    border-radius: 4px;
    padding: 6px 12px;
    width: 100%;
    margin: auto;
    cursor: pointer;
}

#frontend_skill {
    background: rgba(0, 0, 0, 0.5);
}

#skills_frontend,
#skills_backend,
#skills_widgets {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 10px;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
}

#skills_backend,
#skills_widgets {
    display: none;
}

.skill {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px;
    border-radius: 6px;
    background-color: var(--background_cards);
    border: solid 1px rgba(255, 255, 255, 0.02);
    backdrop-filter: blur(21px);
    -webkit-backdrop-filter: blur(21px);
}

.skill p {
    font-size: 13px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.point_in_skill {
    width: 7px;
    height: 7px;
    background: var(--background_special);
    border-radius: 50%;
    display: inline-block;
}

.icon_ability {
    width: 22px !important;
    height: 22px !important;
}

/* ------------------------------------------ Projects ------------------------------------------ */

#projects {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

#content_projects {
    display: grid;
    gap: 20px;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    justify-content: center;
    height: 370px;
    width: 100%;
}

.project {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    width: 100%;
    background-color: var(--background_cards);
    border: solid 1px rgba(255, 255, 255, 0.02);
    backdrop-filter: blur(21px);
    -webkit-backdrop-filter: blur(21px);
    transition: all 0.5s;
    overflow: hidden;
}

.project:hover {
    background-color: #172031;
    transition: all 0.5s;
    transform: translateY(-5px);
}

.project_image {
    overflow: hidden;
    z-index: 1;
    border-radius: 6px 6px 0 0;
    width: 100%;
    height: 45%;
    transition: all 0.5s;
    cursor: pointer;

    box-sizing: border-box;
}

.project_image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    margin: auto;
    transition: all 0.5s;
    overflow: hidden;
    box-sizing: border-box;
    z-index: -1;
}

.project_image:hover {
    opacity: 0.9;
    overflow: hidden;
}

.project_description {
    display: flex;
    flex-direction: column;
    padding: 20px;
    gap: 12px;
    width: 100%;
    height: 55%;
    box-sizing: border-box;
}

.project_description a {
    cursor: pointer;
}

.project_description p {
    width: 100%;
    height: auto;
    overflow: hidden;
    text-overflow: ellipsis;
    flex-grow: 1;
}

.mininame_languages_container {
    display: flex;
    gap: 10px;
    align-items: center;
    padding: 0;
    width: 100%;
    box-sizing: border-box;
}

.mininame_languages {
    display: flex;
    padding: 5px 10px;
    border-radius: 9999px;
    font-size: 12px;
    font-weight: 600;
    box-sizing: border-box;
    color: var(--text-color-minicard_one);
    background-color: var(--minicard_two);
    width: min-content;
    white-space: nowrap;
}

#bttn_see_more_projects {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 50px;
    backdrop-filter: blur(15px);
    background: rgba(0, 0, 0, 0.5);
    border: 1px solid rgba(128, 128, 128, 0.2) !important;
    padding: 10px;
    border-radius: 6px;
    color: var(--text-color);
    cursor: pointer;
    font-weight: 600;
    transition: 0.6s;
}

#bttn_see_more_projects:hover {
    box-shadow: 0px 0px 60px #1f4c65;
    -webkit-box-reflect: below 7px
        linear-gradient(to bottom, rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.1));
}

/* ----------------------------------------- Education ----------------------------------------- */

.education_item {
    display: flex;
    gap: 24px;
    margin-bottom: 48px;
}

.education_item .mininame_section {
    font-size: 11px;
}

.content_point_line {
    display: flex;
    flex-direction: column;
    margin-top: 15px;
}

.content_point_in_education {
    display: flex;
    width: 49px;
    height: 49px;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background-color: var(--background_cards);
    border: 1px solid rgba(128, 128, 128, 0.2) !important;
}

.point_in_education {
    line-height: 24px;
    width: 12px;
    height: 12px;
    background: var(--background_special);
    border-radius: 50%;
    display: inline-block;
}

.education_item_info {
    display: flex;
    flex-direction: column;
    height: min-content;
    min-height: 170px;
    width: 100%;
    padding: 24px;
    background-color: var(--background_cards);
    border: 1px solid rgba(128, 128, 128, 0.2);
    border-radius: 8px;
}

.education_item_info .mininame_section {
    margin-bottom: 12px;
}

.education_item_info h4 {
    margin-bottom: 8px;
}

.name_ubication_education {
    margin-bottom: 12px !important;
    color: gray;
}

/* ----------------------------------------- Contact ----------------------------------------- */

#content_contact {
    display: flex;
    width: 80%;
    margin: auto;
    height: auto;
    border-radius: 8px;
    border: 1px solid rgba(128, 128, 128, 0.2);
}

#info_contact {
    display: flex;
    flex-direction: column;
    width: 40%;
    min-height: 100% !important;
    gap: 24px;
    padding: 32px;
    background: var(--background_special);
}

#info_contact h3 {
    font-size: 20px;
    line-height: 32px;
    font-weight: 600;
    margin-bottom: 0 0 24px;
}

#info_contact p {
    line-height: 24px;
    margin-bottom: 0 0 32px;
}

.contact_data {
    display: flex;
    flex-direction: row;
    gap: 12px;
    align-items: center;
    margin-bottom: 12px;
}

.content_icons_contact_data {
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50000px;
    padding: 2%;
    background: rgba(255, 255, 255, 0.1);
}

.content_icons_contact_data i {
    font-size: 24px;
}

.content_icons_contact_data p {
    margin: 0 !important;
    text-align: left;
}

#form_contact {
    display: flex;
    flex-direction: column;
    width: 60%;
    padding: 32px;
    min-height: 100%;
    background-color: var(--background_cards);
}

.form_data_principal {
    display: grid;
    grid-template-rows: 70px;
    grid-template-columns: 1fr 1fr;
    width: 100%;
    gap: 24px;
    line-height: 24px;
}

#form_data_subject,
#form_data_message {
    display: flex;
    flex-direction: column;
    width: 100%;
    margin: 24px 0 0 0;
    line-height: 24px;
}

.form_data_item {
    display: flex;
    flex-direction: column;
    width: 100%;
}

.form_data_item label {
    margin: 0 0 8px;
    line-height: 20px;
    font-weight: 600;
    font-size: 14px;
}

.form_data_item input,
textarea {
    display: inline-block;
    width: 100%;
    resize: none;
    padding: 8px 16px;
    border-radius: 6px;
    border: 1px solid rgba(128, 128, 128, 0.2);
    background: var(--minicard_two);
    height: auto;
    line-height: 24px;
    color: var(--text-color);
    z-index: 9999999;
}

.form_data_item input,
textarea:focus {
    outline: none;
}

#bttn_send_message {
    text-align: center;
    width: 100%;
    color: var(--text-color);
    font-weight: 600;
    padding: 8px 16px;
    line-height: 20px;
    margin-top: 24px;
    font-size: 14px;
    background: var(--background_special);
    border-radius: 6px;
    border: none;
}

#bttn_send_message:hover {
    background-image: linear-gradient(
        to right,
        rgb(13, 148, 136),
        rgb(79, 70, 229)
    );
    box-shadow: 0px 0px 60px #1f4c65;
}

/* ----------------------------------------- Footer ----------------------------------------- */

footer {
    display: flex;
    color: var(--text-color);
    line-height: 24px;
    padding: 32px 20px;
    border: 1px solid rgba(128, 128, 128, 0.2);
    margin-top: 100px;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    gap: 1rem;
}

#name_footer {
    display: flex;
    align-items: center;
    gap: 10px;
}

#name_footer img {
    width: 25px;
    height: 25px;
}

#rights_footer {
    display: flex;
    gap: 1rem;
    align-items: center;
    justify-content: center;
}


/*---------------BUTTON UP---------------*/

.up {
    transition: all 0.3s ease-in-out;
    display: none;
    align-items: center;
    justify-content: center;
    border-radius: 999999px;
    border: 1px solid #4c3e89de;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(15px);
    background-color: #291a6664;
    position: fixed;
    bottom: 20px;
    right: 20px;
    z-index: 1000;
    cursor: pointer;
    padding: 10px;
    width: 40px;
    height: 40px;
    color: var(--text-color-P);
}

.up:hover {
    background-color: #3b38d864;
}

.up i {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    font-size: large;
    color: var(--secondary-color);
}

/* ----------------------------------------- ANIMATIONS ----------------------------------------- */

@keyframes slide-in-left {
    0% {
        transform: translateX(-1000px);
        opacity: 0;
    }
    100% {
        transform: translateX(0);
        opacity: 1;
    }
}

@keyframes slide-in-right {
    0% {
        transform: translateX(1000px);
        opacity: 0;
    }
    100% {
        transform: translateX(0);
        opacity: 1;
    }
}
