/* =============================================
    AJUSTES ESPECÍFICOS PARA ELEMENTOS EXISTENTES
    ============================================= */

/* Asegurar que elementos específicos tengan neumorphism */

/* Menu mobile button */
.mobile-menu-btn {
  background: var(--neuro-surface);
  box-shadow: var(--neuro-shadow-sm);
  border-radius: 8px;
  transition: all 0.3s ease;
}

.mobile-menu-btn:hover {
  box-shadow: var(--neuro-shadow-md);
  transform: translateY(-2px);
}

/* Language selector */
.language-selector {
  background: var(--neuro-surface);
  box-shadow: var(--neuro-shadow-sm);
  border-radius: 20px;
  transition: all 0.3s ease;
}

.language-selector:hover {
  box-shadow: var(--neuro-shadow-md);
  transform: translateY(-2px);
}

/* Stats numbers */
.stat-number {
  background: var(--neuro-surface);
  box-shadow: var(--neuro-shadow-md);
  border-radius: 15px;
  padding: 1.5rem;
  text-align: center;
  transition: all 0.3s ease;
}

.stat-number:hover {
  box-shadow: var(--neuro-shadow-lg);
  transform: translateY(-5px);
}

/* Technology badges */
.tech-badge {
  background: var(--neuro-surface);
  box-shadow: var(--neuro-shadow-sm);
  border-radius: 25px;
  padding: 0.5rem 1rem;
  transition: all 0.3s ease;
  display: inline-block;
  margin: 0.25rem;
}

.tech-badge:hover {
  box-shadow: var(--neuro-shadow-md);
  transform: translateY(-2px);
  color: var(--primary-color);
}

/* Download CV button enhancement */
.btn[href*="cv"], .btn[href*="CV"] {
  position: relative;
  overflow: hidden;
}

.btn[href*="cv"]::after, .btn[href*="CV"]::after {
  content: '⬇';
  position: absolute;
  right: 1rem;
  opacity: 0;
  transition: all 0.3s ease;
  transform: translateY(-10px);
}

.btn[href*="cv"]:hover::after, .btn[href*="CV"]:hover::after {
  opacity: 1;
  transform: translateY(0);
}

/* Social links specific */
.social-links a {
  background: var(--neuro-surface);
  box-shadow: var(--neuro-shadow-sm);
  border-radius: 50%;
  width: 45px;
  height: 45px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
  color: var(--text-color);
}

.social-links a:hover {
  box-shadow: var(--neuro-shadow-md);
  transform: translateY(-3px);
  color: var(--primary-color);
}

.social-links a:active {
  box-shadow: var(--neuro-inset-sm);
  transform: translateY(0);
}

/* Form inputs if they exist */
input[type="text"],
input[type="email"], 
input[type="tel"],
textarea {
  background: var(--neuro-bg);
  box-shadow: var(--neuro-inset-sm);
  border: none;
  border-radius: 15px;
  padding: 1rem 1.5rem;
  color: var(--text-color);
  transition: all 0.3s ease;
  font-family: inherit;
}

input[type="text"]:focus,
input[type="email"]:focus, 
input[type="tel"]:focus,
textarea:focus {
  box-shadow: 
    var(--neuro-inset-md),
    0 0 0 2px var(--primary-color);
  outline: none;
}

/* Section dividers */
.section::before {
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 90%;
  height: 1px;
  background: linear-gradient(90deg, 
    transparent, 
    var(--neuro-shadow-light), 
    transparent);
}

/* Ensure existing elements work with new system */
.experience-card,
.education-card,
.skill-card {
  background: var(--neuro-surface);
  box-shadow: var(--neuro-shadow-md);
  border-radius: 20px;
  padding: 2rem;
  transition: all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.experience-card:hover,
.education-card:hover,
.skill-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--neuro-shadow-lg);
}

/* Timeline elements if they exist */
.timeline-item {
  position: relative;
}

.timeline-item::before {
  content: '';
  position: absolute;
  left: -30px;
  top: 20px;
  width: 15px;
  height: 15px;
  background: var(--primary-color);
  border-radius: 50%;
  box-shadow: var(--neuro-shadow-sm);
}

.timeline-item::after {
  content: '';
  position: absolute;
  left: -23px;
  top: 35px;
  width: 1px;
  height: calc(100% - 35px);
  background: linear-gradient(180deg, 
    var(--primary-color), 
    transparent);
}

/* Progress bars enhancement */
.progress-bar {
  background: var(--neuro-bg);
  box-shadow: var(--neuro-inset-sm);
  border-radius: 10px;
  height: 10px;
  overflow: hidden;
  position: relative;
}

.progress-fill {
  background: linear-gradient(90deg, 
    var(--primary-color), 
    var(--primary-dark));
  height: 100%;
  border-radius: 10px;
  position: relative;
  box-shadow: 
    0 0 10px rgba(0, 170, 255, 0.3);
}

.progress-fill::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(90deg, 
    transparent, 
    rgba(255, 255, 255, 0.4), 
    transparent);
  animation: progressShine 2s ease-in-out infinite;
}

@keyframes progressShine {
  0% { transform: translateX(-100%); }
  100% { transform: translateX(100%); }
}

/* Scroll to top button */
.scroll-top {
  background: var(--neuro-surface);
  box-shadow: var(--neuro-shadow-lg);
  border-radius: 50%;
  width: 50px;
  height: 50px;
  position: fixed;
  bottom: 2rem;
  right: 2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
  border: none;
  color: var(--primary-color);
  cursor: pointer;
  z-index: 1000;
}

.scroll-top:hover {
  box-shadow: var(--neuro-shadow-lg);
  transform: translateY(-5px) scale(1.1);
}

.scroll-top:active {
  box-shadow: var(--neuro-inset-sm);
  transform: translateY(-2px) scale(1.05);
}

/* Tooltips */
[data-tooltip] {
  position: relative;
}

[data-tooltip]:hover::after {
  content: attr(data-tooltip);
  position: absolute;
  bottom: 120%;
  left: 50%;
  transform: translateX(-50%);
  background: var(--neuro-surface);
  box-shadow: var(--neuro-shadow-md);
  border-radius: 8px;
  padding: 0.5rem 1rem;
  font-size: 0.9rem;
  white-space: nowrap;
  z-index: 1000;
  animation: tooltipFade 0.3s ease;
}

@keyframes tooltipFade {
  0% { opacity: 0; transform: translateX(-50%) translateY(10px); }
  100% { opacity: 1; transform: translateX(-50%) translateY(0); }
}

/* Loading states */
.loading {
  background: var(--neuro-surface);
  box-shadow: var(--neuro-shadow-sm);
  border-radius: 10px;
  position: relative;
  overflow: hidden;
}

.loading::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, 
    transparent, 
    rgba(255, 255, 255, 0.2), 
    transparent);
  animation: loadingShimmer 2s ease-in-out infinite;
}

@keyframes loadingShimmer {
  0% { left: -100%; }
  100% { left: 100%; }
}