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

:root{
  --primary-color:#00a8ff;
  --secondary-color:#1e3799;
  --accent-color:#fbc531;
  --dark-color:#0c0c0c;
  --darker-color:#070707;
  --light-color:#fff;
  --gray-color:#6c757d;
  --light-gray:#f8f9fa;
  --gradient-primary:linear-gradient(135deg,#667eea 0%,#764ba2 100%);
  --gradient-secondary:linear-gradient(135deg,#f093fb 0%,#f5576c 100%);
  --gradient-accent:linear-gradient(135deg,#4facfe 0%,#00f2fe 100%);
  --font-primary:'Inter',sans-serif;
  --font-mono:'JetBrains Mono',monospace;
  --shadow-sm:0 2px 8px rgba(0,0,0,.1);
  --shadow-lg:0 10px 30px rgba(0,0,0,.15);
  --shadow-xl:0 20px 40px rgba(0,0,0,.2);
  --border-radius:12px;
  --transition:all .3s cubic-bezier(.25,.46,.45,.94);
  --container-max-width:1200px;
  --nav-height:72px;
}

html{scroll-behavior:smooth;font-size:16px;}
body{
  font-family:var(--font-primary);
  line-height:1.6;
  color:var(--light-color);
  background:var(--dark-color);
  overflow-x:hidden;
  width:100%;
}
.container{
  max-width:var(--container-max-width);
  margin:0 auto;
  padding:0 1rem;
  width:100%;
  box-sizing:border-box;
}

::-webkit-scrollbar{width:8px;}
::-webkit-scrollbar-track{background:var(--darker-color);}
::-webkit-scrollbar-thumb{background:var(--primary-color);border-radius:4px;}
::-webkit-scrollbar-thumb:hover{background:var(--secondary-color);}

h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.2;margin-bottom:1rem;}

.section-title{
  font-size:clamp(2rem,4vw,2.5rem);
  font-weight:700;
  margin-bottom:3rem;
  background:var(--gradient-primary);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  text-align:center;
  position:relative;
}
.section-title::after{
  content:'';
  position:absolute;
  bottom:-10px;
  left:50%;
  transform:translateX(-50%);
  width:80px;
  height:3px;
  background:var(--gradient-accent);
  border-radius:2px;
}

.text-gradient{
  background:var(--gradient-primary);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}
.card-hover{transition:var(--transition);}
.card-hover:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);}

.custom-navbar{
  background:rgba(12,12,12,.95);
  backdrop-filter:blur(15px);
  transition:var(--transition);
  padding:1rem 0;
  border-bottom:1px solid rgba(255,255,255,.1);
  width:100%;
  left:0;
  top:0;
  box-sizing:border-box;
  overflow:visible;
  min-height:var(--nav-height);
}
.custom-navbar.scrolled{background:rgba(12,12,12,.98);box-shadow:var(--shadow-lg);}

.navbar-brand .brand-text{
  font-size:1.5rem;
  font-weight:700;
  background:var(--gradient-primary);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}

.navbar-nav{
  display:flex;
  flex-direction:row;
  flex-wrap:nowrap;
  gap:.25rem .25rem;
  align-items:center;
  justify-content:flex-start;
  max-width:100%;
}
.navbar-nav .nav-link{
  color:var(--light-color)!important;
  font-weight:500;
  margin:0 .25rem;
  transition:var(--transition);
  position:relative;
  padding:.5rem .85rem!important;
  white-space:nowrap;
  font-size:clamp(.9rem,1.1vw,1rem);
}
.navbar-nav .nav-link::after{
  content:'';
  position:absolute;
  bottom:0;
  left:50%;
  transform:translateX(-50%);
  width:0;
  height:2px;
  background:var(--primary-color);
  transition:var(--transition);
}
.navbar-nav .nav-link:hover::after,
.navbar-nav .nav-link.active::after{width:80%;}
.navbar-nav .nav-link:hover{color:var(--primary-color)!important;}

.language-toggle .form-select.form-select-sm{
  min-width:72px;
  background:transparent;
  color:var(--primary-color);
  border-color:var(--primary-color);
  padding-top:.15rem;
  padding-bottom:.15rem;
}
.language-toggle .form-select.form-select-sm:focus{
  box-shadow:none;
  border-color:var(--accent-color);
  color:var(--accent-color);
}

@media (min-width:992px){
  .navbar .navbar-toggler{display:none!important;}
  html[lang="fr"] .navbar-nav .nav-link[href="#about"]{font-size:.95rem;padding-inline:.8rem!important;}
}

.custom-navbar .navbar-toggler{border:none;padding:.4rem .6rem;outline:none;}
.custom-navbar .navbar-toggler:focus{box-shadow:none;}
.custom-navbar .navbar-toggler .navbar-toggler-icon{
  background-image:none!important;
  width:26px;
  height:2px;
  display:inline-block;
  position:relative;
  background-color:#fff;
  border-radius:2px;
  transition:background-color .2s ease,transform .25s ease;
}
.custom-navbar .navbar-toggler .navbar-toggler-icon::before,
.custom-navbar .navbar-toggler .navbar-toggler-icon::after{
  content:"";
  position:absolute;
  left:0;
  width:26px;
  height:2px;
  background-color:#fff;
  border-radius:2px;
  transition:background-color .2s ease,transform .25s ease,top .25s ease;
}
.custom-navbar .navbar-toggler .navbar-toggler-icon::before{top:-7px;}
.custom-navbar .navbar-toggler .navbar-toggler-icon::after{top:7px;}
.custom-navbar .navbar-toggler:hover .navbar-toggler-icon,
.custom-navbar .navbar-toggler:hover .navbar-toggler-icon::before,
.custom-navbar .navbar-toggler:hover .navbar-toggler-icon::after{background-color:#ffd60a;}
.custom-navbar .navbar-toggler:hover .navbar-toggler-icon{transform:scale(1.08);}
.custom-navbar .navbar-toggler[aria-expanded="true"] .navbar-toggler-icon{background-color:transparent;}
.custom-navbar .navbar-toggler[aria-expanded="true"] .navbar-toggler-icon::before{top:0;transform:rotate(45deg);background-color:#ffd60a;}
.custom-navbar .navbar-toggler[aria-expanded="true"] .navbar-toggler-icon::after{top:0;transform:rotate(-45deg);background-color:#ffd60a;}
@media (prefers-reduced-motion:reduce){
  .custom-navbar .navbar-toggler .navbar-toggler-icon,
  .custom-navbar .navbar-toggler .navbar-toggler-icon::before,
  .custom-navbar .navbar-toggler .navbar-toggler-icon::after{transition:none;}
}

@media (max-width:992px){
  .navbar-collapse{
    position:absolute;
    top:100%;
    left:0;
    width:100vw;
    background:rgba(12,12,12,.99);
    border-bottom:1px solid rgba(255,255,255,.15);
    padding:.75rem 0;
    z-index:999;
  }
  .navbar-collapse.collapse:not(.show){display:none;}
  .navbar-collapse.show{display:block;}

  .navbar-nav{
    width:100%;
    flex-direction:column;
    align-items:center;
    gap:.25rem;
    flex-wrap:nowrap;
  }
  .navbar-nav .nav-link{
    width:100%;
    text-align:center;
    margin:0;
    padding:.65rem .75rem!important;
    font-size:1rem;
  }

  .custom-navbar .navbar-toggler{display:block!important;}
}

@media (min-width:993px){
  .navbar-collapse{
    position:static!important;
    width:auto;
    background:transparent;
    border:0;
    padding:0;
    display:flex!important;
  }
}

.hero-section{
  min-height:calc(100vh - var(--nav-height));
  position:relative;
  display:flex;
  align-items:center;
  overflow:hidden;
  padding:calc(var(--nav-height) + 1rem) 0 2rem;
}
.hero-background{
  position:absolute;
  top:0;
  left:0;
  width:120%;
  height:120%;
  background:linear-gradient(135deg,rgba(0,168,255,.03) 0%,rgba(30,55,153,.03) 50%,rgba(251,197,49,.02) 100%);
  z-index:-2;
  transform:rotate(-5deg);
  animation:float 20s ease-in-out infinite;
  opacity:.05;
}
@keyframes float{
  0%,100%{transform:translateY(0) rotate(0)}
  50%{transform:translateY(-20px) rotate(180deg)}
}

.hero-content{position:relative;z-index:2;}
.hero-title{
  font-size:clamp(2rem,5vw,3.5rem);
  font-weight:700;
  line-height:1.1;
  margin-bottom:1.5rem;
}
.hero-title .greeting{
  display:block;
  font-size:clamp(1rem,2vw,1.2rem);
  font-weight:400;
  color:var(--gray-color);
  margin-bottom:.5rem;
  animation:fadeInUp 1s ease-out .3s both;
}
.hero-title .name{
  display:block;
  background:var(--gradient-primary);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  animation:fadeInUp 1s ease-out .5s both;
}
.hero-title .title{
  display:block;
  font-size:clamp(1.5rem,3vw,2rem);
  color:var(--accent-color);
  animation:fadeInUp 1s ease-out .7s both;
}
.hero-description{
  font-size:clamp(1rem,2vw,1.1rem);
  color:var(--gray-color);
  margin-bottom:2rem;
  max-width:600px;
  animation:fadeInUp 1s ease-out .9s both;
}
.hero-buttons{
  margin-bottom:2rem;
  animation:fadeInUp 1s ease-out 1.1s both;
  display:flex;
  flex-wrap:wrap;
  gap:1rem;
}
.hero-buttons .btn{
  padding:.8rem 2rem;
  font-weight:600;
  border-radius:var(--border-radius);
  transition:var(--transition);
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  white-space:nowrap;
}
.btn-primary{
  background:var(--gradient-primary);
  border:none;
  color:var(--light-color);
}
.btn-primary:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow-lg);
  color:var(--light-color);
}
.btn-outline-light{
  border:2px solid var(--light-color);
  color:var(--light-color);
  background:transparent;
}
.btn-outline-light:hover{
  background:var(--light-color);
  color:var(--dark-color);
  transform:translateY(-2px);
}

.social-links{
  display:flex;
  gap:1rem;
  animation:fadeInUp 1s ease-out 1.3s both;
}
.social-link{
  width:50px;
  height:50px;
  border-radius:50%;
  background:rgba(255,255,255,.1);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--light-color);
  text-decoration:none;
  transition:var(--transition);
  backdrop-filter:blur(10px);
}
.social-link:hover{
  background:var(--primary-color);
  color:var(--light-color);
  transform:translateY(-3px);
  box-shadow:var(--shadow-lg);
}

.hero-image{display:flex;justify-content:center;align-items:center;height:100%;}
.image-container{
  position:relative;
  max-width:400px;
  width:100%;
  animation:fadeInLeft 1s ease-out .5s both;
}
.profile-image{
  width:100%;
  height:auto;
  border-radius:20px;
  box-shadow:var(--shadow-xl);
  position:relative;
  z-index:2;
}
.image-border{
  position:absolute;
  top:-10px;
  left:-10px;
  right:-10px;
  bottom:-10px;
  background:var(--gradient-accent);
  border-radius:25px;
  z-index:1;
  animation:pulse 2s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{transform:scale(1);opacity:.7}
  50%{transform:scale(1.05);opacity:.5}
}

.scroll-indicator{
  position:absolute;
  bottom:30px;
  left:50%;
  transform:translateX(-50%);
  animation:bounce 2s infinite;
  z-index:2;
}
.scroll-arrow{
  width:30px;
  height:30px;
  border:2px solid var(--light-color);
  border-top:none;
  border-left:none;
  transform:rotate(45deg);
}
@keyframes bounce{
  0%,20%,50%,80%,100%{transform:translateX(-50%) translateY(0)}
  40%{transform:translateX(-50%) translateY(-10px)}
  60%{transform:translateX(-50%) translateY(-5px)}
}

@keyframes fadeInUp{
  from{opacity:0;transform:translateY(30px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes fadeInLeft{
  from{opacity:0;transform:translateX(-30px)}
  to{opacity:1;transform:translateX(0)}
}

section{
  padding:5rem 0;
  position:relative;
  scroll-margin-top:calc(var(--nav-height) + 10px);
}
.about-section{background:rgba(255,255,255,.02);}
.skills-section{background:var(--darker-color);}
.projects-section{background:rgba(255,255,255,.02);}
.experience-section{background:var(--darker-color);}
.education-section{background:rgba(255,255,255,.02);}
.contact-section{background:rgba(255,255,255,.02);}

.about-content h3{
  font-size:clamp(1.5rem,3vw,2rem);
  margin-bottom:1.5rem;
  color:var(--accent-color);
}
.about-content p{
  font-size:clamp(1rem,2vw,1.1rem);
  color:var(--gray-color);
  margin-bottom:2rem;
  text-align:justify;
}

.about-stats{
  display:flex;
  gap:2rem;
  flex-wrap:wrap;
  justify-content:flex-start;
}
.stat-item{
  text-align:center;
  min-width:120px;
  transition:var(--transition);
  cursor:pointer;
}
.stat-number{
  display:block;
  font-size:clamp(2rem,4vw,2.5rem);
  font-weight:700;
  background:var(--gradient-accent);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}
.stat-label{
  font-size:.9rem;
  color:var(--gray-color);
  text-transform:uppercase;
  letter-spacing:1px;
}
.stat-item:hover{transform:translateY(-5px) scale(1.05);}
.stat-item:hover .stat-number{
  background:var(--gradient-secondary);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}

.about-image{display:flex;justify-content:center;align-items:center;}
.image-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:1.5rem;
  max-width:300px;
}
.grid-item{
  background:rgba(255,255,255,.05);
  padding:2rem 1rem;
  border-radius:var(--border-radius);
  text-align:center;
  transition:var(--transition);
  backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.1);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:.5rem;
}
.grid-item:hover{
  background:rgba(255,255,255,.1);
  transform:translateY(-5px);
  box-shadow:var(--shadow-lg);
}
.grid-item i{
  font-size:2rem;
  color:var(--primary-color);
  margin-bottom:0;
  line-height:1;
  transition:var(--transition);
  display:block;
}
.grid-item span{
  font-size:.9rem;
  color:var(--light-color);
  font-weight:500;
  transition:var(--transition);
  display:block;
}
.grid-item:hover i{transform:scale(1.2) rotate(5deg);color:var(--accent-color);}
.grid-item:hover span{color:var(--accent-color);font-weight:600;}

.image-grid .grid-item{
  opacity:0;
  transform:translateY(14px) scale(.98);
}
.image-grid.activated .grid-item{
  animation:aboutCardIn .6s cubic-bezier(.22,1,.36,1) forwards;
  animation-delay:var(--reveal-delay,0ms);
}
.image-grid.activated .grid-item i{
  animation:aboutIconIn .55s cubic-bezier(.22,1,.36,1) forwards;
  animation-delay:calc(var(--reveal-delay,0ms) + 80ms);
}
@keyframes aboutCardIn{
  0%{opacity:0;transform:translateY(22px) scale(.9)}
  60%{opacity:1;transform:translateY(-4px) scale(1.04)}
  100%{opacity:1;transform:translateY(0) scale(1)}
}
@keyframes aboutIconIn{
  0%{transform:scale(.65) rotate(-10deg)}
  50%{transform:scale(1.18) rotate(6deg)}
  100%{transform:scale(1) rotate(0)}
}
@media (prefers-reduced-motion:reduce){
  .image-grid .grid-item{opacity:1;transform:none;animation:none!important;}
  .image-grid .grid-item i{animation:none!important;}
}

.project-card{
  background:rgba(255,255,255,.05);
  border-radius:var(--border-radius);
  overflow:hidden;
  transition:var(--transition);
  backdrop-filter:blur(10px);
  height:100%;
  border:1px solid rgba(255,255,255,.1);
}
.project-card:hover{
  transform:translateY(-10px);
  box-shadow:var(--shadow-xl);
  border-color:var(--primary-color);
}
.project-card.expanded{min-height:auto;}
.project-card.expanded .project-content{height:auto;min-height:400px;}

.project-image{
  position:relative;
  overflow:hidden;
  height:200px;
}
.project-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:var(--transition);
}
.project-card:hover .project-image img{transform:scale(1.1);}

.play-button-overlay{
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%,-50%);
  background:#fff;
  color:var(--primary-color);
  width:56px;
  height:56px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  box-shadow:0 0 0 6px var(--primary-color);
  border:2px solid #fff;
  z-index:3;
  transition:box-shadow .2s,background .2s,color .2s;
  padding:0;
  line-height:1;
  font-size:2rem;
}
.play-button-overlay i{font-size:2rem;position:relative;left:3px;}
.play-button-overlay:hover{
  background:var(--primary-color);
  color:#fff;
  box-shadow:0 0 0 8px var(--accent-color);
}

.project-overlay{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,0);
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:0;
  transition:var(--transition);
  z-index:2;
}
.project-card:hover .project-overlay{opacity:1;}

.project-content{
  padding:1.5rem;
  display:flex;
  flex-direction:column;
  height:calc(100% - 200px);
}
.project-content h4{
  margin-bottom:1rem;
  color:var(--accent-color);
  font-size:1.25rem;
}
.project-content p{
  color:var(--gray-color);
  margin-bottom:1.5rem;
  font-size:.95rem;
  flex-grow:1;
  line-height:1.6;
}

.project-tech{
  display:flex;
  flex-wrap:wrap;
  gap:.5rem;
  margin-top:auto;
}
.tech-tag{
  background:rgba(0,168,255,.2);
  color:var(--primary-color);
  padding:.3rem .8rem;
  border-radius:20px;
  font-size:.8rem;
  font-weight:500;
  border:1px solid rgba(0,168,255,.3);
  transition:var(--transition);
  position:relative;
  overflow:hidden;
}
.tech-tag::before{
  content:'';
  position:absolute;
  top:0;
  left:-100%;
  width:100%;
  height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);
  transition:left .5s ease;
}
.tech-tag:hover::before{left:100%;}
.tech-tag:hover{background:var(--primary-color);color:#fff;cursor:pointer;}

.download-pdf-overlay{
  position:absolute;
  top:10px;
  right:10px;
  width:44px;
  height:44px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(251,197,49,.95);
  color:#fff;
  box-shadow:0 0 0 4px rgba(0,0,0,.15);
  cursor:pointer;
  z-index:5;
  opacity:1;
  transform:none;
  transition:transform .2s ease,box-shadow .2s ease,background .2s ease;
}
.project-image .project-overlay.download-pdf-overlay{inset:auto;background:transparent;}
.download-pdf-overlay i{font-size:18px;line-height:1;display:block;}
.download-pdf-overlay:hover{
  background:var(--primary-color);
  box-shadow:0 0 0 6px var(--accent-color);
  transform:scale(1.04);
}

.experience-section h4{
  margin-bottom:2rem;
  color:var(--accent-color);
  font-size:clamp(1.3rem,2.5vw,1.5rem);
}
.timeline{position:relative;padding-left:2rem;}
.timeline::before{
  content:'';
  position:absolute;
  left:15px;
  top:0;
  bottom:0;
  width:2px;
  background:linear-gradient(to bottom,var(--primary-color),var(--accent-color));
}
.timeline-item{position:relative;margin-bottom:2rem;padding-bottom:1rem;}
.timeline-marker{
  position:absolute;
  left:-2rem;
  top:5px;
  width:12px;
  height:12px;
  border-radius:50%;
  background:var(--primary-color);
  border:3px solid var(--dark-color);
  box-shadow:0 0 10px rgba(0,168,255,.5);
}
.timeline-content{
  background:rgba(255,255,255,.05);
  padding:1.5rem;
  border-radius:var(--border-radius);
  border-left:3px solid var(--primary-color);
  transition:all .3s ease;
}
.timeline-item:hover .timeline-content{transform:translateX(5px);box-shadow:var(--shadow-lg);}
.timeline-item:hover .timeline-marker{background:var(--accent-color);box-shadow:0 0 15px rgba(251,197,49,.6);}
.timeline-content h5{color:var(--accent-color);margin-bottom:.5rem;font-size:1.1rem;}
.timeline-company{color:var(--primary-color);font-weight:600;display:block;margin-bottom:.3rem;}
.timeline-date{color:var(--gray-color);font-size:.9rem;display:block;margin-bottom:.8rem;font-style:italic;}
.timeline-content p{color:var(--gray-color);font-size:.95rem;line-height:1.6;margin:0;}

.education-item{
  background:rgba(255,255,255,.05);
  padding:2rem 1.5rem;
  border-radius:var(--border-radius);
  margin-bottom:2rem;
  border-left:4px solid var(--primary-color);
  box-shadow:var(--shadow-sm);
  transition:var(--transition);
}
.education-item:hover{
  box-shadow:var(--shadow-lg);
  border-left-color:var(--accent-color);
  transform:translateY(-4px) scale(1.01);
}
.education-item h4{color:var(--accent-color);margin-bottom:.5rem;font-size:1.2rem;}
.education-school{display:block;color:var(--primary-color);font-weight:600;margin-bottom:.3rem;}
.education-date{color:var(--gray-color);font-size:.95rem;margin-bottom:1rem;display:block;font-style:italic;}
.education-item p{color:var(--gray-color);font-size:.98rem;margin:0;}

.contact-content p{
  font-size:clamp(1rem,2vw,1.1rem);
  color:var(--gray-color);
  margin-bottom:2rem;
  max-width:600px;
  margin-inline:auto;
  text-align:center;
}
.contact-info{
  display:flex;
  justify-content:center;
  gap:2rem;
  margin-bottom:2rem;
  flex-wrap:wrap;
}
.contact-item{
  display:flex;
  align-items:center;
  gap:.5rem;
  color:var(--light-color);
  padding:.5rem 1rem;
  background:rgba(255,255,255,.05);
  border-radius:var(--border-radius);
  transition:var(--transition);
  position:relative;
}
.contact-item:hover{
  background:rgba(255,255,255,.1);
  transform:translateY(-3px);
  box-shadow:var(--shadow-lg);
}
.contact-item::before{
  content:'';
  position:absolute;
  bottom:0;
  left:50%;
  width:0;
  height:2px;
  background:var(--primary-color);
  transition:all .3s ease;
  transform:translateX(-50%);
}
.contact-item:hover::before{width:100%;}
.contact-item i{color:var(--primary-color);width:20px;text-align:center;}
.contact-actions{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap;}

.footer{
  background:var(--darker-color);
  border-top:1px solid rgba(255,255,255,.1);
  padding:2rem 0;
}
.footer p{color:var(--gray-color);margin:0;}
.footer-social{display:flex;gap:1rem;justify-content:flex-end;}
.footer-social .social-link{width:40px;height:40px;font-size:.9rem;}

.scroll-progress-container{
  position:fixed;
  top:0;
  left:0;
  width:100%;
  height:3px;
  background:rgba(255,255,255,.1);
  z-index:10000;
}
.scroll-progress{
  height:100%;
  background:var(--gradient-accent);
  width:0%;
  transition:width .1s ease;
}

.bg-pattern{
  position:absolute;
  inset:0;
  background-image:url('../assets/images/bg-pattern.svg');
  background-repeat:repeat;
  background-size:200px 200px;
  opacity:.03;
  z-index:-1;
  animation:bgPattern 30s linear infinite;
}
@keyframes bgPattern{
  0%{transform:translate(0,0)}
  100%{transform:translate(-200px,-200px)}
}

#particles-js{
  position:fixed;
  inset:0;
  z-index:-10;
  pointer-events:none;
  background:transparent;
}
.hero-section,.about-section,.skills-section,.projects-section,.experience-section,.contact-section{position:relative;z-index:1;}
.about-section,.skills-section,.projects-section,.experience-section,.contact-section{backdrop-filter:blur(.5px);}
.project-card:hover,.contact-item:hover,.grid-item:hover{backdrop-filter:blur(2px);border:1px solid rgba(0,168,255,.2);}

.project-video,.project-preview-img{
  width:100%;
  height:200px;
  object-fit:cover;
  cursor:pointer;
  transition:transform .3s ease;
}
.project-video{
  display:none;
  border-radius:var(--border-radius);
}
.project-video:focus{outline:2px solid var(--primary-color);outline-offset:2px;}
video{transition:all .5s ease-in-out;}

.video-modal{
  border:none;
  padding:0;
  background:transparent;
  width:600px;
  max-width:95vw;
  box-shadow:0 8px 40px rgba(0,0,0,.7);
  border-radius:20px;
  position:fixed;
  top:50%;
  left:50%;
  transform:translate(-50%,-50%);
  overflow:visible;
  z-index:9999;
  outline:none;
  animation:fadeInModal .3s;
}
@keyframes fadeInModal{
  from{opacity:0;transform:translate(-50%,-60%)}
  to{opacity:1;transform:translate(-50%,-50%)}
}
.video-modal::before{
  content:'';
  position:absolute;
  inset:-8px;
  border-radius:28px;
  border:4px solid var(--primary-color);
  pointer-events:none;
  z-index:10;
  animation:pulse-modal 1.5s infinite;
}
@keyframes pulse-modal{
  0%,100%{box-shadow:0 0 0 0 var(--primary-color);opacity:.7}
  50%{box-shadow:0 0 24px 8px var(--accent-color);opacity:.4}
}
.video-modal-close{
  position:absolute;
  top:10px;
  right:15px;
  background:rgba(0,0,0,.5);
  color:#fff;
  border:none;
  font-size:2rem;
  line-height:1;
  border-radius:50%;
  width:40px;
  height:40px;
  cursor:pointer;
  z-index:20;
  transition:background .2s;
  display:flex;
  align-items:center;
  justify-content:center;
}
.video-modal-close:hover{background:var(--primary-color);}
.video-modal video{
  display:block;
  width:100%;
  max-height:70vh;
  background:#000;
  border-radius:16px;
  margin:0;
  box-shadow:0 2px 16px rgba(0,0,0,.6);
}

.btn:focus,
.nav-link:focus,
.social-link:focus,
.video-modal:focus,
.video-modal-close:focus,
.play-button-overlay:focus{
  outline:2px solid var(--primary-color);
  outline-offset:2px;
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:.01ms!important;
  }
}
@media (prefers-contrast:high){
  :root{
    --primary-color:#0066cc;
    --secondary-color:#004499;
    --accent-color:#ff6600;
  }
}

@media (min-width:1201px){
  .container{max-width:var(--container-max-width);padding:0 1rem;}
}
@media (min-width:1201px) and (max-width:1400px){
  .navbar-nav .nav-link{padding:.5rem .65rem!important;font-size:.95rem;}
  .language-toggle .form-select.form-select-sm{min-width:72px;}
}

@media (min-width:993px) and (max-width:1200px){
  .container{max-width:100%;padding:0 2rem;}
  .hero-section{text-align:center;}
  .hero-content{margin-inline:auto;max-width:700px;}
  .hero-description{margin:0 auto 2rem;}
  .hero-buttons{justify-content:center;}
  .social-links{justify-content:center;}
  .navbar-nav{gap:.1rem .1rem;}
  .navbar-nav .nav-link{padding:.45rem .6rem!important;font-size:.95rem;}
}

@media (max-width:992px){
  section{padding:3rem 0;}
  .container{max-width:100%;padding:0 2rem;}

  .hero-section{text-align:center;padding:calc(var(--nav-height) + .5rem) 0 2rem;}
  .hero-content{margin-bottom:2rem;margin-inline:auto;}
  .hero-title,.hero-description{text-align:center;}
  .hero-description{margin-left:auto;margin-right:auto;}
  .hero-buttons{justify-content:center;}
  .social-links{justify-content:center;}

  .about-stats{justify-content:center;}
  .contact-info{flex-direction:column;align-items:center;}
  .contact-actions{flex-direction:column;align-items:center;}
  .footer-social{justify-content:center;margin-top:1rem;}
  .timeline{padding-left:1.5rem;}
  .timeline-marker{left:-1.5rem;}
}

@media (max-width:768px){
  .container{padding:0 1rem;}
  .hero-section{padding:calc(var(--nav-height) + .25rem) 0 50px;min-height:auto;}
  .hero-title .name{font-size:2.2rem;}
  .hero-title .title{font-size:1.5rem;}
  .hero-description{font-size:1rem;margin:0 auto 1.5rem;max-width:100%;}
  .hero-buttons .btn{width:100%;max-width:300px;justify-content:center;}
  .image-container{max-width:300px;margin:0 auto;}
  .scroll-indicator{bottom:20px;}
  .about-stats{gap:1rem;justify-content:space-around;}
  .stat-item{flex:1;min-width:80px;}
  .image-grid{grid-template-columns:1fr;max-width:200px;}
  .navbar-nav{text-align:center;padding:1rem 0;}
  .navbar-nav .nav-link{padding:.5rem 0!important;margin:0;}
  .project-tech{justify-content:center;}
  .contact-item{font-size:.9rem;flex-direction:column;text-align:center;padding:1rem;}
  .project-details{padding:.8rem;}
  .project-details li{font-size:.8rem;}
  .project-video{height:180px;}
  .contact-item span{font-size:.9rem;word-break:break-word;}
  .bg-pattern{background-size:150px 150px;opacity:.02;}
}

@media (max-width:576px){
  .hero-section{padding:calc(var(--nav-height) - 8px) 0 40px;min-height:auto;}
  .hero-title{font-size:1.5rem;}
  .hero-title .name{font-size:1.8rem;}
  .hero-title .title{font-size:1.2rem;}
  .hero-description{font-size:.9rem;}
  .hero-buttons .btn{padding:.7rem 1.5rem;font-size:.9rem;}
  .social-link{width:42px;height:42px;font-size:.9rem;}
  .image-container{max-width:250px;}
  .scroll-indicator{display:none;}
  .timeline-content{padding:1rem;}
  .project-details ul{padding-left:1rem;}
  .project-details li::before{left:-.8rem;}
  .tech-tag{font-size:.75rem;padding:.25rem .6rem;}
  .bg-pattern{background-size:100px 100px;opacity:.015;}
}

@media (max-width:768px){#particles-js{opacity:1}}
@media (max-width:576px){#particles-js{opacity:1}}

.multimedia-section .mm-card{
  background:rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.1);
  border-radius:16px;
  padding:1.5rem;
  box-shadow:var(--shadow-lg);
  text-align:initial;
}
.mm-desc{color:var(--gray-color);margin-bottom:1rem;line-height:1.6;}

.mm-tags{
  display:flex;
  flex-wrap:wrap;
  gap:.5rem;
  margin-bottom:1rem;
  justify-content:center;
}
.mm-actions{
  display:flex;
  flex-wrap:wrap;
  gap:1rem;
  justify-content:center;
}
@media (max-width:992px){.mm-actions .btn{min-width:220px;}}
@media (max-width:576px){.mm-actions .btn{width:100%;max-width:320px;}}

.mm-media{
  border-radius:16px;
  overflow:hidden;
  margin-bottom:1.25rem;
  box-shadow:var(--shadow-lg);
  background:#000;
  aspect-ratio:16/9;
}
.mm-media .mm-video{display:block;width:100%;height:100%;object-fit:contain;}
.mm-fallback{display:none!important;width:100%;height:100%;object-fit:contain;}
.mm-media.video-hidden .mm-video{display:none!important;}
.mm-media.video-hidden .mm-fallback{display:block!important;}

.skills-section{
  background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.02));
  position:relative;
}
.skills-section .skill-title{
  margin:.35rem 0 1rem;
  text-align:center;
  color:var(--accent-color);
  font-weight:700;
}
.skills-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:1.25rem;
  align-items:start;
}
@media (max-width:767.98px){
  .skills-grid{
    grid-template-columns:1fr;
    gap:1rem;
  }
}

.skill-card{
  position:relative;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  border-radius:20px;
  padding:1.2rem 1rem 1.1rem;
  box-shadow:var(--shadow-lg);
  overflow:hidden;
  transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;
}
.skill-card::before{
  content:"";
  position:absolute;
  inset:-1px;
  border-radius:inherit;
  background:
    radial-gradient(120px 80px at 20% -10%,rgba(79,172,254,.25),transparent 60%),
    radial-gradient(160px 120px at 110% 10%,rgba(246,211,101,.18),transparent 60%);
  pointer-events:none;
  z-index:0;
}
.skill-card:hover{
  transform:translateY(-4px);
  box-shadow:0 16px 40px rgba(0,0,0,.25);
  border-color:rgba(0,168,255,.35);
}

.skill-card-head{
  position:relative;
  z-index:1;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  margin-bottom:.75rem;
}
.skill-icon{
  width:68px;
  height:68px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(0,168,255,.14);
  box-shadow:inset 0 8px 24px rgba(0,168,255,.25),0 8px 22px rgba(0,0,0,.28);
  border:1px solid rgba(255,255,255,.18);
  position:relative;
  transition:transform .25s ease,box-shadow .25s ease;
}
.skill-icon::after{
  content:"";
  position:absolute;
  inset:2px;
  border-radius:inherit;
  padding:2px;
  background:conic-gradient(#4facfe,#00f2fe,#fbc531,#764ba2,#4facfe);
  mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  mask-composite:exclude;
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;
}
.skill-icon i{
  font-size:28px;
  color:#fff;
  filter:drop-shadow(0 0 6px rgba(79,172,254,.8));
}
.skill-card:hover .skill-icon{
  transform:scale(1.06);
  box-shadow:inset 0 10px 26px rgba(0,168,255,.32),0 10px 26px rgba(0,0,0,.3);
}

.skill-list{position:relative;z-index:1;}
.skill-item{margin-bottom:1rem;}
.skill-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:.35rem;
}
.skill-header span:first-child{
  font-weight:600;
  letter-spacing:.2px;
  color:var(--light-color);
}
.skill-header span:last-child{
  font-weight:700;
  font-size:.8rem;
  color:var(--primary-color);
  background:rgba(0,168,255,.15);
  border:1px solid rgba(0,168,255,.35);
  padding:.15rem .55rem;
  border-radius:999px;
}
.skill-bar{
  height:8px;
  background:rgba(255,255,255,.12);
  border-radius:10px;
}
.skill-progress{
  height:100%;
  border-radius:inherit;
  width:0;
  background:linear-gradient(90deg,#4facfe,#00f2fe);
  position:relative;
  overflow:hidden;
  box-shadow:0 0 12px rgba(0,168,255,.35);
}
.skill-progress::after{
  content:"";
  position:absolute;
  top:0;
  left:-40%;
  width:40%;
  height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.35),transparent);
  animation:skill-shine 2.2s ease-in-out infinite;
}
@keyframes skill-shine{
  0%{left:-40%}
  100%{left:120%}
}
@media (max-width:576px){
  .skill-header span:last-child{font-size:.75rem;}
  .skill-bar{height:9px;}
}

/* FIX : Skills Section Media */

.skills-grid {
    display: block; 
    column-count: 3; 
    column-gap: 1.5rem; 
    width: 100%;
}

.skill-card {
    break-inside: avoid; 
    -webkit-break-inside: avoid;
    margin-bottom: 1.5rem; 
    
    display: inline-block; 
    width: 100%;
    
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 20px;
    padding: 1.2rem 1rem 1.1rem;
    box-shadow: var(--shadow-lg);
    position: relative;
    overflow: hidden;
    
    opacity: 0;
    transform: translateY(30px);
    transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease, opacity 0.6s ease-out;
}

.skill-card.visible {
    opacity: 1;
    transform: translateY(0);
}

@media (max-width: 992px) {
    .skills-grid {
        column-count: 2; 
    }
}

@media (max-width: 576px) {
    .skills-grid {
        column-count: 1; 
    }
}

.skill-card {
    break-inside: avoid;
    -webkit-break-inside: avoid;
    margin-bottom: 1.5rem;
    display: inline-block;
    width: 100%;
    
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 20px;
    padding: 1.2rem 1rem 1.1rem;
    box-shadow: var(--shadow-lg);
    position: relative;
    overflow: hidden;
    
    opacity: 0;
    transform: translateY(40px); 
    
    transition: opacity 0.8s cubic-bezier(0.22, 1, 0.36, 1), 
                transform 0.8s cubic-bezier(0.22, 1, 0.36, 1);
}

.skill-card.visible {
    opacity: 1;
    transform: translateY(0);
}

.skill-card.loaded {
    transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
}

.skill-card.loaded:hover {
    transform: translateY(-5px);
    box-shadow: 0 16px 40px rgba(0,0,0,0.25);
    border-color: rgba(0, 168, 255, 0.35);
}

.skill-progress {
    height: 100%;
    border-radius: inherit;
    width: 0; 
    background: linear-gradient(90deg, #4facfe, #00f2fe);
    position: relative;
    overflow: hidden;
    box-shadow: 0 0 12px rgba(0, 168, 255, 0.35);
    
    transition: width 1.5s cubic-bezier(0.22, 1, 0.36, 1);
}

/* --- MEJORAS VISUALES SECCIÓN MULTIMEDIA --- */

.multimedia-section .mm-card {
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 24px; 
    padding: 2rem;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
    text-align: left; 
}

.multimedia-section .mm-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 12px 40px rgba(0, 168, 255, 0.1); 
    border-color: rgba(0, 168, 255, 0.3);
}

.mm-card ul {
    list-style: none;
    padding-left: 0;
    margin: 1.5rem 0;
}

.mm-card li {
    position: relative;
    padding-left: 1.8rem; 
    margin-bottom: 0.8rem;
    color: var(--gray-color);
    font-size: 1rem;
    line-height: 1.6;
}

.mm-card li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 10px; 
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--gradient-accent);
    box-shadow: 0 0 8px rgba(79, 172, 254, 0.8); 
}

.mm-card li strong {
    color: var(--light-color);
    font-weight: 600;
    margin-right: 4px;
}

.mm-media {
    border-radius: 16px;
    overflow: hidden;
    margin: 2rem 0;
    border: 1px solid rgba(255, 255, 255, 0.1);
    box-shadow: var(--shadow-lg);
    transition: all 0.3s ease;
}

.mm-media:hover {
    border-color: rgba(0, 168, 255, 0.4);
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5);
}

.mm-tags .tech-tag {
    padding: 0.5rem 1rem;
    background: rgba(0, 168, 255, 0.08);
    border: 1px solid rgba(0, 168, 255, 0.2);
    font-size: 0.9rem;
}

.mm-tags .tech-tag:hover {
    background: var(--primary-color);
    color: #fff;
    transform: translateY(-2px);
    box-shadow: 0 4px 15px rgba(0, 168, 255, 0.3);
}

.multimedia-section .mm-card h4 {
    text-align: center; 
    font-size: 1.8rem; 
    margin-bottom: 1.5rem;
    
    background: var(--gradient-primary);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    
    filter: drop-shadow(0 2px 4px rgba(0,0,0,0.3));
}

.multimedia-section .mm-card {    
    box-shadow: 
        0 10px 30px -5px rgba(0, 0, 0, 0.5), 
        0 0 0 1px rgba(255, 255, 255, 0.05) inset; 
        
    transform-style: preserve-3d; 
    perspective: 1000px;
}

.multimedia-section .mm-desc {
    text-align: center; 
    max-width: 800px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 2rem;
}

.multimedia-section .mm-card ul {
    display: table; 
    margin: 0 auto 2rem auto;
    max-width: 850px;
}

/* ===== Alpha Finance ===== */

.alpha-finance-section {
  position: relative;
  padding: 5rem 0;
}

.alpha-finance-section .section-title {
  background: linear-gradient(135deg, #395c83 0%, #548C92 40%, #6ccfd1 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.alpha-finance-section .section-title::after {
  background: linear-gradient(135deg, #395c83 0%, #6ccfd1 50%, #e1e7e5 100%);
}

.alpha-card {
  position: relative;
  max-width: 1320px;
  min-height: 560px;
  margin: 0 auto;
  border-radius: 30px;
  padding: 3.5rem 3.25rem 3.25rem;
  overflow: hidden;
  background: #e1e7e5; 
  border: 1px solid rgba(57, 92, 131, 0.25);
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.32);
  text-align: left;

  transform-origin: top center;
  transform: scale(0.95);          
  transition: transform 0.6s ease;
}

.alpha-card::before {
  content: "";
  position: absolute;
  inset: -18%;
  border-radius: inherit;
  background-color: #e1e7e5;
  background-image:
    radial-gradient(ellipse at 20% 80%, rgba(84, 140, 146, 0.55) 0%, transparent 55%),
    radial-gradient(ellipse at 80% 20%, rgba(74, 92, 126, 0.55) 0%, transparent 60%),
    radial-gradient(ellipse at 40% 40%, rgba(108, 207, 209, 0.75) 0%, transparent 65%);
  animation: alpha-bg-morph-light 18s ease-in-out infinite alternate;
  z-index: 0;
}

.alpha-card > * {
  position: relative;
  z-index: 1;
}

.alpha-hero {
  position: static;
  margin-bottom: 2.2rem;
  min-height: 260px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
}

.alpha-loader {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem 2.5rem;
  background: #ffffff;
  z-index: 5;
  opacity: 1;
  transition: opacity 0.6s ease;
}

.alpha-loader-gif {
  width: 100%;
  max-width: 980px;
  height: auto;
  object-fit: contain;
  border-radius: 0;
  box-shadow: none;
}

.alpha-logo-content {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  opacity: 0;
  transform: translateY(14px);
  transition: opacity 0.6s 0.1s ease, transform 0.6s 0.1s ease;
}

.alpha-logo-img {
  max-width: 230px;
  height: auto;
  margin-bottom: 1rem;
}

.alpha-logo-desc {
  max-width: 580px;
  font-size: 0.95rem;
  color: #334a63;
}

.alpha-card.alpha-loaded {
  transform: scale(1); 
}

.alpha-card.alpha-loaded .alpha-loader {
  opacity: 0;         
  pointer-events: none;
}

.alpha-card.alpha-loaded .alpha-logo-content {
  opacity: 1;
  transform: translateY(0);
}

.alpha-main-title {
  text-align: center;
  font-size: 2.2rem;
  margin-bottom: 2rem;
  background: linear-gradient(135deg, #395c83 0%, #1e6263 45%, #6ccfd1 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}


.alpha-info-card {
  position: relative;
  border-radius: 20px;
  padding: 1.7rem 1.9rem;
  background: rgba(241, 248, 252, 0.78); 
  border: 1px solid rgba(255, 255, 255, 0.9);
  box-shadow: 0 18px 45px rgba(0, 0, 0, 0.30);
  backdrop-filter: blur(18px) saturate(140%);
  -webkit-backdrop-filter: blur(18px) saturate(140%);
  color: #123047;
}

.alpha-info-main {
  margin-bottom: 2.1rem;
}

.alpha-info-card h5,
.alpha-subtitle {
  font-size: 1.15rem;
  font-weight: 700;
  margin-bottom: 0.9rem;
  color: #123047;
}

.alpha-info-card p,
.alpha-info-main .alpha-desc {
  font-size: 0.96rem;
  line-height: 1.6;
  color: #123047;
  margin-bottom: 0.85rem;
}

.alpha-bullets {
  list-style: none;
  padding-left: 0;
  margin: 0.5rem 0 0.9rem 0;
}

.alpha-bullets li {
  position: relative;
  padding-left: 1.7rem;
  margin-bottom: 0.45rem;
  font-size: 0.95rem;
  line-height: 1.5;
}

.alpha-bullets li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.55em;
  width: 0.7rem;
  height: 0.7rem;
  border-radius: 999px;
  background: radial-gradient(circle at 30% 30%, #ffffff 0%, #6ccfd1 35%, #395c83 100%);
  box-shadow: 0 0 0 3px rgba(108, 207, 209, 0.35);
}

.alpha-subcards {
  margin-top: 0.5rem;
}

.alpha-actions {
  margin-top: 0.8rem;
}

.alpha-actions .btn {
  border-radius: 999px;
  padding: 0.75rem 2.1rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  font-size: 0.95rem;
  transition: transform 0.18s ease, box-shadow 0.18s ease, filter 0.18s ease;
}

/* Botón ghost claro */
.alpha-btn-ghost {
  background: rgba(241, 248, 252, 0.95);
  border: 1px solid #395c83;
  color: #223048;
}

.alpha-btn-ghost:hover {
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.22);
  transform: translateY(-1px);
}

.alpha-btn-primary {
  background: linear-gradient(135deg, #6ccfd1 0%, #395c83 100%);
  border: 0;
  color: #ffffff;
  box-shadow: 0 16px 38px rgba(23, 72, 117, 0.55);
}

.alpha-btn-primary:hover {
  filter: brightness(1.06);
  transform: translateY(-1px);
}

/* Animación del fondo */
@keyframes alpha-bg-morph-light {
  0%, 100% {
    background-position: 18% 82%, 82% 22%, 42% 42%;
    background-size: 58% 58%, 58% 58%, 60% 60%;
  }
  50% {
    background-position: 80% 24%, 22% 78%, 60% 60%;
    background-size: 68% 68%, 68% 68%, 72% 72%;
  }
}

/* Responsivo */
@media (max-width: 992px) {
  .alpha-card {
    padding: 2.6rem 1.7rem 2.4rem;
  }

  .alpha-main-title {
    font-size: 1.8rem;
  }

  .alpha-logo-img {
    max-width: 190px;
  }
}

@media (max-width: 768px) {
  .alpha-loader {
    padding: 1.5rem;
  }

  .alpha-loader-gif {
    max-width: 100%;
  }
}

@media (max-width: 768px) {
  #alpha-finance .alpha-card {
    min-height: auto;
    padding: 2.4rem 1.4rem 2.2rem;
    transform: none; 
  }

  #alpha-finance .alpha-loader,
  #alpha-finance .alpha-loader-gif {
    display: none !important;
    opacity: 0 !important;
    pointer-events: none !important;
  }

  #alpha-finance .alpha-logo-content {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (min-width: 992px) {
  .alpha-subcards > [class^="col-"],
  .alpha-subcards > [class*=" col-"] {
    display: flex;
  }

  .alpha-subcards .alpha-info-card {
    display: flex;
    flex-direction: column;
    height: 100%;
  }
}

@media (min-width: 992px) {
  .alpha-subcards > .col-lg-6:last-child .alpha-info-card {
    display: flex;
    flex-direction: column;
    justify-content: center; 
  }

  .alpha-subcards > .col-lg-6:last-child .alpha-info-card h5 {
    margin-bottom: 0.8rem;
  }

  .alpha-subcards > .col-lg-6:last-child .alpha-info-card p {
    margin-bottom: 1.1rem;
  }

  .alpha-subcards > .col-lg-6:last-child .alpha-info-card .alpha-bullets {
    margin-bottom: 0;
  }
}

section p,
section li {
  text-align: justify;
  text-justify: inter-word; 
}

.contact-content p {
  text-align: center;
}
