@import url("https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Ubuntu:ital,wght@0,300;0,400;0,500;0,700;1,300;1,400;1,500;1,700&display=swap");

.arrow-down {
  display: inline-block;
  font-size: 1.8rem;
  margin-top: 0.6rem;
  animation: blink 1.2s infinite;
}

.btn-content {
  display: flex;
  align-items: center;
  gap: 10px;
  position: relative;
  z-index: 2;
}

/* Solo mostrar el botón de inscripción en desktop */
.btn-desktop-only {
  display: none;
}

@media (min-width: 1024px) {
  .btn-desktop-only {
    display: flex;
  }
}

/* Ajustes para el wizard en dispositivos móviles */
@media (max-width: 768px) {
  .login-sec-bg p {
    font-size: 1rem;
    margin: 10px 0;
  }
}
/* Ajustes para dispositivos ultra pequeños */
@media (max-width: 480px) {
  .login-sec-bg p {
    font-size: 0.9rem;
    margin: 8px 0;
  }
}

.timeline-section {
  background: linear-gradient(to bottom, #f3f3f3 0%, #ececec 100%);
  padding: 4rem 1rem 0;
  text-align: center;
  position: relative;
}

.timeline {
  display: flex;
  justify-content: center;
  gap: 1.5rem;
  flex-wrap: wrap;
  margin-top: 2rem;
}

.timeline-item {
  background: #fff;
  padding: 1.2rem;
  border-radius: 12px;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.05);
  min-width: 90px;
  transition: transform 0.3s ease;
  opacity: 0.6;
}

.timeline-item:hover {
  transform: translateY(-5px);
  opacity: 1;
}

.timeline-item .icon {
  font-size: 1.5rem;
  margin-bottom: 0.5rem;
  display: block;
}

.timeline-item .label {
  font-weight: 600;
  color: #444;
  font-size: 0.9rem;
}

/* FIXED BTN */
/* Base (se adapta por media queries) */
.cta-inscripcion-fixed {
  position: fixed;
  z-index: 9999;
  right: max(0px, env(safe-area-inset-right)); /* iOS safe area */
  text-decoration: none;
  color: var(--cta-text);
  background: var(--color-accent);
  font-weight: 800;
  letter-spacing: 0.04em;
  box-shadow: var(--cta-shadow);
  transition:
    transform 0.2s ease,
    background 0.2s ease,
    opacity 0.2s ease;
}

/* Desktop / Tablet: cinta vertical en el centro derecho */
@media (min-width: 768px) {
  .cta-inscripcion-fixed {
    top: 30%;
    transform: translateY(-50%);
    border-radius: 12px 0 0 12px;
    padding: 14px 16px;
    writing-mode: horizontal-tb;
    text-orientation: mixed;
    display: flex;
    align-items: center;
    gap: 8px;
    right: 0;
  }
}

/* Mobile: FAB abajo a la derecha */
@media (max-width: 767px) {
  .cta-inscripcion-fixed {
    top: 30%;
    transform: translateY(-50%);
    border-radius: 12px 0 0 12px;
    padding: 14px 16px;
    writing-mode: vertical-lr;
    text-orientation: mixed;
    display: flex;
    align-items: center;
    gap: 8px;
    right: 0;
  }
}

/* Interacciones */
.cta-inscripcion-fixed:hover {
  background: var(--color-accent-700);
  text-decoration: none;
}
.cta-inscripcion-fixed:active {
  transform: translateY(-50%) scale(0.98);
}
@media (max-width: 767px) {
  .cta-inscripcion-fixed:active {
    transform: scale(0.96);
  }
}

/* Respeta usuarios con reduced motion */
@media (prefers-reduced-motion: reduce) {
  .cta-inscripcion-fixed {
    transition: none;
  }
}
