:root {
    /* Paleta de colores Clientes (Azules) */
    --fid-pri: #003469;
    --fid-sec: #7b9fc6;
    --fid-claro: #e5f2ff;
    --fid-medio: #2d5b8b;
    --fid-oscuro: rgb(4, 35, 66);
    /* Paleta de colores Produccion (Verdes) */
    --prod-pri: #057151;
    --prod-sec: #41a788;
    --prod-claro: #d2f1e8;
    --prod-medio: #3a806a;
    --prod-oscuro: #103f31;
    /* Neutrales y Negativos */
    --gris-50: #fdfdfd; /* Blanco */
    --gris-100: #ececec;
    --gris-200: #d9d9d9;
    --gris-300: #848484;
    --gris-350: #6a6a6a;
    --gris-400: #444444;
    --gris-500: #1c1a1c;
    --neg-pri: #9f0c0a;
    --neg-claro: #e9d1d1;
    --neg-oscuro: #780302;
    /* Semáforo */
    --sem-1: #06661e;
    --sem-2: #66b933;
    --sem-3: #ffcc00;
    --sem-4: #f59510;
    --sem-5: #f45047;
    --sem-6: #9f0c04;
    --sem-7: #ccccd0;
    /* Categorías */
    --cat-1: #1d558c;
    --cat-2: #a276a6;
    --cat-3: #f46582;
    --cat-4: #e69162;
    --cat-5: #a4ca7a;
    --cat-6: #1ea895;
}
/* ========== Clases de pesos de fuentes ========== */
.fw-100 {
    font-weight: 100;
}
.fw-200 {
    font-weight: 200;
}
.fw-300 {
    font-weight: 300;
}
.fw-400 {
    font-weight: 400;
}
.fw-500 {
    font-weight: 500;
}
.fw-600 {
    font-weight: 600;
}
.fw-700 {
    font-weight: 700;
}
.fw-800 {
    font-weight: 800;
}
.fw-900 {
    font-weight: 900;
}
/* ========== Clases de color (texto) ========== */

/* Fidelitas (Azules) */
.text-fid-pri {
    color: var(--fid-pri);
}
.text-fid-sec {
    color: var(--fid-sec);
}
.text-fid-claro {
    color: var(--fid-claro);
}
.text-fid-medio {
    color: var(--fid-medio);
}
.text-fid-oscuro {
    color: var(--fid-oscuro);
}

/* Producción (Verdes) */
.text-prod-pri {
    color: var(--prod-pri);
}
.text-prod-sec {
    color: var(--prod-sec);
}
.text-prod-claro {
    color: var(--prod-claro);
}
.text-prod-medio {
    color: var(--prod-medio);
}
.text-prod-oscuro {
    color: var(--prod-oscuro);
}

/* Neutrales */
.text-gris-50 {
    color: var(--gris-50);
}
.text-gris-100 {
    color: var(--gris-100);
}
.text-gris-200 {
    color: var(--gris-200);
}
.text-gris-300 {
    color: var(--gris-300);
}
.text-gris-350 {
    color: var(--gris-350);
}
.text-gris-400 {
    color: var(--gris-400);
}
.text-gris-500 {
    color: var(--gris-500);
}

/* Negativos */
.text-neg-pri {
    color: var(--neg-pri);
}
.text-neg-claro {
    color: var(--neg-claro);
}
.text-neg-oscuro {
    color: var(--neg-oscuro);
}

/* Semáforo */
.text-sem-1 {
    color: var(--sem-1);
}
.text-sem-2 {
    color: var(--sem-2);
}
.text-sem-3 {
    color: var(--sem-3);
}
.text-sem-4 {
    color: var(--sem-4);
}
.text-sem-5 {
    color: var(--sem-5);
}
.text-sem-6 {
    color: var(--sem-6);
}
.text-sem-7 {
    color: var(--sem-7);
}

/* Categorías */
.text-cat-1 {
    color: var(--cat-1);
}
.text-cat-2 {
    color: var(--cat-2);
}
.text-cat-3 {
    color: var(--cat-3);
}
.text-cat-4 {
    color: var(--cat-4);
}
.text-cat-5 {
    color: var(--cat-5);
}
.text-cat-6 {
    color: var(--cat-6);
}

/* ========== Clases de background-color ========== */

/* Fidelitas (Azules) */
.bg-fid-pri {
    background-color: var(--fid-pri);
}
.bg-fid-sec {
    background-color: var(--fid-sec);
}
.bg-fid-claro {
    background-color: var(--fid-claro);
}
.bg-fid-medio {
    background-color: var(--fid-medio);
}
.bg-fid-oscuro {
    background-color: var(--fid-oscuro);
}

/* Producción (Verdes) */
.bg-prod-pri {
    background-color: var(--prod-pri);
}
.bg-prod-sec {
    background-color: var(--prod-sec);
}
.bg-prod-claro {
    background-color: var(--prod-claro);
}
.bg-prod-medio {
    background-color: var(--prod-medio);
}
.bg-prod-oscuro {
    background-color: var(--prod-oscuro);
}

/* Neutrales */
.bg-gris-50 {
    background-color: var(--gris-50);
}
.bg-gris-100 {
    background-color: var(--gris-100);
}
.bg-gris-200 {
    background-color: var(--gris-200);
}
.bg-gris-300 {
    background-color: var(--gris-300);
}
.bg-gris-350 {
    background-color: var(--gris-350);
}
.bg-gris-400 {
    background-color: var(--gris-400);
}
.bg-gris-500 {
    background-color: var(--gris-500);
}

/* Negativos */
.bg-neg-pri {
    background-color: var(--neg-pri);
}
.bg-neg-claro {
    background-color: var(--neg-claro);
}
.bg-neg-oscuro {
    background-color: var(--neg-oscuro);
}

/* Semáforo */
.bg-sem-1 {
    background-color: var(--sem-1);
}
.bg-sem-2 {
    background-color: var(--sem-2);
}
.bg-sem-3 {
    background-color: var(--sem-3);
}
.bg-sem-4 {
    background-color: var(--sem-4);
}
.bg-sem-5 {
    background-color: var(--sem-5);
}
.bg-sem-6 {
    background-color: var(--sem-6);
}
.bg-sem-7 {
    background-color: var(--sem-7);
}

/* Categorías */
.bg-cat-1 {
    background-color: var(--cat-1);
}
.bg-cat-2 {
    background-color: var(--cat-2);
}
.bg-cat-3 {
    background-color: var(--cat-3);
}
.bg-cat-4 {
    background-color: var(--cat-4);
}
.bg-cat-5 {
    background-color: var(--cat-5);
}
.bg-cat-6 {
    background-color: var(--cat-6);
}

/* Botones */

/* Reset para botones como <a> */
a[class*="btn-"],
a[class*="btn-"]:hover,
a[class*="btn-"]:focus,
a[class*="btn-"]:active,
a[class*="btn-"]:visited {
    text-decoration: none;
}

/* Tamaños */
.btn-small {
    height: 32px;
    padding: 8px 16px;
    font-size: 14px;
    font-weight: 700;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    --b-width: 1px; /* Variable para el grosor */
    transition: all 0.2s ease-in-out;
}
.btn-small i {
    font-size: 14px;
    padding-right: 8px;
}

.btn-medium {
    height: 40px;
    padding: 8px 16px;
    font-size: 16px;
    font-weight: 700;
    line-height: 1;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    --b-width: 2px; /* Variable para el grosor */
    transition: all 0.1s ease-in-out;
}
.btn-medium i {
    font-size: 16px;
    padding-right: 8px;
    line-height: 1;
}

/* Solo ícono */
.btn-icon {
    padding: 10px;
}
.btn-icon.btn-medium {
    padding: 10px;
}
.btn-icon i {
    padding-right: 0;
}

/* Diseños de botones fidelitas (azules)*/
.btn-fid-fill {
    background-color: var(--fid-pri);
    color: var(--gris-50);
    /* Borde Simulado */
    box-shadow: inset 0 0 0 var(--b-width) var(--fid-pri);
}

.btn-fid-fill:hover {
    background-color: var(--fid-oscuro);
    color: var(--gris-50);
    /* Efecto Glow limpio */
    box-shadow: inset 0 0 12px 0 rgba(229, 242, 255, 0.65);
}

.btn-fid-fill:active {
    background-color: var(--fid-oscuro);
    color: var(--gris-50);
    /* Efecto Neón 4 direcciones */
    box-shadow:
        inset -2px -2px 4px 0px rgba(229, 242, 255, 0.65),
        inset 2px 2px 4px 0px rgba(229, 242, 255, 0.65),
        inset 2px -2px 4px 0px rgba(229, 242, 255, 0.65),
        inset -2px 2px 4px 0px rgba(229, 242, 255, 0.65);
}

/* Fidelitas Outline (Adaptado a Shadow para mantener tamaño) */
.btn-fid-outline {
    background-color: var(--gris-50);
    color: var(--fid-pri);
    box-shadow: inset 0 0 0 var(--b-width) var(--fid-pri);
}
.btn-fid-outline:hover {
    background-color: var(--fid-claro);
    color: var(--fid-pri);
    /* Combinamos borde + sombra interna suave */
    box-shadow:
        inset 0 0 0 var(--b-width) var(--fid-pri),
        inset 0 0 16px 0 rgba(4, 35, 66, 0.25);
}
.btn-fid-outline:active {
    background-color: var(--fid-claro);
    color: var(--fid-pri);
    box-shadow:
    inset 0 0 0 var(--b-width) var(--fid-pri),
        inset -2px -2px 4px 0px rgba(4, 35, 66, 0.4),
        inset 2px 2px 4px 0px rgba(4, 35, 66, 0.4),
        inset 2px -2px 4px 0px rgba(4, 35, 66, 0.4),
        inset -2px 2px 4px 0px rgba(4, 35, 66, 0.4);
}

.btn-fid-text {
    background-color: transparent;
    color: var(--fid-pri);
    border-color: transparent;
}
.btn-fid-text:hover {
    color: var(--fid-oscuro);
    text-decoration: underline;
}
.btn-fid-text:active {
    color: var(--fid-pri);
    text-decoration: underline;
}
.btn-fid-text:disabled {
    color: var(--gris-350);
    pointer-events: none;
    text-decoration: none;
}

/* Label de boton fidelitas*/
.btn-fid-label {
    position: relative;
}
.btn-fid-label::after {
    content: attr(data-label);
    position: absolute;
    bottom: -75%;
    left: 50%;
    transform: translateX(-50%);
    background-color: var(--fid-claro);
    color: var(--fid-pri);
    padding: 4px 8px;
    border-radius: 2px;
    font-size: 12px;
    white-space: nowrap;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.3s ease;
}
.btn-fid-label:hover::after {
    opacity: 1;
}

/* Diseños de botones producción (verdes)*/
.btn-prod-fill {
    background-color: var(--prod-pri);
    color: var(--gris-50);
    box-shadow: inset 0 0 0 var(--b-width) var(--prod-pri);
}

.btn-prod-fill:hover {
    background-color: var(--prod-oscuro);
    color: var(--gris-50);
    /* Glow verde */
    box-shadow: inset 0 0 12px 0 rgba(210, 241, 232, 0.65);
}

.btn-prod-fill:active {
    background-color: var(--prod-oscuro);
    color: var(--gris-50);
    /* Neón verde 4 direcciones */
    box-shadow:
        inset -2px -2px 4px 0px rgba(210, 241, 232, 0.65),
        inset 2px 2px 4px 0px rgba(210, 241, 232, 0.65),
        inset 2px -2px 4px 0px rgba(210, 241, 232, 0.65),
        inset -2px 2px 4px 0px rgba(210, 241, 232, 0.65);
}

/* Producción Outline */
.btn-prod-outline {
    background-color: var(--gris-50);
    color: var(--prod-pri);
    box-shadow: inset 0 0 0 var(--b-width) var(--prod-pri);
}
.btn-prod-outline:hover {
    background-color: var(--prod-claro);
    color: var(--prod-pri);
    box-shadow:
        inset 0 0 0 var(--b-width) var(--prod-pri),
        inset 0 0 2px 2px rgba(16, 63, 49, 0.2);
}
.btn-prod-outline:active {
    background-color: var(--prod-claro);
    color: var(--prod-pri);
    box-shadow:
        inset 0 0 0 var(--b-width) var(--prod-pri),
        inset 0 0 2px 4px rgba(16, 63, 49, 0.4);
}

.btn-prod-text {
    background-color: transparent;
    color: var(--prod-pri);
    border-color: transparent;
}
.btn-prod-text:hover {
    color: var(--prod-oscuro);
    text-decoration: underline;
}
.btn-prod-text:active {
    color: var(--prod-pri);
    text-decoration: underline;
}
.btn-prod-text:disabled {
    color: var(--gris-350);
    pointer-events: none;
    text-decoration: none;
}

/* Label de boton producción*/
.btn-prod-label {
    position: relative;
}
.btn-prod-label::after {
    content: attr(data-label);
    position: absolute;
    bottom: -75%;
    left: 50%;
    transform: translateX(-50%);
    background-color: var(--prod-claro);
    color: var(--prod-pri);
    padding: 4px 8px;
    border-radius: 2px;
    font-size: 12px;
    white-space: nowrap;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.3s ease;
}
.btn-prod-label:hover::after {
    opacity: 1;
}

/* Botones negativos */
.btn-neg-fill {
    background-color: var(--neg-pri);
    color: var(--gris-50);
    box-shadow: inset 0 0 0 var(--b-width) var(--neg-pri);
}

.btn-neg-fill:hover {
    background-color: var(--neg-oscuro);
    color: var(--gris-50);
    /* Glow rojo */
    box-shadow: inset 0 0 12px 0 rgba(233, 209, 209, 0.65);
}

.btn-neg-fill:active {
    background-color: var(--neg-oscuro);
    color: var(--gris-50);
    box-shadow:
        inset -2px -2px 4px 0px rgba(233, 209, 209, 0.65),
        inset 2px 2px 4px 0px rgba(233, 209, 209, 0.65),
        inset 2px -2px 4px 0px rgba(233, 209, 209, 0.65),
        inset -2px 2px 4px 0px rgba(233, 209, 209, 0.65);
}

/* Negativo Outline */
.btn-neg-outline {
    background-color: var(--gris-50);
    color: var(--neg-pri);
    box-shadow: inset 0 0 0 var(--b-width) var(--neg-pri);
}
.btn-neg-outline:hover {
    background-color: var(--neg-claro);
    color: var(--neg-pri);
    box-shadow:
        inset 0 0 0 var(--b-width) var(--neg-pri),
        inset 0 0 2px 2px rgba(156, 12, 4, 0.2);
}
.btn-neg-outline:active {
    background-color: var(--neg-claro);
    color: var(--neg-pri);
    box-shadow:
        inset 0 0 0 var(--b-width) var(--neg-pri),
        inset 0 0 2px 4px rgba(156, 12, 4, 0.4);
}

.btn-neg-text {
    background-color: transparent;
    color: var(--neg-pri);
    border-color: transparent;
}
.btn-neg-text:hover {
    color: var(--neg-oscuro);
    text-decoration: underline;
}
.btn-neg-text:active {
    color: var(--neg-pri);
    text-decoration: underline;
}
.btn-neg-text:disabled {
    color: var(--gris-350);
    pointer-events: none;
    text-decoration: none;
}

/* Label de boton negativo*/
.btn-neg-label {
    position: relative;
}
.btn-neg-label::after {
    content: attr(data-label);
    position: absolute;
    bottom: -75%;
    left: 50%;
    transform: translateX(-50%);
    background-color: var(--neg-claro);
    color: var(--neg-pri);
    padding: 4px 8px;
    border-radius: 2px;
    font-size: 12px;
    white-space: nowrap;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.3s ease;
}
.btn-neg-label:hover::after {
    opacity: 1;
}
.btn-fid-fill:disabled,
.btn-prod-fill:disabled,
.btn-neg-fill:disabled {
    background-color: var(--gris-350);
    box-shadow: inset 0 0 0 var(--b-width) var(--gris-350);
    pointer-events: none;
}

.btn-fid-outline:disabled,
.btn-prod-outline:disabled,
.btn-neg-outline:disabled {
    background-color: var(--gris-100);
    color: var(--gris-350);
    box-shadow: inset 0 0 0 var(--b-width) var(--gris-350);
    pointer-events: none;
}

.btn-fid-text,
.btn-prod-text,
.btn-neg-text {
    background-color: transparent;
    border: none;
    box-shadow: none;
}

/* Inputs */
.input-fid {
    background-color: var(--fid-claro);
    border: 1px solid var(--fid-pri);
    font-weight: 400;
    border-radius: 4px;
    padding: 8px 12px;
    transition: all 0.2s ease-in-out;
}
.input-fid:focus {
    outline: none;
    color: var(--fid-pri);
    background-color: var(--gris-50);
    border: 2px solid var(--fid-pri);
    box-shadow: 0 0 4px 0 rgba(0, 52, 105, 0.5);
}

.input-prod {
    background-color: var(--prod-claro);
    border: 1px solid var(--prod-pri);
    font-weight: 400;
    border-radius: 4px;
    padding: 8px 12px;
    transition: all 0.2s ease-in-out;
}
.input-prod:focus {
    outline: none;
    color: var(--prod-pri);
    background-color: var(--gris-50);
    border: 2px inset var(--prod-pri);
    box-shadow: 0 0 4px 0 rgba(5, 113, 81, 0.5);
}

.input-fid:disabled, .input-prod:disabled {
    background-color: var(--gris-100);
    color: var(--gris-350);
    border-color: var(--gris-200);
    pointer-events: none;
    font-weight: 500;
}

/* Input wrapper (componente) */
.input-wrapper {
    display: flex;
    flex-direction: column;
}
.input-inner {
    position: relative;
    display: flex;
    align-items: center;
}
.input-inner input {
    width: 100%;
    padding-right: 32px;
}
.input-clear {
    position: absolute;
    right: 6px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 2px 4px;
    font-size: 12px;
    line-height: 1;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--fid-oscuro);
    transition: opacity 0.2s ease;
}
.input-clear:hover {
    opacity: 1;
}
.input-clear-fid {
    color: var(--fid-pri);
}
.input-clear-prod {
    color: var(--prod-pri);
}

/* Select */
.select-fid {
    background-color: var(--gris-50);
    color: var(--fid-oscuro);
    border: 1px solid var(--fid-oscuro);
    font-weight: 400;
    border-radius: 4px;
    padding: 8px 12px;
    transition: all 0.2s ease-in-out;
}
.select-fid option {
    background-color: var(--gris-50);
    color: var(--fid-oscuro);
    border: 1px solid var(--fid-oscuro);
}
.select-fid:has(option:checked:not([value=""])) {
    background-color: var(--fid-claro);
    font-weight: 500;
}

.select-prod {
    background-color: var(--gris-50);
    color: var(--prod-oscuro);
    border: 1px solid var(--prod-oscuro);
    font-weight: 400;
    border-radius: 4px;
    padding: 8px 12px;
    transition: all 0.2s ease-in-out;
}
.select-prod option {
    background-color: var(--gris-50);
    color: var(--prod-oscuro);
    border: 1px solid var(--prod-oscuro);
}
.select-prod:has(option:checked:not([value=""])) {
    background-color: var(--prod-claro);
    font-weight: 500;
}

.link-prod {
  color: var(--prod-pri);
}