/*!********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[11].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[14].oneOf[11].use[3]!./node_modules/next/dist/build/webpack/loaders/resolve-url-loader/index.js??ruleSet[1].rules[14].oneOf[11].use[4]!./node_modules/next/dist/compiled/sass-loader/cjs.js??ruleSet[1].rules[14].oneOf[11].use[5]!./src/app/globals.scss ***!
  \********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
:root {
  --bg-primary: #FAFAF8;
  --bg-secondary: #F3F0FC;
  --text-primary: #0C0A1E;
  --text-secondary: #423A6C;
  --accent-primary: #5B16F0;
  --accent-secondary: #06B6D4;
  --accent-primary-rgb: 91, 22, 240;
  --container-width: 1200px;
  --header-height: 70px;
  --border-radius: 8px;
  --transition-speed: 0.3s;
}

[data-theme=dark] {
  --bg-primary: #060914;
  --bg-secondary: #0B0F21;
  --text-primary: #EDF0FF;
  --text-secondary: #8B91B8;
  --accent-primary: #8B5CF6;
  --accent-secondary: #22D3EE;
  --accent-primary-rgb: 139, 92, 246;
}

body {
  font-family: var(--font-inter), sans-serif;
  margin: 0;
  padding: 0;
  background-color: var(--bg-primary);
  color: var(--text-primary);
  transition: background-color var(--transition-speed) ease, color var(--transition-speed) ease;
}
body::after {
  content: "";
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 9999;
  opacity: 0.025;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
  background-repeat: repeat;
  background-size: 200px 200px;
}

h1, h2 {
  font-family: var(--font-display), sans-serif;
  margin: 0;
}

h3, h4, h5, h6 {
  font-family: var(--font-inter), sans-serif;
  margin: 0;
}

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

a {
  color: var(--accent-primary);
  text-decoration: none;
  transition: color var(--transition-speed) ease;
}
a:hover {
  color: var(--accent-secondary);
}

.container {
  max-width: var(--container-width);
  margin: 0 auto;
  padding: 0 20px;
}
@media (min-width: 1280px) and (max-width: 1300px) {
  .container {
    padding: 0 30px;
  }
}

body {
  counter-reset: section-counter;
}

.section {
  padding: 60px 0;
}
.section__title {
  font-size: 2.4rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  margin-bottom: 40px;
  position: relative;
  display: inline-block;
  counter-increment: section-counter;
}
.section__title::before {
  content: "0" counter(section-counter);
  position: absolute;
  top: -1.4rem;
  left: -0.3rem;
  font-size: 7rem;
  font-style: normal;
  font-weight: 900;
  line-height: 1;
  opacity: 0.04;
  pointer-events: none;
  z-index: -1;
  font-family: var(--font-display), serif;
  transition: opacity var(--transition-speed) ease;
}
.section__title::after {
  content: "";
  position: absolute;
  bottom: -12px;
  left: 0;
  width: 100%;
  height: 1px;
  background: linear-gradient(to right, var(--accent-primary), transparent);
  opacity: 0.4;
  transition: opacity var(--transition-speed) ease;
}
[data-theme=dark] .section__title::before {
  opacity: 0.06;
}
[data-theme=dark] .section__title::after {
  opacity: 0.3;
}

.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}

.theme-transition {
  transition: background-color 1s ease, color 1s ease, border-color 1s ease, box-shadow 1s ease;
}
.theme-transition * {
  transition: background-color 1s ease, color 1s ease, border-color 1s ease, box-shadow 1s ease, fill 1s ease, stroke 1s ease;
}

[data-theme=dark] img {
  filter: brightness(0.9);
}
[data-theme=dark] .section__title::after {
  opacity: 0.8;
}
[data-theme=dark] .header--scrolled {
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
}
[data-theme=dark] .experience__timeline::before {
  opacity: 0.3;
}

@media (max-width: 1280px) {
  .home-page {
    /* Add padding to the bottom to prevent content from being hidden behind social links */
  }
  /* Adjust footer padding as well */
  .footer {
    padding-bottom: 80px;
  }
  .footer__bottom {
    margin-bottom: 80px;
  }
}
/*!*****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[2].use[1]!./node_modules/next/dist/build/webpack/loaders/next-font-loader/index.js??ruleSet[1].rules[14].oneOf[2].use[2]!./node_modules/next/font/google/target.css?{"path":"src/app/layout.js","import":"Manrope","arguments":[{"subsets":["latin","cyrillic"],"variable":"--font-inter","display":"swap"}],"variableName":"manrope"} ***!
  \*****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
/* cyrillic-ext */
@font-face {
  font-family: 'Manrope';
  font-style: normal;
  font-weight: 200 800;
  font-display: swap;
  src: url(/_next/static/media/438aa629764e75f3-s.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Manrope';
  font-style: normal;
  font-weight: 200 800;
  font-display: swap;
  src: url(/_next/static/media/875ae681bfde4580-s.p.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek */
@font-face {
  font-family: 'Manrope';
  font-style: normal;
  font-weight: 200 800;
  font-display: swap;
  src: url(/_next/static/media/51251f8b9793cdb3-s.woff2) format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'Manrope';
  font-style: normal;
  font-weight: 200 800;
  font-display: swap;
  src: url(/_next/static/media/e857b654a2caa584-s.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Manrope';
  font-style: normal;
  font-weight: 200 800;
  font-display: swap;
  src: url(/_next/static/media/cc978ac5ee68c2b6-s.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Manrope';
  font-style: normal;
  font-weight: 200 800;
  font-display: swap;
  src: url(/_next/static/media/4c9affa5bc8f420e-s.p.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}@font-face {font-family: 'Manrope Fallback';src: local("Arial");ascent-override: 103.31%;descent-override: 29.07%;line-gap-override: 0.00%;size-adjust: 103.19%
}.__className_fe7774 {font-family: 'Manrope', 'Manrope Fallback';font-style: normal
}.__variable_fe7774 {--font-inter: 'Manrope', 'Manrope Fallback'
}

/*!************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[2].use[1]!./node_modules/next/dist/build/webpack/loaders/next-font-loader/index.js??ruleSet[1].rules[14].oneOf[2].use[2]!./node_modules/next/font/google/target.css?{"path":"src/app/layout.js","import":"JetBrains_Mono","arguments":[{"subsets":["latin","cyrillic"],"variable":"--font-roboto-mono","display":"swap"}],"variableName":"jetbrainsMono"} ***!
  \************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
/* cyrillic-ext */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 100 800;
  font-display: swap;
  src: url(/_next/static/media/886030b0b59bc5a7-s.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 100 800;
  font-display: swap;
  src: url(/_next/static/media/0aa834ed78bf6d07-s.p.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 100 800;
  font-display: swap;
  src: url(/_next/static/media/67957d42bae0796d-s.woff2) format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 100 800;
  font-display: swap;
  src: url(/_next/static/media/f911b923c6adde36-s.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 100 800;
  font-display: swap;
  src: url(/_next/static/media/939c4f875ee75fbb-s.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 100 800;
  font-display: swap;
  src: url(/_next/static/media/bb3ef058b751a6ad-s.p.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}@font-face {font-family: 'JetBrains Mono Fallback';src: local("Arial");ascent-override: 75.79%;descent-override: 22.29%;line-gap-override: 0.00%;size-adjust: 134.59%
}.__className_89caef {font-family: 'JetBrains Mono', 'JetBrains Mono Fallback';font-style: normal
}.__variable_89caef {--font-roboto-mono: 'JetBrains Mono', 'JetBrains Mono Fallback'
}

/*!***********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[2].use[1]!./node_modules/next/dist/build/webpack/loaders/next-font-loader/index.js??ruleSet[1].rules[14].oneOf[2].use[2]!./node_modules/next/font/google/target.css?{"path":"src/app/layout.js","import":"Geologica","arguments":[{"subsets":["latin","cyrillic"],"variable":"--font-display","display":"swap"}],"variableName":"geologica"} ***!
  \***********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
/* cyrillic-ext */
@font-face {
  font-family: 'Geologica';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(/_next/static/media/13d601e0732c7766-s.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Geologica';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(/_next/static/media/f54e13212b7871d5-s.p.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek */
@font-face {
  font-family: 'Geologica';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(/_next/static/media/5ccbc299521a181a-s.woff2) format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'Geologica';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(/_next/static/media/4fca260083159167-s.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Geologica';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(/_next/static/media/fe1772644044fc6c-s.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Geologica';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(/_next/static/media/f3fb4235d30510d6-s.p.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}@font-face {font-family: 'Geologica Fallback';src: local("Arial");ascent-override: 90.18%;descent-override: 25.43%;line-gap-override: 0.00%;size-adjust: 108.12%
}.__className_fc9c50 {font-family: 'Geologica', 'Geologica Fallback';font-style: normal
}.__variable_fc9c50 {--font-display: 'Geologica', 'Geologica Fallback'
}

/*!*************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[11].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[14].oneOf[11].use[3]!./node_modules/next/dist/build/webpack/loaders/resolve-url-loader/index.js??ruleSet[1].rules[14].oneOf[11].use[4]!./node_modules/next/dist/compiled/sass-loader/cjs.js??ruleSet[1].rules[14].oneOf[11].use[5]!./src/components/Background/AnimatedBackground.scss ***!
  \*************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
.animated-background {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  opacity: 0.8;
  background: transparent;
}
.animated-background canvas {
  pointer-events: auto;
}
/*!*************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[11].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[14].oneOf[11].use[3]!./node_modules/next/dist/build/webpack/loaders/resolve-url-loader/index.js??ruleSet[1].rules[14].oneOf[11].use[4]!./node_modules/next/dist/compiled/sass-loader/cjs.js??ruleSet[1].rules[14].oneOf[11].use[5]!./src/components/ScrollProgress/ScrollProgress.scss ***!
  \*************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
.scroll-progress {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 4px;
  z-index: 1000;
  background-color: rgba(0, 0, 0, 0.1);
}
[data-theme=dark] .scroll-progress {
  background-color: rgba(255, 255, 255, 0.1);
}
.scroll-progress__bar {
  height: 100%;
  background-color: var(--accent-primary);
  width: 0%;
  transition: width 0.1s ease;
}
/*!*******************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[11].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[14].oneOf[11].use[3]!./node_modules/next/dist/build/webpack/loaders/resolve-url-loader/index.js??ruleSet[1].rules[14].oneOf[11].use[4]!./node_modules/next/dist/compiled/sass-loader/cjs.js??ruleSet[1].rules[14].oneOf[11].use[5]!./src/components/SocialLinks/SocialLinks.scss ***!
  \*******************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
.social-links {
  position: fixed;
  left: 20px;
  top: 50%;
  transform: translateY(-50%) translateX(-60px);
  transition: transform 0.8s cubic-bezier(0.215, 0.61, 0.355, 1);
  z-index: 990;
  display: flex;
  width: -moz-fit-content;
  width: fit-content;
  margin: auto;
  border-radius: 20px;
}
@media (max-width: 1200px) {
  .social-links {
    left: 15px; /* Reduce left spacing */
  }
}
@media (max-width: 480px) {
  .social-links {
    display: block;
    width: unset;
    margin: unset;
  }
}
.social-links--visible {
  transform: translateY(-50%) translateX(0);
}
.social-links--pulse {
  animation: socialLinksPulse 1s ease-in-out 3;
}
@keyframes socialLinksPulse {
  0% {
    transform: translateY(-50%) translateX(0);
    box-shadow: 0 0 0 0 rgba(var(--accent-primary-rgb, 109, 40, 217), 0.4);
  }
  50% {
    transform: translateY(-50%) translateX(0);
    box-shadow: 0 0 20px 5px rgba(var(--accent-primary-rgb, 109, 40, 217), 0.6);
  }
  100% {
    transform: translateY(-50%) translateX(0);
    box-shadow: 0 0 0 0 rgba(var(--accent-primary-rgb, 109, 40, 217), 0);
  }
}
.social-links__list {
  display: flex;
  flex-direction: column;
  gap: 15px;
  padding: 0;
  margin: 0;
  list-style: none;
}
.social-links__item {
  position: relative;
  transition: transform 0.3s ease;
}
.social-links__item:hover {
  transform: translateX(3px);
}
.social-links__item:hover .social-links__tooltip {
  opacity: 1;
  transform: translateX(10px) scale(1);
}
.social-links__item--linkedin .social-links__icon-wrapper {
  background-color: rgba(0, 119, 181, 0.1);
  border-color: rgba(0, 119, 181, 0.3);
}
.social-links__item--linkedin .social-links__icon-wrapper:hover {
  background-color: rgba(0, 119, 181, 0.2);
}
.social-links__item--telegram .social-links__icon-wrapper {
  background-color: rgba(0, 136, 204, 0.1);
  border-color: rgba(0, 136, 204, 0.3);
}
.social-links__item--telegram .social-links__icon-wrapper:hover {
  background-color: rgba(0, 136, 204, 0.2);
}
.social-links__item--email .social-links__icon-wrapper {
  background-color: rgba(234, 67, 53, 0.1);
  border-color: rgba(234, 67, 53, 0.3);
}
.social-links__item--email .social-links__icon-wrapper:hover {
  background-color: rgba(234, 67, 53, 0.2);
}
.social-links__item--instagram .social-links__icon-wrapper {
  background-color: rgba(225, 48, 108, 0.1);
  border-color: rgba(225, 48, 108, 0.3);
}
.social-links__item--instagram .social-links__icon-wrapper:hover {
  background-color: rgba(225, 48, 108, 0.2);
}
.social-links__item--whatsapp .social-links__icon-wrapper {
  background-color: rgba(37, 211, 102, 0.1);
  border-color: rgba(37, 211, 102, 0.3);
}
.social-links__item--whatsapp .social-links__icon-wrapper:hover {
  background-color: rgba(37, 211, 102, 0.2);
}
.social-links__item--phone .social-links__icon-wrapper {
  background-color: rgba(109, 40, 217, 0.1);
  border-color: rgba(109, 40, 217, 0.3);
}
.social-links__item--phone .social-links__icon-wrapper:hover {
  background-color: rgba(109, 40, 217, 0.2);
}
.social-links__link {
  display: block;
  width: 100%;
  height: 100%;
  text-decoration: none;
}
.social-links__icon-wrapper {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background-color: var(--color-surface, rgba(247, 247, 253, 0.8));
  border: 1px solid var(--color-border, rgba(229, 225, 245, 0.8));
  box-shadow: 0 4px 10px rgba(45, 27, 105, 0.05);
  transition: all 0.3s ease;
}
[data-theme=dark] .social-links__icon-wrapper {
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
}
.social-links__icon {
  width: 20px;
  height: 20px;
  transition: transform 0.3s ease;
}
.social-links__link:hover .social-links__icon {
  transform: scale(1.15);
}
.social-links__tooltip {
  position: absolute;
  left: 100%;
  top: 50%;
  transform: translateX(5px) translateY(-50%) scale(0.9);
  background-color: var(--color-card, rgba(255, 255, 255, 0.9));
  color: var(--color-text, #2D1B69);
  padding: 4px 10px;
  border-radius: 4px;
  font-size: 0.75rem;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: all 0.3s ease;
  box-shadow: 0 2px 8px rgba(45, 27, 105, 0.1);
}
[data-theme=dark] .social-links__tooltip {
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}
.social-links__tooltip::before {
  content: "";
  position: absolute;
  right: 100%;
  top: 50%;
  transform: translateY(-50%);
  border-width: 5px;
  border-style: solid;
  border-color: transparent var(--color-card, rgba(255, 255, 255, 0.9)) transparent transparent;
}
@media (max-width: 768px) {
  .social-links {
    left: 10px;
  }
  .social-links__icon-wrapper {
    width: 36px;
    height: 36px;
  }
  .social-links__icon {
    width: 18px;
    height: 18px;
  }
}
@media (min-width: 481px) and (max-width: 768px) {
  .social-links {
    left: 10px;
  }
  .social-links__list {
    gap: 14px;
    background-color: var(--color-card, rgba(255, 255, 255, 0.9));
    -webkit-backdrop-filter: blur(10px);
            backdrop-filter: blur(10px);
    padding: 12px;
    border-radius: 16px;
    box-shadow: 0 8px 30px rgba(45, 27, 105, 0.15);
    border: 1px solid var(--color-border, rgba(229, 225, 245, 0.5));
  }
  [data-theme=dark] .social-links__list {
    background-color: var(--color-card, rgba(26, 21, 54, 0.9));
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.25);
  }
  .social-links__icon-wrapper {
    width: 42px;
    height: 42px;
    transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    box-shadow: 0 4px 12px rgba(45, 27, 105, 0.1);
  }
  [data-theme=dark] .social-links__icon-wrapper {
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
  }
  .social-links__icon-wrapper:hover {
    transform: scale(1.15) translateX(3px);
    box-shadow: 0 8px 16px rgba(45, 27, 105, 0.15);
  }
  .social-links__icon {
    width: 20px;
    height: 20px;
    filter: saturate(1.2);
  }
  .social-links__item--linkedin .social-links__icon-wrapper {
    background-color: rgba(0, 119, 181, 0.15);
    border-color: rgba(0, 119, 181, 0.5);
  }
  .social-links__item--telegram .social-links__icon-wrapper {
    background-color: rgba(0, 136, 204, 0.15);
    border-color: rgba(0, 136, 204, 0.5);
  }
  .social-links__item--email .social-links__icon-wrapper {
    background-color: rgba(234, 67, 53, 0.15);
    border-color: rgba(234, 67, 53, 0.5);
  }
  .social-links__item--instagram .social-links__icon-wrapper {
    background-color: rgba(225, 48, 108, 0.15);
    border-color: rgba(225, 48, 108, 0.5);
  }
  .social-links__item--whatsapp .social-links__icon-wrapper {
    background-color: rgba(37, 211, 102, 0.15);
    border-color: rgba(37, 211, 102, 0.5);
  }
  .social-links__item--phone .social-links__icon-wrapper {
    background-color: rgba(109, 40, 217, 0.15);
    border-color: rgba(109, 40, 217, 0.5);
  }
  [data-theme=dark] .social-links__item--linkedin .social-links__icon-wrapper {
    background-color: rgba(0, 119, 181, 0.2);
    border-color: rgba(0, 119, 181, 0.6);
  }
  [data-theme=dark] .social-links__item--telegram .social-links__icon-wrapper {
    background-color: rgba(0, 136, 204, 0.2);
    border-color: rgba(0, 136, 204, 0.6);
  }
  [data-theme=dark] .social-links__item--email .social-links__icon-wrapper {
    background-color: rgba(234, 67, 53, 0.2);
    border-color: rgba(234, 67, 53, 0.6);
  }
  [data-theme=dark] .social-links__item--instagram .social-links__icon-wrapper {
    background-color: rgba(225, 48, 108, 0.2);
    border-color: rgba(225, 48, 108, 0.6);
  }
  [data-theme=dark] .social-links__item--whatsapp .social-links__icon-wrapper {
    background-color: rgba(37, 211, 102, 0.2);
    border-color: rgba(37, 211, 102, 0.6);
  }
  [data-theme=dark] .social-links__item--phone .social-links__icon-wrapper {
    background-color: rgba(139, 92, 246, 0.2);
    border-color: rgba(139, 92, 246, 0.6);
  }
}
@media (max-width: 1280px) {
  .social-links {
    bottom: 20px;
    top: auto;
    left: 0;
    right: 0;
    transform: translateY(70px);
  }
  .social-links--visible {
    transform: translateY(0);
  }
  .social-links__list {
    flex-direction: row;
    justify-content: center;
    gap: 16px;
    background-color: var(--color-card, rgba(255, 255, 255, 0.9));
    -webkit-backdrop-filter: blur(10px);
            backdrop-filter: blur(10px);
    padding: 12px 16px;
    box-shadow: 0 8px 30px rgba(45, 27, 105, 0.15);
    border: 1px solid var(--color-border, rgba(229, 225, 245, 0.5));
    margin: 0 -10px;
  }
  [data-theme=dark] .social-links__list {
    background-color: var(--color-card, rgba(26, 21, 54, 0.9));
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.25);
  }
  .social-links__icon-wrapper {
    width: 44px;
    height: 44px;
    transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    box-shadow: 0 4px 12px rgba(45, 27, 105, 0.1);
  }
  [data-theme=dark] .social-links__icon-wrapper {
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
  }
  .social-links__icon-wrapper:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 16px rgba(45, 27, 105, 0.15);
  }
  .social-links__icon {
    width: 22px;
    height: 22px;
    filter: saturate(1.2);
  }
  .social-links__item:hover {
    transform: none;
  }
  .social-links__item:hover .social-links__tooltip {
    transform: translateY(-10px) translateX(-50%) scale(1);
    left: 50%;
    top: 0;
  }
  .social-links__tooltip {
    left: 50%;
    top: 0;
    transform: translateY(-5px) translateX(-50%) scale(0.9);
    font-weight: 500;
  }
  .social-links__tooltip::before {
    right: auto;
    left: 50%;
    top: 100%;
    transform: translateX(-50%);
    border-color: var(--color-card, rgba(255, 255, 255, 0.9)) transparent transparent transparent;
  }
  .social-links__item--linkedin .social-links__icon-wrapper {
    background-color: rgba(0, 119, 181, 0.15);
    border-color: rgba(0, 119, 181, 0.5);
  }
  .social-links__item--telegram .social-links__icon-wrapper {
    background-color: rgba(0, 136, 204, 0.15);
    border-color: rgba(0, 136, 204, 0.5);
  }
  .social-links__item--email .social-links__icon-wrapper {
    background-color: rgba(234, 67, 53, 0.15);
    border-color: rgba(234, 67, 53, 0.5);
  }
  .social-links__item--instagram .social-links__icon-wrapper {
    background-color: rgba(225, 48, 108, 0.15);
    border-color: rgba(225, 48, 108, 0.5);
  }
  .social-links__item--whatsapp .social-links__icon-wrapper {
    background-color: rgba(37, 211, 102, 0.15);
    border-color: rgba(37, 211, 102, 0.5);
  }
  .social-links__item--phone .social-links__icon-wrapper {
    background-color: rgba(109, 40, 217, 0.15);
    border-color: rgba(109, 40, 217, 0.5);
  }
  [data-theme=dark] .social-links__item--linkedin .social-links__icon-wrapper {
    background-color: rgba(0, 119, 181, 0.2);
    border-color: rgba(0, 119, 181, 0.6);
  }
  [data-theme=dark] .social-links__item--telegram .social-links__icon-wrapper {
    background-color: rgba(0, 136, 204, 0.2);
    border-color: rgba(0, 136, 204, 0.6);
  }
  [data-theme=dark] .social-links__item--email .social-links__icon-wrapper {
    background-color: rgba(234, 67, 53, 0.2);
    border-color: rgba(234, 67, 53, 0.6);
  }
  [data-theme=dark] .social-links__item--instagram .social-links__icon-wrapper {
    background-color: rgba(225, 48, 108, 0.2);
    border-color: rgba(225, 48, 108, 0.6);
  }
  [data-theme=dark] .social-links__item--whatsapp .social-links__icon-wrapper {
    background-color: rgba(37, 211, 102, 0.2);
    border-color: rgba(37, 211, 102, 0.6);
  }
  [data-theme=dark] .social-links__item--phone .social-links__icon-wrapper {
    background-color: rgba(139, 92, 246, 0.2);
    border-color: rgba(139, 92, 246, 0.6);
  }
  .social-links + footer {
    margin-bottom: 60px; /* Add space before footer for the social links */
  }
}
@media (min-width: 480px) and (max-width: 1280px) {
  .social-links__list {
    flex-direction: row;
    justify-content: center;
    gap: 16px;
    width: -moz-fit-content;
    width: fit-content;
    background-color: var(--color-card, rgba(255, 255, 255, 0.9));
    -webkit-backdrop-filter: blur(10px);
            backdrop-filter: blur(10px);
    padding: 12px 16px;
    border-radius: 16px;
    box-shadow: 0 8px 30px rgba(45, 27, 105, 0.15);
    border: 1px solid var(--color-border, rgba(229, 225, 245, 0.5));
    margin: 0 auto;
  }
}
.social-links--hidden {
  transform: translateY(-50%) translateX(-60px) !important;
}
@media (max-width: 480px) {
  .social-links--hidden {
    transform: translateY(70px) !important;
  }
}
.social-links--hidden .social-links__toggle {
  transform: translateX(60px);
}
@media (max-width: 480px) {
  .social-links--hidden .social-links__toggle {
    transform: translateY(-70px);
  }
}
.social-links__toggle {
  position: absolute;
  background-color: var(--bg-primary);
  border: 1px solid rgba(var(--gray-rgb, 0, 0, 0), 0.1);
  border-radius: 50%;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  transition: all 0.3s ease;
  z-index: 2;
  color: var(--text-primary);
  /* Position differently based on viewport size */
  right: -40px;
  top: 50%;
  transform: translateY(-50%);
}
@media (max-width: 480px) {
  .social-links__toggle {
    top: -40px;
    right: 20px;
    transform: none;
  }
}
.social-links__toggle:hover {
  background-color: var(--accent-primary);
  color: white;
}
[data-theme=dark] .social-links__toggle {
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}
