:root {
  --purple-deep: #1a0533; /* sidebar bg */
  --purple-header: #2d1b69; /* header bg  */
  --purple-black: #0d001a; /* footer     */
  --purple-main: #6d28d9; /* títulos / accent principal */
  --purple-light: #a78bfa; /* subtítulos sidebar */
  --purple-pale: #ede9fe; /* fondo main / sobre mí */
  --purple-muted: #c4b5fd; /* texto sidebar */
  --accent-gold: #f4d03f; /* detalles dorados */
}

body {
  background-color: var(--purple-black);
}

.cv-wrapper {
  max-width: 960px;
  background: #fff;
}

.cv-header {
  background-color: var(--purple-header);
}

.cv-cargo {
  color: var(--purple-light);
  font-size: 0.85rem;
  letter-spacing: 3px;
}

.photo-box {
  width: 160px;
  height: 160px;
  min-width: 160px;
  background-color: var(--purple-main);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 72px;
  color: rgba(255, 255, 255, 0.5);
  overflow: hidden;
}
.photo-box img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.sidebar {
  background-color: var(--purple-deep);
  min-height: 100%;
}

.sidebar-title {
  color: var(--purple-light);
  letter-spacing: 2px;
  font-size: 0.75rem;
}

.sidebar-subtitle {
  color: var(--purple-light);
}

.sidebar-divider {
  border-color: rgba(167, 139, 250, 0.2);
  margin: 0.75rem 0;
}

.icon-accent {
  color: var(--purple-light);
}

.lang-bar {
  height: 6px;
  border-radius: 3px;
  background-color: rgba(167, 139, 250, 0.2);
}
.lang-fill {
  background-color: var(--purple-light) !important;
}
.lang-level {
  color: var(---purple-light);
  font-size: 0.82rem;
}

.kitty-btn {
  background-color: var(--purple-main);
  color: #fff;
  border: none;
  transition: background-color 0.2s;
}
.kitty-btn:hover {
  background-color: var(--purple-light);
  color: var(--purple-deep);
}

.cv-main {
  background-color: #faf8ff;
}

.main-title {
  color: var(--purple-main);
  letter-spacing: 2px;
  font-size: 0.75rem;
}

.section-divider {
  border-top: 2px solid var(--purple-main);
}

.sobre-mi-box {
  background-color: var(--purple-pale);
  border-left: 4px solid var(--purple-main);
  padding: 12px 16px;
  border-radius: 0 6px 6px 0;
  color: #2d1b69;
}

.edu-title {
  color: var(--purple-deep);
}

.edu-inst {
  color: var(--purple-main);
}

.cv-footer {
  background-color: var(--purple-black);
  color: rgba(196, 181, 253, 0.6);
  font-family: "Montserrat", sans-serif;
  letter-spacing: 1px;
  font-size: 0.75rem;
}

.font-montserrat {
  font-family: "Montserrat", sans-serif;
}

#cat-overlay {
  position: fixed;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
}

.cat-container {
  position: absolute;
  bottom: 150px;
}

.cat {
  position: absolute;
  width: 140px;
  image-rendering: auto;

  animation: jump 1s ease-in-out infinite;
}

#party-lights {
  position: fixed;
  inset: 0;
  pointer-events: none;

  background:
    radial-gradient(circle, #ff00ff55, transparent 80%),
    radial-gradient(circle, #00ffff55, transparent 60%),
    radial-gradient(circle, #ffff0055, transparent 95%);

  mix-blend-mode: screen;

  animation: lights 6s linear infinite;
}

@keyframes lights {
  0% {
    filter: hue-rotate(0deg);
    transform: translateX(0);
  }

  100% {
    filter: hue-rotate(360deg);
    transform: translateX(100px);
  }
}

@keyframes jump {
  0% {
    transform: translateY(0) scaleX(calc(var(--dir) * 1.15)) scaleY(0.85);
  }
  10% {
    transform: translateY(10px) scaleX(calc(var(--dir) * 0.9)) scaleY(1.1);
  }
  40% {
    transform: translateY(-120px) scaleX(calc(var(--dir) * 1)) scaleY(1);
  }
  70% {
    transform: translateY(0px) scaleX(calc(var(--dir) * 1.2)) scaleY(0.8);
  }
  82% {
    transform: translateY(-25px) scaleX(calc(var(--dir) * 0.95)) scaleY(1.05);
  }
  100% {
    transform: translateY(0) scaleX(calc(var(--dir) * 1.1)) scaleY(0.9);
  }
}

.cat:nth-child(2) {
  animation-duration: 0.8s, 1.6s;
}

.cat:nth-child(3) {
  animation-duration: 1.2s, 2.4s;
}

.cat:nth-child(4) {
  animation-duration: 0.9s, 1.8s;
}

.cat:nth-child(5) {
  animation-duration: 1.1s, 2.2s;
}
