/* --------------------- VARIABLES --------------------- */
/* Modo CLARO - Default */
:root {
    --bg-colorbk: hsl(276, 22%, 95%);
    --bg-color: #ffffff;
    --text-color: #501E53;
    --thead-color: #ffffff;
    --ball-color: #ffffff;
    --switch-on: #501E53;

    --search-bg: #ffffff;
    --search-border: #501E53;      /* lila */
    --search-text: #501E53;
    --search-placeholder: #501E53;

    --search-icon-bg: #501E53;
    --search-icon-filterc: invert(30%) sepia(60%) saturate(400%) hue-rotate(260deg);
    
}

/* Modo OSCURO */
:root[data-theme="dark"] {
    --bg-color: #1C131C;
    --text-color: #ffffff;
    --thead-color: #ffffff;
    --ball-color: #501E53;
    --switch-on: #501E53;

    --search-bg: #501E53;          /* lila */
    --search-border: #ffffff;
    --search-text: #ffffff;
    --search-placeholder: #cccccc;

    --search-icon-bg: #501E53;
    --search-icon-filterx: invert(100%);
}

/* --------------------- BODY --------------------- */

body {
    background-color: var(--bg-color);
    color: var(--text-color);
    font-family: 'Roboto', sans-serif;
    margin: 0;
    padding: 0;
    overflow-x: hidden;
}

thead{
    color: var(--thead-color);
}

.checkbox-label{
    color: var(--text-color);
}

/* --------------------- Balls --------------------- */

.glow-container {
    position: fixed;
    width: 100%;
    height: 100vh;
    z-index: -1;
    overflow: hidden;
}

.ball {
    position: absolute;
    width: 300px;
    height: 300px;
    background: radial-gradient(circle, var(--ball-color) 0%, transparent 100%);
    border-radius: 50%;
    filter: blur(10px);
    opacity: 0.8;
}

/* --------------------- Fade in --------------------- */
/* Add this new class */
.page-wrapper {
    position: relative;
    min-height: 100vh;
    width: 100%;
}

.svg-animation-container {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
    pointer-events: none;
    overflow: hidden;
}

.svg-left {
    position: absolute;
    top: 0;
    left: -7%;
    width: 50%;
    max-width: 600px;
}

.svg-right {
    position: absolute;
    bottom: 0;
    right: -7%;
    width: 50%;
    max-width: 600px;
}

/* SVG images */
.svg-left img,
.svg-right img {
    width: 100%;
    height: auto;
    object-fit: contain;
    display: block;  /* Prevents extra space below image */
}

/* Animations */
@keyframes fadeInLeft {
    from {
        opacity: 0;
        transform: translate3d(-100%, 0, 0)
    }
    to {
        opacity: 1;
        transform: none
    }
}

.fadeInLeft {
    animation-name: fadeInLeft;
    animation-duration: 1.5s;
    animation-fill-mode: both;
}

@keyframes fadeInRight {
    from {
        opacity: 0;
        transform: translate3d(100%, 0, 0)
    }
    to {
        opacity: 1;
        transform: none
    }
}

.fadeInRight {
    animation-name: fadeInRight;
    animation-duration: 1.5s;
    animation-fill-mode: both;
}

/* -- Confifuraciones para el Claro / Oscuro -- */
/* Switch apagado*/
.form-check.form-switch {
  display: flex;
  align-items: center;
  gap: 6px; 
  color: var(--switch-on);
}
.form-switch .form-check-input {
  background-color: var(--switch-on);
  border-color: var(--switch-on);
  width: 3.5rem;
  height: 1.7rem;   
}

/* Switch encendido */
.form-switch .form-check-input:checked {
  background-color: var(--switch-on);
  border-color: var(--switch-on);
  background-size: contain;
}
.switch-theme {
  position: relative;
  display: inline-flex;
  align-items: center;
}

/* Bolita del Switch siempre blanca */
.form-check-input,
.form-check-input:checked {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3E%3Ccircle r='3' fill='%23ffffff'/%3E%3C/svg%3E") !important;
}

/* Imagen en el switch - Sol y Luna */
.switch-icon {
  position: relative;
  left: -25px;
  top: 2px;
  font-size: 14px;
  color: #ffffff;
  pointer-events: none;
  transition: all 0.1s ease;
}

/* Juego de posiciones izquierda y derecha */
#switchTheme:checked ~ .switch-icon {
    left: -55px;
}

.search-box {
  display: flex;
  align-items: center;
  border: 1px solid var(--search-border);
  background-color: var(--search-bg);
  border-radius: 6px;
  padding: 10px 10px;
  gap: 8px;
  
}

.custom-select .select-selected {
    color: var(--text-color);
    display: flex;
    align-items: start;
    border: 1px solid var(--search-border);
    background-color: var(--search-bg);
    border-radius: 6px;
    gap: 8px;
}

/* Input */
.search-box input {
    flex: 1;
    border: none;
    outline: none;
    background: transparent;
    color: var(--text-color) !important;
    font-size: 14px;
}

/* Placeholder */
.search-box input::placeholder {
    color: var(--search-placeholder);
    opacity: 1; /* importante para Firefox */
}

/* Icono */
.search-box .icon {
    background-color: var(--search-icon-bg);
    width: 16px;
    height: 16px;
    filter: var(--search-icon-filter);
}

.expand-details {
    color: var(--text-color);
    background-color: var(--bg-color);
}

.bs-tooltip-auto div{
    background-color: #501E53 !important;
}