/* ===========================
   INPUT, SELECT AND BUTTON
=========================== */
.custom-switch {
    scale: 1.3;
}

.custom-control-input:checked~.custom-control-label::before {
    background-color: var(--altoken-orange) !important;
    border-color: var(--altoken-orange) !important;
}

.custom-control-label::after {
    background-color: #fff !important;
}

.custom-control-input:not(:checked)~.custom-control-label::before {
    background-color: #ccc !important;
    border-color: #ccc !important;
}

input,
input:focus {
    outline: none !important;
    box-shadow: none !important;
    border-color: var(--altoken-secondary-25) !important;
}

input:focus {
    outline: none !important;
    box-shadow: none !important;
    border-color: var(--altoken-indigo) !important;
}

input::placeholder {
    color: var(--altoken-secondary-75) !important;
    text-transform: none !important;
    font-weight: 300;
}

select,
select:focus {
    outline: none !important;
    box-shadow: none !important;
}

input[type='number'] {
    -moz-appearance: textfield;
}

input[type='number']::-webkit-outer-spin-button,
input[type='number']::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

button:focus,
.btn:focus {
    box-shadow: none !important;
    outline: none !important;
}

.btn:hover svg path {
    transition: all 0.4s;
    scale: 1.01;
}

.btn:hover svg path#path3428 {
    transition: all 0.4s;
    fill: var(--altoken-indigo) !important;
}


/* ============================================================
   CHECKBOX PERSONALIZADO
============================================================ */
.custom-checkbox input[type='checkbox'] {
    display: none;
}

.custom-checkbox label {
    position: relative;
    padding-left: 32px;
    cursor: pointer;
    user-select: none;
}

.custom-checkbox label::before {
    content: '';
    position: absolute;
    left: 0;
    top: 30%;
    transform: translateY(-50%);
    width: 20px;
    height: 20px;
    background-color: var(--altoken-yellow);
    border: 2px solid var(--altoken-yellow-15);
    border-radius: 4px;
    box-sizing: border-box;
    transition: background-color 0.3s ease;
}

.custom-checkbox input[type='checkbox']:checked+label::before {
    background-color: var(--altoken-yellow);
    border-color: var(--altoken-secondary-15);

}

.custom-checkbox input[type='checkbox']:checked+label::after {
    content: '✔';
    position: absolute;
    left: 4px;
    top: 30%;
    transform: translateY(-50%);
    font-size: 14px;
    color: var(--altoken-black);
    font-weight: bold;

}

.custom-radio .form-check-input {
    appearance: none;
    -webkit-appearance: none;
    width: 20px;
    height: 20px;
    border: 3px solid #f58220;
    /* Borde naranja */
    border-radius: 50%;
    outline: none;
    margin-right: 8px;
    position: relative;
    cursor: pointer;
}

.custom-radio .form-check-input:checked::before {
    content: '';
    position: absolute;
    top: 7px;
    left: 5px;
    width: 10px;
    height: 10px;
    background-color: var(--altoken-orange);
    /* Centro naranja */
    border-radius: 50%;
}

/* ===========================
   FONDOS (Backgrounds)
=========================== */
.bg-indigo {
    background-color: var(--altoken-indigo) !important;
}

.bg-indigo-15 {
    background-color: var(--altoken-indigo-15) !important;
}

.bg-indigo-25 {
    background-color: var(--altoken-indigo-25) !important;
}

.bg-indigo-50 {
    background-color: var(--altoken-indigo-50) !important;
}

.bg-indigo-75 {
    background-color: var(--altoken-indigo-75) !important;
}

.bg-azulejo {
    background-color: var(--altoken-azulejo) !important;
}

.bg-azulejo-15 {
    background-color: var(--altoken-azulejo-15) !important;
}

.bg-azulejo-25 {
    background-color: var(--altoken-azulejo-25) !important;
}

.bg-azulejo-50 {
    background-color: var(--altoken-azulejo-50) !important;
}

.bg-azulejo-75 {
    background-color: var(--altoken-azulejo-75) !important;
}

.bg-orange {
    background-color: var(--altoken-orange) !important;
}

.bg-orange-15 {
    background-color: var(--altoken-orange-15) !important;
}

.bg-orange-25 {
    background-color: var(--altoken-orange-25) !important;
}

.bg-orange-50 {
    background-color: var(--altoken-orange-50) !important;
}

.bg-orange-75 {
    background-color: var(--altoken-orange-75) !important;
}

.bg-orange-full {
    background-color: var(--altoken-orange-full) !important;
}

.bg-yellow {
    background-color: var(--altoken-yellow) !important;
}

.bg-yellow-15 {
    background-color: var(--altoken-yellow-15) !important;
}

.bg-yellow-25 {
    background-color: var(--altoken-yellow-25) !important;
}

.bg-yellow-50 {
    background-color: var(--altoken-yellow-50) !important;
}

.bg-yellow-75 {
    background-color: var(--altoken-yellow-75) !important;
}

.bg-green {
    background-color: var(--altoken-green) !important;
}

.bg-green-15 {
    background-color: var(--altoken-green-15) !important;
}

.bg-green-25 {
    background-color: var(--altoken-green-25) !important;
}

.bg-green-50 {
    background-color: var(--altoken-green-50) !important;
}

.bg-green-75 {
    background-color: var(--altoken-green-75) !important;
}

.bg-red {
    background-color: var(--altoken-red) !important;
}

.bg-red-15 {
    background-color: var(--altoken-red-15) !important;
}

.bg-red-25 {
    background-color: var(--altoken-red-25) !important;
}

.bg-red-50 {
    background-color: var(--altoken-red-50) !important;
}

.bg-red-75 {
    background-color: var(--altoken-red-75) !important;
}


.bg-secondary {
    background-color: var(--altoken-secondary) !important;
}

.bg-secondary-15 {
    background-color: var(--altoken-secondary-15) !important;
}

.bg-secondary-25 {
    background-color: var(--altoken-secondary-25) !important;
}

.bg-secondary-50 {
    background-color: var(--altoken-secondary-50) !important;
}

.bg-secondary-75 {
    background-color: var(--altoken-secondary-75) !important;
}

.bg-black {
    background-color: var(--altoken-black) !important;
}

.bg-white {
    background-color: var(--altoken-white) !important;
}

.bg-white-15 {
    background-color: var(--altoken-white-15) !important;
}

.bg-white-25 {
    background-color: var(--altoken-white-25) !important;
}

.bg-white-50 {
    background-color: var(--altoken-white-50) !important;
}

.bg-white-75 {
    background-color: var(--altoken-white-75) !important;
}

.bg-account {
    background-color: var(--altoken-account) !important;
}

.bg-login {
    background-color: var(--altoken-yellow) !important;
}

.bg-login:hover {
    background-color: var(--altoken-yellow-75) !important;
    color: var(--altoken-indigo-75) !important;
}

/* ===========================
   TEXTO (Text colors)
=========================== */
.text-muted {
    color: rgb(104, 103, 103) !important;
}

.text-indigo {
    color: var(--altoken-indigo) !important;
}

.text-indigo-15 {
    color: var(--altoken-indigo-15) !important;
}

.text-indigo-25 {
    color: var(--altoken-indigo-25) !important;
}

.text-indigo-50 {
    color: var(--altoken-indigo-50) !important;
}

.text-indigo-75 {
    color: var(--altoken-indigo-75) !important;
}

.text-azulejo {
    color: var(--altoken-azulejo) !important;
}

.text-azulejo-15 {
    color: var(--altoken-azulejo-15) !important;
}

.text-azulejo-25 {
    color: var(--altoken-azulejo-25) !important;
}

.text-azulejo-50 {
    color: var(--altoken-azulejo-50) !important;
}

.text-azulejo-75 {
    color: var(--altoken-azulejo-75) !important;
}

.text-orange {
    color: var(--altoken-orange) !important;
}

.text-orange-15 {
    color: var(--altoken-orange-15) !important;
}

.text-orange-25 {
    color: var(--altoken-orange-25) !important;
}

.text-orange-50 {
    color: var(--altoken-orange-50) !important;
}

.text-orange-75 {
    color: var(--altoken-orange-75) !important;
}

.text-yellow {
    color: var(--altoken-yellow) !important;
}

.text-yellow-15 {
    color: var(--altoken-yellow-15) !important;
}

.text-yellow-25 {
    color: var(--altoken-yellow-25) !important;
}

.text-yellow-50 {
    color: var(--altoken-yellow-50) !important;
}

.text-yellow-75 {
    color: var(--altoken-yellow-75) !important;
}

.text-green {
    color: var(--altoken-green) !important;
}

.text-green-15 {
    color: var(--altoken-green-15) !important;
}

.text-green-25 {
    color: var(--altoken-green-25) !important;
}

.text-green-50 {
    color: var(--altoken-green-50) !important;
}

.text-green-75 {
    color: var(--altoken-green-75) !important;
}

.text-red {
    color: var(--altoken-red) !important;
}

.text-red-15 {
    color: var(--altoken-red-15) !important;
}

.text-red-25 {
    color: var(--altoken-red-25) !important;
}

.text-red-50 {
    color: var(--altoken-red-50) !important;
}

.text-red-75 {
    color: var(--altoken-red-75) !important;
}

.text-secondary {
    color: var(--altoken-secondary) !important;
}

.text-secondary-15 {
    color: var(--altoken-secondary-15) !important;
}

.text-secondary-25 {
    color: var(--altoken-secondary-25) !important;
}

.text-secondary-50 {
    color: var(--altoken-secondary-50) !important;
}

.text-secondary-75 {
    color: var(--altoken-secondary-75) !important;
}

.text-black {
    color: var(--altoken-black) !important;
}

.text-white {
    color: var(--altoken-white) !important;
}

.text-white-15 {
    color: var(--altoken-white-15) !important;
}

.text-white-25 {
    color: var(--altoken-white-25) !important;
}

.text-white-50 {
    color: var(--altoken-white-50) !important;
}

.text-white-75 {
    color: var(--altoken-white-75) !important;
}

/* ===========================
   TEXTO (Sizes)
=========================== */

.text-xs {
    font-size: 12px !important;
}

.text-sm {
    font-size: 14px !important;
}

.text-md {
    font-size: 16px !important;
}

.text-lg {
    font-size: 20px !important;
}

.text-xl {
    font-size: 24px !important;
}

.text-2xl {
    font-size: 28px !important;
}

h1 {
    font-size: 28px !important;
    line-height: 1.3 !important;
}

h2 {
    font-size: 24px !important;
    line-height: 1.3 !important;
}

h3 {
    font-size: 20px !important;
    line-height: 1.3 !important;
}

h4 {
    font-size: 18px !important;
    line-height: 1.3 !important;
}

h5 {
    font-size: 16px !important;
    line-height: 1.3 !important;
}

h6 {
    line-height: 1.3 !important;
}

p {
    font-size: 14px !important;
    line-height: 1.3 !important;
}

a {
    text-decoration: none !important;
}

/* ===========================
   BORDER Y SOMBRAS
=========================== */
/* En tu archivo CSS global */
/* Añade esto a tu CSS global */
html {
    scroll-behavior: smooth;
    scroll-padding-top: 80px;
}

.border-transparent-1 {
    border: 1px solid transparent !important;
}

.border {
    border: 0.5px solid !important;
    border-color: var(--altoken-secondary-50) !important;
}

.border-2 {
    border: 0.5px solid !important;
    border-color: var(--altoken-secondary-25) !important;
}

.btn.border-indigo-1 {
    border: 1px solid var(--altoken-indigo) !important;
}

.btn.border-indigo-1:hover {
    background-color: var(--altoken-indigo-15);
}

.btn.border-black-2 {
    border: 2px solid var(--altoken-black) !important;
}

/* Bordes redondeados */
.rounded-xl {
    border-radius: 25px !important;
}

.rounded-lg {
    border-radius: 15px !important;
}

.rounded-md {
    border-radius: 10px !important;
}

.rounded-sm {
    border-radius: 9px !important;
}

.rounded-xs {
    border-radius: 5px !important;
}

.form-control {
    height: 42px !important;
}

/* Sombras personalizadas */
.shadow-md {
    box-shadow: 0px 4.19px 12.57px 0px #ABBED140 !important;
}

.shadow-altoken-lg {
    box-shadow: 0px -3px 31px 0px #ABBED166 !important;
}

.shadow-altoken-md {
    box-shadow: 0px 16.1px 32.19px 0px #ABBED14D;
}

/* Gradients */
.bg-gradient-otc {
    background: linear-gradient(180deg, #FFFFFF 0%, #F0F0F5 100%);
}


/* ===========================
   HOVERS
=========================== */
.btn {
    border: 2px solid transparent !important;
}


.btn.bg-white:hover {
    background-color: var(--altoken-secondary-25) !important;
    color: var(--altoken-indigo) !important;
}

a.text-white-75:hover {
    transition: all 0.3s ease;
    color: var(--altoken-white) !important;
}

.modal-content {
    border: none !important;
    border-radius: 9px !important;
}

/* ============================================================
   CUSTOM LOADER
============================================================ */

#loader-wrapper {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: var(--altoken-white);
    z-index: 9999;
    display: flex;
    justify-content: center;
    align-items: center;
    transition: opacity 1s ease;
}

.loader {
    width: 40px;
    height: 20px;
    --c: no-repeat radial-gradient(farthest-side, #000 93%, #0000);
    background:
        var(--c) 0 0,
        var(--c) 50% 0,
        var(--c) 100% 0;
    background-size: 8px 8px;
    position: relative;
    animation: l4-0 1s linear infinite alternate;
}

.loader:before {
    content: "";
    position: absolute;
    width: 8px;
    height: 12px;
    background: var(--altoken-yellow);
    left: 0;
    top: 0;
    animation:
        l4-1 1s linear infinite alternate,
        l4-2 0.5s cubic-bezier(0, 200, .8, 200) infinite;
}

@keyframes l4-0 {
    0% {
        background-position: 0 100%, 50% 0, 100% 0
    }

    8%,
    42% {
        background-position: 0 0, 50% 0, 100% 0
    }

    50% {
        background-position: 0 0, 50% 100%, 100% 0
    }

    58%,
    92% {
        background-position: 0 0, 50% 0, 100% 0
    }

    100% {
        background-position: 0 0, 50% 0, 100% 100%
    }
}

@keyframes l4-1 {
    100% {
        left: calc(100% - 8px)
    }
}

@keyframes l4-2 {
    100% {
        top: -0.1px
    }
}

/* ============================================================
   CUSTOM FONT-WEIGHT
============================================================ */

.font-thin {
    font-weight: 100 !important;
}

.font-extralight {
    font-weight: 200 !important;
}

.font-light {
    font-weight: 300 !important;
}

.font-normal {
    font-weight: 400 !important;
}

.font-medium {
    font-weight: 500 !important;
}

.font-semibold {
    font-weight: 600 !important;
}

.font-bold {
    font-weight: 700 !important;
}

.font-extrabold {
    font-weight: 800 !important;
}

.font-black {
    font-weight: 900 !important;
}