html {
  font-size: 14px;
}

@media (min-width: 768px) {
  html {
    font-size: 16px;
  }
}

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
    box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem #258cfb;
}

html {
    position: relative;
    min-height: 100%;
}

body {
    overflow-x: hidden;
    margin: 0;
}

.form-floating > .form-control-plaintext::placeholder, .form-floating > .form-control::placeholder {
  color: var(--bs-secondary-color);
  text-align: end;
}

.form-floating > .form-control-plaintext:focus::placeholder, .form-floating > .form-control:focus::placeholder {
  text-align: start;
}


.panel-ads {
}
    .panel-ads img {
        width: 100%;
        border-radius: 15px;
    }


.panel-tip {
    padding: 30px
}
    .panel-tip img {
        border-radius: 15px;
        width: 100%;
        display: block;
    }


/* Estado inicial: más abajo y oculto */
.animate-on-scroll {
    opacity: 0;
    transform: translateY(60px); /* desde abajo */
    transition: opacity 1.6s ease, transform 1.6s ease;
}

    /* Cuando Intersection Observer agrega la clase */
    .animate-on-scroll.is-visible {
        opacity: 1;
        transform: translateY(0); /* posición final */
    }
