@charset "utf-8";

/* http://meyerweb.com/eric/tools/css/reset/
   v2.0 | 20110126
   License: none (public domain)
*/
html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}

body {
  line-height: 1;
}

ol,
ul {
  list-style: none;
}

blockquote,
q {
  quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
  content: "";
  content: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

@font-face {
  font-family: "Montserrat";
  src: url("../font/Montserrat-VariableFont_wght.ttf");
}

@font-face {
  font-family: "Japon";
  src: url("../font/Japon.otf");
}

* {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

@import url("./variables.css");

body {
  font-family: "Montserrat";
  font-weight: 500;
  color: var(--foreground);
  background: var(--bacground);
  background: var(--baground__gradient);
}

body::-webkit-scrollbar {
  background: transparent;
  width: 5px;
}

body::-webkit-scrollbar-thumb {
  background: var(--color-secundario);
  border-radius: 5000px;
}

a {
  text-decoration: none;
  color: unset;
}

input,
select,
textarea,
button {
  font-family: "Montserrat";
  font-weight: 500;
  font-size: 14px;
  height: 35px;
  border: 1px solid transparent;
  border-radius: 5px;
  background: #eff3f7;
  padding: 0 15px;
  transition: 0.3s;
  outline: none;
}

textarea {
  padding: 15px;
}

button {
  background: var(--color-secundario);
  color: var(--color-blanco);
  cursor: pointer;
}

input:hover,
input:focus,
select:hover,
select:focus,
textarea:hover,
textarea:focus {
  border: 1px solid var(--primary__color);
}

.button__main,
.card-profile .card-image-container button {
  background: var(--primary__color);
  color: #fff !important;
  padding: 10px 24px;
  border-radius: 15px;
  font-size: 14px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 5px;
}

.button__text {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 5px;
  font-size: 14px;
  color: var(--primary__color) !important;
  cursor: pointer;
}

/* CONTENEDOR GENERAL */
.contenedor-general {
  width: 100%;
  min-height: 100vh;
  height: max-content;
  position: relative;
  padding-top: 20px;
}

/* ESTILOS DEL LOGIN */
.login-section,
.registro-section {
  width: 100%;
  min-height: 100vh;
  height: 100vh;
  display: flex;
  color: var(--color-primario-textos);
  background: #fdfcfc;
  transition: 0.3s;
  background-image: url("../img/background_login3.png");
  background-size: cover;
  background-position: center;
  padding: 50px;
  position: relative;
}

.logo__login {
  width: 180px;
  margin-top: 50px;
}

.registro-section {
  background: transparent;
}

.login-section::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(6, 0, 0, 0.4);
  backdrop-filter: blur(0.5px);
}

.formulario__container {
  position: relative;
}

.formulario__container-title {
  position: absolute;
  top: 100px;
  left: -15px;
  z-index: 2;
  color: #fff;
  font-family: "Japon";
  font-size: 32px;
  writing-mode: sideways-lr;
  text-shadow: 2px 2px 8px rgb(255, 255, 255);
}

.login-section .formulario {
  width: 450px;
  background: rgb(2, 0, 36);
  background: linear-gradient(
    0deg,
    rgba(67, 0, 7, 0.1) 0%,
    rgba(102, 7, 7, 0.5) 87%
  );
  backdrop-filter: blur(18px);
  height: 100%;
  padding: 50px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
  color: #ffffff;
  clip-path: polygon(
    0 36%,
    6% 32%,
    6% 12%,
    0 9%,
    0 2%,
    4% 0,
    88% 0,
    100% 6%,
    100% 98%,
    96% 100%,
    12% 100%,
    0 94%
  );
  z-index: 1;
  border: 1px solid rgb(49, 0, 0);
}

.login-section .formulario form {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.login-section .flc-head {
  text-align: center;
}

.login-section .flc-head h1 {
  position: absolute;
  top: 0;
  left: 0;
}

.login-section .flc-body {
  display: flex;
  flex-direction: column;
  gap: 25px;
}
.login-section .flc-body .flc-body__group {
  display: flex;
  flex-direction: column;
  gap: 10px;
  position: relative;
}

.login-section .flc-body .flc-body__group input {
  height: 60px;
  background: transparent;
  color: #fff;
  background: rgba(178, 9, 9, 0.1);
  padding-top: 25px;
  font-size: 16px;
  border-radius: 10px;
}

.login-section .flc-body .flc-body__group label {
  position: absolute;
  font-size: 13px;
  top: 10px;
  left: 10px;
  font-weight: 400;
  opacity: 1;
}
input:-webkit-autofill,
input:-internal-autofill-selected {
  background-color: transparent !important; /* Evita el color amarillo */
  color: inherit !important;
  box-shadow: 0 0 0px 1000px white inset !important; /* Truco para forzar el color de fondo */
}

.login-section .flc-body .flc-body__group button {
  height: 50px;
  border-radius: 10px;
  background: rgb(172, 13, 23);
  font-family: "Japon";
  font-size: 24px;
  padding-bottom: 5px;
}

.grupo-form {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin: 15px 0;
}

.grupo-form-botones {
  margin-top: 25px;
}

.grupo-form label {
  font-weight: 500;
  font-size: 15px;
}

.grupo-form input {
  background: #e5ebff;
  color: var(--color-primario-textos);
  font-size: 14px;
  width: 100%;
}

.grupo-form input:hover,
.grupo-form input:focus {
  border: 1px solid var(--color-secundario);
}

.grupo-form .grupo-input {
  width: 100%;
  position: relative;
}

.grupo-form .grupo-input .show-password {
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
}

.registro-section .grupo-form input {
  color: #384252;
  background: rgba(0, 0, 0, 0.03);
}

.grupo-form input::placeholder {
  color: #000;
  opacity: 0.6;
}

.registro-section .grupo-form input::placeholder {
  color: #384252;
}

.grupo-form button {
  border: 1px solid var(--color-secundario);
  background: none;
  font-weight: 500;
}
.grupo-form button.btn-entrar {
  background: var(--color-secundario);
}
.registro-section .grupo-form button.btn-entrar {
  color: #fff;
}
.registro-section .grupo-form button {
  color: var(--color-secundario);
}

.grupo-form a {
  text-align: center;
  font-size: 14px;
  margin: 5px 0;
}

.grupo-form a:hover {
  color: var(--color-secundario);
  text-decoration: none;
}

.login-section .flc-footer {
  display: flex;
  justify-content: center;
  margin-top: 50px;
}

.login-section .flc-footer .logo-zettatronics {
  width: 200px;
  transform: translateX(10px);
}

.alerta-roja {
  color: #e4211b;
  font-size: 15px;
}
.alerta-verde {
  color: #00b34c;
  font-size: 15px;
}

.switch-login {
  width: 22px;
  height: 22px;
  cursor: pointer;
  position: relative;
}

.switch-login p {
  position: absolute;
  font-size: 22px;
  transition: 0.3s;
  display: flex;
  gap: 5px;
  align-items: center;
}

.switch-login p span {
  font-size: 12px;
  opacity: 0.5;
}

.switch-login p.sol {
  opacity: 0;
  transform: scale(0.01);
}

body.dark .switch-login p.sol {
  transform: scale(1);
  opacity: 1;
}
body.dark .switch-login p.luna {
  transform: rotate(360deg);
  opacity: 0;
}

.logo-login {
  width: 120px;
  position: absolute;
  bottom: 50px;
  left: 50%;
  transform: translateX(-50%);
}

/*CONTENEDOR GENERAL*/
.general-container {
  width: 100%;
  height: 100vh;
  transition: 0.3s;
  overflow: hidden;
}

/*WRAPPER CONTAINER*/
.box-flexbox {
  width: 100%;
  display: flex;
}

.wrapper-content {
  padding: 50px;
}

.wrapper-container {
  width: calc(100% - 300px);
  height: 100vh;
  overflow-y: scroll;
  /* padding: 50px; */
}

.wrapper-container::-webkit-scrollbar {
  background: transparent;
  width: 1px;
}

.wrapper-container::-webkit-scrollbar-thumb {
  background: rgba(0, 0, 0, 0);
  border-radius: 5000px;
}

.wrapper-boxs {
  width: 100%;
  position: relative;
}

body.dark .wrapper-container .bn {
  font-weight: 400;
}

.module__title {
  font-size: 16px;
  font-weight: 700;
  color: var(--primary__color);
  text-transform: uppercase;
}

.info-user {
  position: relative;
}

.user-menu {
  position: absolute;
  top: 125%;
  right: 0px;
  /* pointer-events: none; */
  transform: translateY(0px);
  opacity: 1;
  transition: 0.3s;
  z-index: 101;
  height: max-content;
  width: 275px;
  border-radius: 25px;
  background: var(--bacground);
  color: var(--foreground);
  border: 1px solid var(--border__light__card);
  display: none;
}

.user-menu.active {
  display: block;
}

.user__description {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 10px;
  cursor: pointer;
}

.user-menu .user__description {
  padding: 20px;
  border-bottom: 1px solid var(--border__light__card);
  cursor: initial;
}

.user__description .img-user-container {
  width: 30px;
  height: 30px;
  background: rgb(88, 0, 0);
  background: linear-gradient(
    75deg,
    rgba(88, 0, 0, 1) 0%,
    rgba(213, 27, 27, 1) 100%
  );
  overflow: hidden;
  border-radius: 100%;
}

.user__description .user__name {
  text-align: right;
  display: flex;
  flex-direction: column;
}

.user__description .user__name h1 {
  font-weight: 700;
  line-height: 1.2;
  font-size: 13px;
}
.user__description .user__name p {
  font-weight: 500;
  font-size: 13px;
  opacity: 0.6;
}

.user__links-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px;
  transition: 0.3s;
  border-radius: 5px;
  cursor: pointer;
}

.user__links-item:hover {
  background: var(--border__light__card);
  color: var(--primary__color);
}

.user__links-item svg {
  width: 18px;
  height: 18px;
  fill: currentColor;
}

.user__links-item p {
  font-size: 14px;
}

.user__links {
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 5px;
  border-bottom: 1px solid var(--border__light__card);
}

.user__button {
  padding: 20px;
}

.user__button .button__main {
  width: 100%;
}

/* ESTILOS DEL MENU */
.menui-container {
  width: 300px;
  height: 100vh;
  overflow-y: scroll;
  z-index: 100;
  border-right: 1px solid var(--border__light);
}

.menui-container::-webkit-scrollbar {
  background: transparent;
  width: 0px;
}

.menui-container::-webkit-scrollbar-thumb {
  background: rgba(0, 0, 0, 0);
  border-radius: 5000px;
}

.menui-container .logo img {
  width: 100%;
}

.main-left-container {
  width: 100%;
  height: max-content;
  padding: 25px 0;
  /* overflow-y: scroll; */
}

.main-left-container .ml-main {
  height: max-content;
  margin-top: 25px;
}

.ml-main-module,
.ml-main-submodule {
  width: 100%;
  height: max-content;
}

.ml-main-module {
  padding: 25px;
  border-top: 1px solid var(--border__light);
}

.ml-main-module {
  display: flex;
  flex-direction: column;
}

.ml-main-module-description {
  margin-bottom: 0px;
  transition: 0.3s !important;
  cursor: pointer;
  position: relative;
  padding-left: 15px;
}

.ml-main-module-description::before {
  content: "[-]";
  position: absolute;
  top: 50%;
  transform: translateY(-75%);
  left: 0;
  font-size: 10px;
}
.ml-main-module.expanded .ml-main-module-description::before {
  content: "[+]";
}
.ml-main-module.expanded .ml-main-module-description {
  margin-bottom: 25px;
}

.ml-main-module-description p {
  font-weight: 700;
  text-transform: uppercase;
  font-size: 11px;
}

.ml-main-module-description svg {
  display: none;
}
.ml-main-submodules-container {
  display: flex;
  flex-direction: column;
  gap: 25px;
  padding: 0 12.5px;
  max-height: 0px; /* Ajusta según el contenido esperado */
  overflow: hidden;
  transition: max-height 0.3s;
}
.ml-main-module.expanded .ml-main-submodules-container {
  max-height: 500px; /* Ajusta según el contenido esperado */
}
.ml-submodule .ml-submodule-description {
  display: flex;
  flex-direction: row-reverse;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  position: relative;
  cursor: pointer;
}

.ml-submodule .ml-submodule-description p {
  font-size: 14px;
  font-weight: 400;
  transition: 0.3s;
}

.ml-submodule .ml-submodule-description svg {
  width: 24px;
  height: 24px;
  padding: 4px;
  transition: 0.3s;
  overflow: visible;
}

.ml-submodule.active .ml-submodule-description svg {
  background: rgb(255, 3, 3);
  background: linear-gradient(
    20deg,
    rgba(255, 3, 3, 1) 0%,
    rgba(251, 78, 20, 1) 100%
  );
  border-radius: 100%;
  padding: 5px;
  fill: #fff;
}

.ml-submodule .ml-submodule-description:hover p {
  color: #ff0303;
}

.ml-submodule .ml-submodule-description:hover svg {
  fill: #ff0303;
}

.ml-submodule.active .ml-submodule-description:hover svg {
  fill: #ffffff;
}

/*HOME*/
.grafica-container {
  width: 100%;
  margin-top: 25px;
  padding: 25px;
  border: 1px solid #dce4f7;
  border-radius: 15px;
  box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.03);
}

body.dark .grafica-container {
  border: 1px solid rgba(255, 255, 255, 0.05);
  background: rgba(52, 52, 62, 0.1);
  background: linear-gradient(
    135deg,
    rgba(52, 52, 62, 0.2) 0%,
    rgba(24, 24, 33, 0.2) 68%
  );
  backdrop-filter: blur(10px);
  color: #fff;
  box-shadow: 0px 0px 10px rgba(255, 255, 255, 0.01);
}

.grafica-container h2,
.boxes-container h1 {
  text-align: center;
  font-size: 24px;
  font-weight: 700;
  margin-bottom: 15px;
  color: var(--primary__color);
}

body.dark .grafica-container h2,
body.dark .boxes-container h1 {
  color: #fff;
}

.boxes-container {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  gap: 25px;
  margin-top: 25px;
}

.boxes-container .boxs {
  width: 200px;
  height: 140px;
  border: 1px solid var(--border__light__card);
  border-radius: 25px;
  position: relative;
  overflow: hidden;
  background: var(--bacground);
  transition: 0.3s;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 25px;
}

.boxs__head {
  display: flex;
  justify-content: space-between;
}

.boxs__head .icon {
  width: 24px;
  fill: #e4211b;
}

.boxs__head h2 {
  font-weight: 700;
}
.boxs__body.horizontally {
  display: flex;
}
.boxs__body .total {
  display: flex;
  flex-direction: column;
  gap: 8px;
  width: 100%;
}

.boxs__body .total h3 {
  font-weight: 600;
  font-size: 14px;
  opacity: 0.4;
}

.boxs__body .total span {
  font-size: 17px;
  font-weight: 700;
}

.boxs:hover .total span {
  color: #e4211b;
}

.boxs:hover {
  border: 1px solid #e4211b;
}

.products__sales {
  margin-top: 50px;
}

/*HEADER*/
.top-header {
  position: sticky;
  width: 100%;
  height: max-content;
  top: 0;
  padding: 14px 30px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  z-index: 100;
  color: var(--color-primario-textos);
}

.top-header .switch {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 12px;
  width: max-content;
}

body.dark .top-header .switch {
  font-weight: 400;
}

.top-header .switch .indicator {
  width: 40px;
  height: 20px;
  background: rgba(0, 0, 0, 0.1);
  border-radius: 500px;
  position: relative;
  cursor: pointer;
}

body.dark .top-header .switch .indicator {
  background: #131314;
}

.top-header .switch .indicator::after {
  content: "";
  position: absolute;
  left: 0;
  width: 20px;
  height: 20px;
  background: var(--primary__color);
  border-radius: 50%;
  transition: 0.5s;
}

body.dark .top-header .switch .indicator::after {
  left: 20px;
  background: #b4b4b4;
}

.top-header .ml-panel-user {
  display: flex;
  align-items: center;
  gap: 10px;
  height: max-content;
  text-align: right;
}

.top-header .ml-panel-user img {
  width: 35px;
}

.top-header .ml-panel-user .ml-user-info {
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.top-header .ml-panel-user .ml-user-info .indicator {
  color: #00b34c;
}

.top-header .ml-panel-user .ml-user-info h1 {
  font-size: 14px;
  font-weight: 400;
}

.top-header .ml-panel-user .ml-user-info p {
  font-size: 14px;
  opacity: 0.8;
}

/*FOOTER*/
.footer-zetttatronics {
  width: 100%;
  text-align: center;
  padding: 14px 0;
  margin-top: 50px;
}

.footer-zetttatronics h1 {
  font-weight: 600;
  font-size: 14px;
}
.footer-zetttatronics p {
  font-weight: 600;
  font-size: 14px;
  opacity: 0.7;
  margin-top: 5px;
}

/*CONTROLES DEL HEADER DE LAS TABLAS */
.controls-table-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 25px;
}

.content {
  padding: 0 !important;
}

.controls-table-header.controls {
  align-items: flex-start;
}
.grupo-fb-controls {
  width: max-content;
  display: flex;
  justify-content: flex-start;
  gap: 10px;
}

.controls-table-header .control-search,
.controls-table-header .header-input-grupo,
.formulario-container-modal .control-search {
  display: flex;
  align-items: center;
  height: max-content;
  width: 300px;
  position: relative;
}

.formulario-container-modal .control-search {
  width: 100%;
  margin-top: 25px;
}

.controls-table-header.controls .header-input-grupo {
  width: 50%;
  flex-wrap: wrap;
}

.controls-table-header .control-search .search,
.formulario-container-modal .control-search .search,
.controls-table-header .header-input-grupo input,
.controls-table-header .header-input-grupo .list {
  background: var(--search__background);
  border: 1px solid var(--search__border);
  outline: none;
  height: 50px;
  border-radius: 15px;
  padding-left: 20px;
  width: 100%;
  font-size: 16px;
  font-weight: 500;
  color: var(--primary__color);
}
.formulario-container-modal .control-search .search {
  background: #fff;
  margin: 0 20px;
  color: #000;
}

.controls-table-header .control-search .search-btn,
.formulario-container-modal .control-search .search-btn {
  position: absolute;
  right: 0%;
  top: 50%;
  transform: translateY(-50%);
  border: none;
  background: none;
  outline: none;
  color: var(--primary__color);
  font-size: 16px;
}

.controls-table-header .control-search .search::placeholder,
.controls-table-header .header-input-grupo input::placeholder {
  font-size: 14px;
  color: #7c7c7c;
}

/* .controls-table-header .header-input-grupo .list button, */
.controls-table-header .header-input-grupo button {
  width: 100%;
  height: 100%;
  left: 0;
  background: none;
  border: 2px solid var(--primary__color);
  outline: none;
  font-size: 12px;
  font-weight: 600;
  color: var(--primary__color);
  padding: 7px 10px;
}

.controls-table-header .header-input-grupo.hig-bordes button {
  border-radius: 0px 5px 5px 0;
}

.controls-table-header .header-input-grupo.hig-bordes input,
.controls-table-header .header-input-grupo.hig-bordes .list {
  border-radius: 5px 0px 0px 5px;
}

.controls-table-header .header-input-grupo button:hover {
  background: var(--primary__color);
  color: #fff;
}

.controls-table-header .botones-header {
  display: flex;
  gap: 10px;
}

.controls-table-header .bh-btn {
  background: transparent;
  color: #ffffff;
  font-weight: 600;
  height: max-content;
  padding: 14px 20px;
  border-radius: 15px;
  font-size: 12px;
  position: relative;
  border: 1px solid var(--primary__color);
  background: var(--primary__color);
  transition: 0.3s;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
}

.controls-table-header .bh-btn:hover {
  background: var(--primary__color);
  color: #fff;
}

.controls-table-header .bh-btn.bh-btn-green {
  background: #00b34c;
  color: #fff;
  border: 1px solid #00b34c;
}

.controls-table-header .bh-btn-mostrar-list:hover .mostrar-list,
.controls-table-header .bh-btn-mostrar-list:hover .mostrar-list:hover {
  opacity: 1;
  pointer-events: all;
}

.controls-table-header .bh-btn .mostrar-list {
  position: absolute;
  background: var(--bacground);
  color: var(--foreground);
  text-align: right;
  padding: 10px;
  z-index: 1;
  top: 106%;
  right: 0;
  width: 150px;
  border-radius: 10px;
  border: 1px solid var(--border__light);
  pointer-events: none;
  opacity: 0;
  transition: 0.2s;
}

.controls-table-header .bh-btn .mostrar-list li {
  padding: 6px 20px;
  width: 100%;
  border-radius: 5px;
}

.controls-table-header .bh-btn .mostrar-list li.active,
.controls-table-header .bh-btn .mostrar-list li.active:hover,
.controls-table-header .bh-btn .mostrar-list li:hover {
  background: var(--primary__color);
  color: #fff;
}

.controls-table-header .header-input-grupo .hi-grupo {
  width: 200px;
}

.controls-table-header.controls .header-input-grupo .hi-grupo .control-search {
  width: 100%;
}

.controls-table-header .header-input-grupo .hi-grupo input,
.controls-table-header .header-input-grupo .hi-grupo select {
  width: 100%;
}

.bootstrap-select:not([class*="col-"]):not([class*="form-control"]):not(
    .input-group-btn
  ) {
  width: 100%;
}

/*CONTROLES DEL FOOTER DE LAS TABLAS */
.controls-table {
  height: max-content;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 5px;
  margin-top: 20px;
  font-weight: 600;
  font-size: 13px;
  color: var(--foreground);
}
.formulario-container-modal .controls-table {
  justify-content: center;
}
.controls-table .cambiar-tabla-controles {
  display: flex;
  align-items: center;
  gap: 5px;
}

.controls-table .cambiar-tabla-controles li {
  background: transparent;
  /* border: 2px solid #0396FF; */
  min-width: max-content;
  padding: 5px 10px;
  transition: 0.3s;
  border-radius: 5px;
}

.controls-table .cambiar-tabla-controles li.contador-pagina {
  background: var(--primary__color);
  color: #fff;
}

.formulario-container-modal
  .controls-table
  .cambiar-tabla-controles
  li.contador-pagina,
body.dark
  .formulario-container-modal
  .controls-table
  .cambiar-tabla-controles
  li.contador-pagina {
  background: #fff;
}
.formulario-container-modal
  .controls-table
  .cambiar-tabla-controles
  li.contador-pagina
  a {
  color: var(--primary__color);
}

/* TABLAS */
.tables-home-container {
  display: flex;
  gap: 50px;
  margin-top: 50px;
}

.tables-home-container .table-1 {
  width: 50%;
  height: max-content;
}
.tables-home-container .table-2 {
  width: 50%;
  height: max-content;
}

.tables-home-container .table-container {
  margin-top: 25px;
  padding: 25px;
  gap: 0;
  border-radius: 25px;
}

.table-container {
  width: 100%;
  padding: 50px;
  background: var(--bacground);
  border-radius: 50px;
  border: 1px solid var(--border__light__card);
  display: flex;
  flex-direction: column;
  gap: 25px;
}

.formulario-container-modal .table-container {
  max-width: 500px;
  background: transparent;
  padding: 0px 20px 30px;
  margin-top: 0;
  border: none;
}

.card-form-contaiter .table-container {
  background: transparent;
  padding: 0px 20px 30px;
  margin-top: 0;
  border: none;
}

.table-container.tv {
  padding: 0;
}

.th-footer {
  display: flex;
  justify-content: space-between;
}
.tables-home-container .table-2 .th-footer,
.tables-home-container .table-1 .th-footer {
  justify-content: flex-end;
  margin-top: 30px;
  gap: 10px;
}
.th-footer a {
  padding: 10px 20px;
  background: var(--primary__color);
  border-radius: 10px;
  color: #fff;
  font-size: 12px;
}

.table-container h1 {
  font-size: 16px;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--primary__color);
}

.table-container .table-content {
  width: 100%;
  overflow-x: scroll;
}

.table-container .table-content::-webkit-scrollbar {
  background: transparent;
  height: 3px;
}

.table-container .table-content::-webkit-scrollbar-thumb {
  background: var(--primary__color);
  border-radius: 5000px;
}

.table-container .table-content table {
  min-width: 100%;
  border-collapse: collapse;
  table-layout: fixed;
}

.table-container .table-content table tr {
  border-bottom: 1px solid var(--border__light);
  transition: 0.3s;
}

.table-container .table-content table tbody tr:hover {
  background: rgba(255, 0, 51, 0.1);
}

.table-container .table-content table thead tr th {
  font-size: 14px;
  min-width: max-content;
  position: relative;
  font-weight: 500;
  padding: 10px 15px;
  transition: 0.2s;
  text-align: center;
}
.table-container.tv .table-content table thead tr th {
  padding: 0px 0px;
}

.table-container .table-content table tbody tr td {
  text-align: center;
  padding: 10px 15px;
  font-size: 14px;
  position: relative;
  vertical-align: middle;
  line-height: 1.5;
  transition: 0.2s;
  white-space: nowrap;
  text-align: center;
  text-transform: capitalize !important;
  opacity: 0.6;
}
.table-container .table-content table tbody tr td.ta-left {
  text-align: left;
}
.table-container.tv .table-content table tbody tr td {
  padding: 0px 8px;
}

.table-container .table-content table tbody tr td.pd-none {
  padding: 0;
}
.formulario-container-modal .table-container .table-content table tbody tr td,
.card-form-contaiter .table-container .table-content table tbody tr td {
  background: #d41c3e;
}

.formulario-container-modal
  .table-container
  .table-content
  table
  tbody
  tr:hover
  td,
.card-form-contaiter .table-container .table-content table tbody tr:hover td {
  background: #b61936;
}

.pointerevents-none {
  pointer-events: none;
}

.formulario-container-modal
  .table-container
  .table-content
  table
  tbody
  tr
  td:nth-of-type(1),
body.dark
  .formulario-container-modal
  .table-container
  .table-content
  table
  tbody
  tr
  td:nth-of-type(1),
.card-form-contaiter
  .table-container
  .table-content
  table
  tbody
  tr
  td:nth-of-type(1),
body.dark
  .card-form-contaiter
  .table-container
  .table-content
  table
  tbody
  tr
  td:nth-of-type(1) {
  border-left: 4px solid #fff;
}

.table-container .table-content table tbody tr td a.tabla-btn-accion {
  margin: 0 5px;
  cursor: pointer;
}

.table-container .table-content table tbody tr td a.tabla-btn-accion svg {
  width: 20px;
}

.table-container .table-content table tbody tr td a.tabla-btn-accion.ba-verde {
  color: #05c775;
}

.table-container
  .table-content
  table
  tbody
  tr
  td
  a.tabla-btn-accion.ba-cancelar-solicitud {
  color: #cc0f0f;
}

.table-container
  .table-content
  table
  tbody
  tr
  td
  a.tabla-btn-accion.ba-ver-solicitud {
  color: #0fbfcc;
}

.table-container
  .table-content
  table
  tbody
  tr
  td
  a.tabla-btn-accion.ba-rechazar-solicitud
  svg {
  fill: #cc0f0f;
}

/* .table-container .table-content table tbody tr td a.tabla-btn-accion.ba- svg{
  fill: #fb0c06;
} */
.table-container
  .table-content
  table
  tbody
  tr
  td
  a.tabla-btn-accion.ba-eliminar-solicitud
  svg {
  fill: #cc0f0f;
}

.table-container
  .table-content
  table
  tbody
  tr
  td
  a.tabla-btn-accion.ba-aceptar-cancelacion {
  color: rgb(245, 98, 23);
}

.table-container .table-content table tbody tr td a.tabla-btn-accion.ba-azul {
  color: #24c0eb;
}

.table-container
  .table-content
  table
  tbody
  tr
  td
  a.tabla-btn-accion.ba-naranja {
  color: #f2511b;
}

.table-container .table-content table tbody tr td a.tabla-btn-accion.ba-rojo {
  color: #f01945;
}

.table-container
  .table-content
  table.tabla-lista-empleados
  tbody
  tr
  td:nth-of-type(2),
.table-container
  .table-content
  table.tabla-lista-empleados
  tbody
  tr
  td:nth-of-type(3) {
  text-align: left;
  padding-left: 20px;
}

.table-container.tc .table-content table tbody tr td:last-child {
  width: max-content !important;
  opacity: 1 !important;
}

.table-container .table-content table.tabla-asistencia tbody tr td:last-child {
  background: #f2f4f8;
  width: auto;
}

.table-container td.estatus-activo {
  color: #05c775;
}

.table-container td.estatus-inactivo {
  color: #cc0f0f;
}

.table-container td.estatus-autorizado {
  color: #0fbfcc;
}

.table-container td.estatus-rechazado {
  color: #f0c505;
}

.table-container td.estatus-azul-rey {
  color: #1c31a5;
}
.table-container td.estatus-validar-solicitud {
  color: #f56217;
}

.table-container td.estatus-validar {
  color: #1c31a5;
}

.table-container td.estatus-proceso-cancelacion {
  color: #468b06;
}

.table-container td.estatus-activo,
.table-container td.estatus-inactivo,
.table-container td.estatus-autorizado,
.table-container td.estatus-rechazado,
.table-container td.estatus-azul-rey,
.table-container td.estatus-validar-solicitud,
.table-container td.estatus-validar,
.table-container td.estatus-proceso-cancelacion {
  font-weight: 600;
  opacity: 1 !important;
  text-align: center;
}

.table-container .table-content table.lista-usuarios tbody tr td:last-child {
  min-width: 160px;
}

.table-container .btn-table-container {
  display: flex;
  justify-content: center;
}

.table-container .btn-table-container button {
  background: var(--primary__color);
  border: 2px solid transparent;
  transition: 0.3s;
}

body.dark .table-container .btn-table-container button {
  background: #1c51ff;
}

.table-container .btn-table-container button:hover {
  background: transparent;
  color: var(--primary__color);
  border: 2px solid var(--primary__color);
}

body.dark .table-container .btn-table-container button:hover {
  background: transparent;
  color: #fff;
  border: 2px solid #1c51ff;
}

body.dark .table-container select {
  background: #131314;
}
/*PERFIL DE LA EMPRESA*/
.card-profile {
  max-width: 800px;
  gap: 25px;
  margin-top: 20px;
  background: var(--bacground);
  border: 1px solid var(--border__light__card);
  border-radius: 50px;
  padding: 50px;
  margin: auto;
  display: flex;
  flex-direction: column;
  gap: 25px;
}

.card-profile .module__title {
  text-align: center;
}

.card-profile .card-image-container {
  width: 100%;
  height: 500px;
  display: flex;
  align-items: center;
  flex-direction: column;
  gap: 25px;
}

.image__prof {
  width: 260px;
  height: 100%;
  border-radius: 25px;
  background: var(--border__light__card);
  overflow: hidden;
  position: relative;
}

.card-profile .card-image-container img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.description__profile {
  height: max-content;
  width: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 15px 0;
  position: relative;
}

.dprofile__head {
  display: flex;
  justify-content: space-between;
}

.profile__name {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.card-profile .card-image-container h2 {
  font-weight: 700;
  font-size: 18px;
  text-align: center;
}

.card-profile .card-image-container p {
  font-weight: 500;
  font-size: 14px;
  opacity: 0.7;
}
.card-form-contaiter {
  width: 100%;
  overflow-x: hidden;
  height: max-content;
}
.card-form-contaiter h1 {
  font-size: 22px;
  text-align: center;
  margin-bottom: 25px;
  font-weight: 700;
}
.file__input {
  background: none;
  padding: none;
  margin-top: 10px;
  border: none !important;
  outline: none !important;
}
.table-container .table-content table tbody tr td.estatus-retirado {
  background: #cc0f0f;
  color: #fff;
  font-weight: 600;
  text-align: center;
}

.card-form-contaiter .card-controls {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 50px;
  width: 100%;
  height: max-content;
  margin-bottom: 50px;
}

.card-form-contaiter .card-controls p {
  background: transparent;
  opacity: 0.5;
  cursor: pointer;
  transition: 0.3s;
  font-size: 14px;
  font-weight: 500;
}
.card-form-contaiter .card-controls p:hover,
.card-form-contaiter .card-controls p.card-control-activo {
  color: var(--primary__color);
  opacity: 1;
}

.card-form-contaiter .form {
  width: 100%;
}

.form-grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 15px;
}

.grid-span-2 {
  grid-column: 2 span;
}

.flex__row {
  display: flex;
  gap: 10px;
  align-items: flex-end;
}

.card-form-contaiter .form.ocultar-form-card {
  display: none;
}
.card-form-contaiter .card-form-group {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 10px;
  max-width: 100%;
}
.card-form-contaiter .form.form-grid-2 .card-form-group {
  margin-top: 0px;
}
.card-form-contaiter .grupo-horario-laboral {
  margin: 20px 0;
  padding: 20px 0;
  border-top: 1px solid rgba(0, 0, 0, 0.1);
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
}
.card-form-contaiter .flexbox-grupos {
  display: flex;
  gap: 10px;
}
.card-form-contaiter h4 {
  font-size: 20px;
  margin-bottom: 20px;
  font-weight: 700;
}
.card-form-contaiter .card-form-group label {
  font-size: 13px;
  font-weight: 500;
  line-height: 1.3;
}
.card-form-contaiter .card-form-group input,
.card-form-contaiter .card-form-group select,
.card-form-contaiter .card-form-group textarea {
  width: 100%;
  height: 40px;
  padding: 0px 10px;
  border-radius: 14px;
  outline: none;
  border: 1px solid var(--search__border);
  font-size: 14px;
  background: none;
}
.card-form-contaiter .card-form-group textarea {
  padding: 10px;
}
.card-form-contaiter .card-form-group input.bg-none,
.card-form-contaiter .card-form-group select.bg-none,
body.dark .card-form-contaiter .card-form-group input.bg-none,
body.dark .card-form-contaiter .card-form-group select.bg-none {
  background: none;
  border: none;
}
.card-form-contaiter .card-form-group input::placeholder,
.card-form-contaiter .card-form-group select::placeholder,
.card-form-contaiter .card-form-group textarea::placeholder {
  opacity: 0.7;
}

.card-form-contaiter .card-form-group textarea {
  resize: none;
}
.card-form-contaiter .card-form-group select option {
  background: var(--bacground);
  color: var(--foreground);
}
.card-form-contaiter .card-form-group button {
  width: max-content;
  margin: auto;
  background: #fff;
  color: var(--primary__color);
  font-weight: 700;
}
.card-form-contaiter .card-form-input-password {
  position: relative;
}
.card-form-contaiter .card-form-input-password input {
  width: 100%;
}
.card-form-contaiter .card-form-group input.btn-generar-password {
  background: var(--color-primario);
  color: #fff;
  font-weight: 500;
}
.card-form-contaiter .card-form-input-password .ver-password {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 5px;
  background: none;
  border: none;
  display: flex;
  justify-content: center;
  align-items: center;
}
.card-form-contaiter .card-form-input-password svg {
  width: 22px;
}
.card-form-contaiter .card-form-input-password svg.seen {
  display: none;
}
.card-form-contaiter .card-form-group.cfg-btns {
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  gap: 10px;
  max-width: max-content;
  margin: auto;
  padding-top: 15px;
}
.card-submit-container {
  margin-top: 25px;
}
.card-submit-container button {
  position: relative;
  left: 50%;
  transform: translateX(-50%);
  padding: 12px 50px;
  border: none;
  background: var(--color-primario);
  color: #fff;
  border-radius: 5px;
  font-weight: 500;
}

.buttons-container {
  display: flex;
  margin-top: 50px;
  gap: 10px;
  justify-content: flex-end;
}
.buttons-container .button__main:first-child {
  background: transparent;
  color: var(--primary__color) !important;
  border: 1px solid var(--primary__color);
}
/* MODALES */
/* .modal {
  padding-bottom: 50px;
} */

.formulario-container-modal {
  background: var(--bacground);
  border: 1px solid var(--border__light__card);
  width: 500px;
  height: max-content;
  padding: 0px;
  border-radius: 25px;
  overflow: hidden;
  margin-left: 50%;
  transform: translateX(-50%);
  margin-bottom: 50px;
  margin-top: 50px;
}

.abrir-menu {
  display: none;
}

@media screen and (max-width: 1440px) {
  .formulario-container-modal {
    top: 10%;
    left: 50%;
    transform: translate(-50%, 0%);
  }
}

.formulario-container-modal .modal-head,
.formulario-container-modal .modal-b {
  padding: 25px 25px 0;
}

.formulario-container-modal .modal-b {
  display: flex;
  flex-direction: column;
  gap: 15px;
}

.formulario-container-modal h1 {
  font-size: 16px;
  font-weight: 700;
  color: var(--primary__color);
  text-transform: uppercase;
}

.formulario-container-modal h2 {
  font-size: 14px;
  font-weight: 700;
}
.formulario-container-modal .img-100-container {
  width: 100%;
  height: 300px;
  position: relative;
  margin-bottom: 50px;
}
.formulario-container-modal .img-100-container img {
  width: 100%;
  height: 100%;
}
.formulario-container-modal .fcm-flexbox {
  display: flex;
  gap: 20px;
}

.formulario-container-modal .fcm-flexbox .fcm-flexbox-img {
  width: 150px;
  height: max-content;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.formulario-container-modal .fcm-flexbox .fcm-flexbox-img img {
  width: 100%;
}

.formulario-container-modal .fcm-flexbox .fcm-flexbox-img .label-img {
  text-align: center;
}

.formulario-container-modal .fcm-flexbox .fcm-flexbox-img .btn-elegir-img {
  text-align: center;
  background: var(--color-secundario);
  width: 100%;
  height: 35px;
  border-radius: 5px;
  font-weight: 500;
  font-size: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.formulario-container-modal .grid-2-formulario {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.formulario-container-modal .controles-solicitud-permisos {
  margin-top: 10px;
  width: 400px;
}

.formulario-container-modal .controles-solicitud-permisos label {
  font-size: 15px;
  font-weight: 500;
  margin: 0 5px;
}

.formulario-container-modal .form-group-modal {
  flex-direction: column;
  display: flex;
  gap: 8px;
  width: 100%;
}

.formulario-container-modal .grid-2-formulario .form-group-modal {
  margin: 0;
}

.formulario-container-modal .grid-2-formulario h2 {
  grid-column: 2 span;
}

.formulario-container-modal .form-group-modal label {
  font-weight: 600;
  font-size: 14px;
}

.formulario-container-modal .form-contador .form-group-modal {
  text-align: center;
}

.formulario-container-modal .form-group-modal input,
.formulario-container-modal .form-group-modal select,
.formulario-container-modal .form-group-modal textarea {
  width: 100%;
  height: 40px;
  border: 1px solid transparent;
  border-radius: 15px;
  padding: 0 15px;
  font-size: 14px;
  outline: none;
  transition: 0.3s;
  background: var(--input__background);
  color: var(--foreground);
}

.formulario-container-modal .form-group-modal input::placeholder,
.formulario-container-modal .form-group-modal textarea::placeholder {
  opacity: 0.7;
  font-weight: 500;
}

.formulario-container-modal .form-group-modal textarea {
  height: 80px;
  resize: none;
}

.formulario-container-modal .form-group-modal input:hover,
.formulario-container-modal .form-group-modal select:hover,
.formulario-container-modal .form-group-modal textarea:hover,
.formulario-container-modal .form-group-modal input:focus,
.formulario-container-modal .form-group-modal select:focus,
.formulario-container-modal .form-group-modal textarea:focus {
  border: 1px solid var(--primary__color);
}

input[type="checkbox"]:checked {
  accent-color: var(--color-primario);
}

.formulario-container-modal .tabla-permisos-grupo {
  font-size: 14px;
  font-weight: 500;
  border-collapse: separate;
  border-spacing: 5px;
  table-layout: fixed;
}

.formulario-container-modal .tabla-permisos-grupo thead tr th {
  /* background: red; */
  min-width: max-content;
}

.formulario-container-modal .fg-modal-botones {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  padding: 25px 25px;
}

.formulario-container-modal .fg-modal-botones .fg-boton {
  background: var(--primary__color);
  color: #fff;
  font-weight: 500;
  padding: 5px 25px;
  border-radius: 13px;
  font-size: 12px;
  border: 1px solid transparent;
}

.formulario-container-modal .fg-modal-botones .fg-boton:nth-of-type(1) {
  background: transparent;
  color: var(--primary__color);
  border-color: 1px solid var(--primary__color);
}

.formulario-container-modal .fg-modal-botones .fg-boton.disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.ver-perfil-empleado .vpe-header {
  width: 100%;
  text-align: center;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.ver-perfil-empleado .vpe-header .vpe-header-img {
  width: 120px;
  margin: auto;
  height: 120px;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 15px;
}

.ver-perfil-empleado .vpe-header .vpe-header-img img {
  width: 100px;
}

.ver-perfil-empleado .vpe-header h1 {
  font-size: 18px;
  font-weight: 700;
}

.ver-perfil-empleado .vpe-header .btn-select-img {
  background: var(--color-secundario);
  margin: 5px 0;
  width: 100%;
  padding: 8px;
  border-radius: 5px;
  cursor: pointer;
}

.ver-perfil-empleado .vpe-body {
  margin-top: 20px;
  width: 100%;
  /* overflow: hidden; */
  /* background: yellowgreen; */
  position: relative;
}

.ver-perfil-empleado .vpe-body .vpe-body-controls,
.ayuda-controls {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 20px;
  margin-bottom: 40px;
}

.ayuda-controls {
  margin-top: 25px;
}

a.bold {
  color: var(--primary__color);
}

body.dark a.bold {
  color: rgb(28, 81, 255);
}

.ver-perfil-empleado .vpe-body .vpe-body-controls p,
.ayuda-controls p {
  background: transparent;
  /* padding: 8px 14px; */
  border-radius: 5px;
  cursor: pointer;
  transition: 0.5s;
  font-size: 16px;
  font-weight: 600;
  opacity: 0.5;
  /* border: 1px solid #fff; */
}

.ver-perfil-empleado .vpe-body .vpe-body-controls p.card-control-activo,
.ver-perfil-empleado .vpe-body .vpe-body-controls p:hover,
.ayuda-controls p.card-control-activo,
.ayuda-controls p:hover {
  opacity: 1;
}

.ver-perfil-empleado .vpe-body .vpe-body-flexbox {
  margin-top: 20px;
  /* display: bl; */
  /* width: 500px; */
  transition: 0.5s;
}

.ver-perfil-empleado .vpe-body .vpe-body-flexbox .vpe-body-grupos {
  width: 100%;

  /* display: grid;
  grid-template-columns:  1fr 1fr;
  gap: 10px; */
}
.ver-perfil-empleado
  .vpe-body
  .vpe-body-flexbox
  .vpe-body-grupos.ocultar-grupo {
  display: none;
}

.ver-perfil-empleado .vpe-body .vpe-body-flexbox .vpe-body-group {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 10px;
  width: 100%;
}

.ver-perfil-empleado .vpe-body .vpe-body-flexbox .grupo-horario-laboral {
  margin: 20px 0;
  padding: 20px 0;
  border-top: 1px solid rgba(0, 0, 0, 0.1);
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
}

.ver-perfil-empleado .vpe-body .vpe-body-flexbox h4 {
  font-size: 20px;
  margin-bottom: 20px;
  font-weight: 700;
}

.ver-perfil-empleado .vpe-body .vpe-body-flexbox .vpe-body-group label {
  font-size: 16px;
  font-weight: 500;
}

.ver-perfil-empleado .vpe-body .vpe-body-flexbox .vpe-body-group label.error {
  color: #ffc219;
  line-height: 1.5;
  font-size: 14px;
  /* margin-top: 2px; */
}

.ver-perfil-empleado .vpe-body-group input,
.ver-perfil-empleado .vpe-body-group select {
  max-width: 100%;
  width: 100%;
  height: 30px;
  padding: 0px 10px;
  border-radius: 5px;
  background: #d41c3e;

  border: 1px solid transparent;
  transition: 0.3s;
}

.ver-perfil-empleado .vpe-body-group input:hover,
.ver-perfil-empleado .vpe-body-group select:hover {
  border: 1px solid #fff;
}

body.dark
  .ver-perfil-empleado
  .vpe-body
  .vpe-body-flexbox
  .vpe-body-group
  input,
body.dark
  .ver-perfil-empleado
  .vpe-body
  .vpe-body-flexbox
  .vpe-body-group
  select {
  background: #0a3de7;
}

.formulario-container-modal .modal-arbol-container {
  max-width: 100%;
  margin-top: 25px;
}

.max-width-900 {
  max-width: 900px;
}

.input-group-addon {
  border: none;
}

.img-ayuda-container {
  width: 500px;
  margin-top: 25px;
}

.img-ayuda-container img {
  width: 100%;
}

.img-ayuda-container img#img_transferencia,
.img-ayuda-container img#img_deposito {
  display: none;
}

.img-ayuda-container img#img_transferencia.img-active,
.img-ayuda-container img#img_deposito.img-active {
  display: block;
}

.formulario-container-modal .tabla-permisos-grupo {
  font-size: 14px;
  font-weight: 600;
  border-collapse: separate;
  border-spacing: 5px;
}

.abrir-menu {
  display: none;
}

/* VENTA DE MESAS */
.ventas-container {
  width: 100%;
  background: #fff;
}

body.dark .ventas-container {
  background: rgb(52, 52, 62);
  background: linear-gradient(
    135deg,
    rgba(52, 52, 62, 1) 0%,
    rgba(24, 24, 33, 1) 68%
  );
}

.ventas-container .v-header {
  padding: 25px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.ventas-container .v-header a {
  padding: 10px;
  border-radius: 5px;
  font-size: 14px;
  font-weight: 600;
}

.ventas-container .v-header a.green {
  background: #00b34c;
  color: #fff;
}

.ventas-container .v-header a.red {
  background: #cc0f0f;
  color: #fff;
}

.ventas-container .ventas-flexbox {
  display: flex;
}

/* PRODUCTOS */
.ventas-container .ventas-flexbox .productos-container {
  width: 65%;
  padding: 15px 25px;
}
.ventas-container .v-header .productos-controls {
  width: 64%;
  display: flex;
  gap: 25px;
}

.ventas-container .v-header .productos-controls input,
.ventas-container .v-header .productos-controls select {
  width: 50%;
}

.ventas-container .listado_productos {
  display: flex;
  flex-wrap: wrap;
  gap: 35px;
}

.ventas-container .listado_productos .card-producto {
  width: 250px;
  height: 190px;
  border-radius: 5px;
  overflow: hidden;
}

.ventas-container .listado_productos .card-producto .producto_img {
  width: 100%;
  height: 125px;
  border-radius: 0px 0px 10px 10px;
  overflow: hidden;
}

.ventas-container .listado_productos .card-producto:hover .producto_img img {
  transform: scale(1.1);
}

.ventas-container .listado_productos .card-producto .producto_img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  background-origin: center;
  transition: 0.3s;
}

.ventas-container .listado_productos .card-producto .prducto-info {
  padding: 15px;
}

.ventas-container
  .listado_productos
  .card-producto
  .prducto-info
  .nombre_producto {
  font-weight: 500;
  font-size: 15px;
  margin-top: 5px;
}
.ventas-container
  .listado_productos
  .card-producto
  .prducto-info
  .precio_producto {
  font-size: 20px;
  font-weight: 800;
  color: #000;
}
body.dark .ventas-container .listado_productos .card-producto .prducto-info,
body.dark
  .ventas-container
  .listado_productos
  .card-producto
  .prducto-info
  .precio_producto {
  color: #fff;
}
body.dark .ventas-container input,
body.dark .ventas-container select {
  background: #131314;
  color: #fff;
}
body.dark .ventas-container input::placeholder {
  color: #fff;
  opacity: 0.7;
}
/* CUENTA */
.ventas-container .ventas-flexbox .cuenta-container {
  width: 35%;
  padding: 0 25px 25px;
}
body.dark .ventas-container .ventas-flexbox .cuenta-container {
  color: #fff;
}
.ventas-container .ventas-flexbox .cuenta-container .cuenta-controls .form-g {
  pointer-events: none;
}
.ventas-container
  .ventas-flexbox
  .cuenta-container
  .cuenta-controls
  .form-g
  label {
  font-size: 14px;
}
.ventas-container
  .ventas-flexbox
  .cuenta-container
  .cuenta-controls
  .form-g
  input {
  background: none;
  padding: 0;
  font-weight: 600;
}
.ventas-container
  .ventas-flexbox
  .cuenta-container
  .cuenta-controls
  .form-g
  input:hover {
  border: 1px solid transparent;
}
.calculador-container {
  margin-bottom: 40px;
}
.calculador-container h1 {
  font-size: 24px;
  font-weight: 700;
  margin-bottom: 15px;
  color: var(--primary__color);
}

body.dark .calculador-container h1 {
  color: #fff;
}

.calculador-container .cc-group {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 25px;
  margin: 15px 0;
}
.calculador-container button {
  width: 100%;
  margin-top: 20px;
  background: var(--primary__color);
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
}
body.dark .calculador-container button {
  background: var(--color-secundario);
}

.calculador-container button:hover {
  color: var(--primary__color);
  border: 1px solid var(--primary__color);
  background: transparent;
}

body.dark .calculador-container button:hover {
  border: 1px solid var(--color-secundario);
  color: #fff;
}

.ventas-container .ventas-flexbox .cuenta-container .client-group,
.ventas-container .ventas-flexbox .cuenta-container .code-group {
  width: 100%;
  display: flex;
  gap: 10px;
  margin-bottom: 10px;
}
.ventas-container .ventas-flexbox .cuenta-container .client-group select,
.ventas-container .ventas-flexbox .cuenta-container .code-group input {
  width: 100%;
}
.ventas-container
  .ventas-flexbox
  .cuenta-container
  .code-group
  input:nth-of-type(1) {
  text-align: center;
  width: 80px;
}
.ventas-container .ventas-flexbox .cuenta-container .client-group button,
.ventas-container .ventas-flexbox .cuenta-container .code-group button {
  min-width: max-content;
  background: var(--primary__color);
  font-weight: 600;
}
body.dark
  .ventas-container
  .ventas-flexbox
  .cuenta-container
  .client-group
  button,
body.dark
  .ventas-container
  .ventas-flexbox
  .cuenta-container
  .code-group
  button {
  background: var(--color-secundario);
}
.ventas-container .ventas-flexbox .cuenta-container .client-group button:hover,
.ventas-container .ventas-flexbox .cuenta-container .code-group button:hover {
  background: transparent;
  border: 1px solid var(--primary__color);
  color: var(--primary__color);
}
body.dark
  .ventas-container
  .ventas-flexbox
  .cuenta-container
  .client-group
  button:hover,
body.dark
  .ventas-container
  .ventas-flexbox
  .cuenta-container
  .code-group
  button:hover {
  background: transparent;
  border: 1px solid var(--color-secundario);
  color: #fff;
}

body.dark .ventas-container .table-container table td,
body.dark .ventas-container .table-container table th {
  color: #fff;
}
/********************************************************/
.header__switchs {
  display: flex;
  align-items: center;
  gap: 10px;
}

.toggle__menu {
  display: none;
}

@media screen and (min-width: 280px) and (max-width: 767px) {
  .menui-container {
    background: var(--bacground);
    position: absolute;
    z-index: 101111;
    width: 100%;
    left: 0;
    top: 0;
    overflow-y: scroll;
    clip-path: polygon(0 0, 100% 0, 100% 0, 0 0);
    transition: .3s ease-in;

  }

  body.menu-activo .menui-container {
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0% 100%);
  }

  .toggle__menu {
    width: 25px;
    display: flex;
    flex-direction: column;
    gap: 5px;
  }

  .toggle__menu span {
    width: 100%;
    height: 1px;
    background: var(--foreground);
    display: block;
  }

  .top-header {
    padding: 15px;
  }

  .user__description .user__name h1 {
    font-size: 11px;
    max-width: 150px;
    text-align: right;
  }

  .wrapper-container {
    width: 100%;
    height: 100vh;
    overflow-y: scroll;
    /* padding: 50px; */
  }

  .wrapper-content {
    padding: 15px;
  }

  .controls-table-header {
    width: 100%;
    margin: auto;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    padding: 0 0%;
    gap: 10px;
    margin-bottom: 25px;
  }

  .controls-table-header .control-search,
  .controls-table-header .header-input-grupo {
    width: 100%;
  }

  .controls-table-header .botones-header {
    margin: 0px 0;
    width: 100%;
  }

  .controls-table-header .bh-btn {
    width: 100%;
  }

  .table-container {
    background: none;
    margin-top: 0px;
    border: none;
    padding: 0;
  }

  .controls-table {
    height: max-content;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    gap: 10px;
    font-size: 12px;
  }

  .controls-table .cambiar-tabla-controles {
    width: max-content;
    overflow-x: scroll;
  }

  .top-header .logo {
    margin-left: 5%;
  }

  .ml-panel-user .ml-user-info h1 {
    display: none;
  }

  .close__menu {
    position: absolute;
    width: 35px;
    height: 35px;
    color: var(--foreground);
    top: 10px;
    right: 10px;
  }

  .close__menu .icono-cerrar {
    width: 100%;
  }

  .contenido.contenido-flexbox {
    flex-direction: column;
    transform: translateX(-8px);
  }

  .carousel-container {
    width: 100%;
  }

  .boxes-container {
    width: 100%;
  }

  .boxes-container .boxes {
    flex-direction: column;
  }

  .boxes-container .boxes .box {
    width: 100%;
  }

  .wrapper-boxs h1 {
    text-align: center;
  }

  .wrapper-boxs h2 {
    text-align: ce;
  }
  .formulario-container-modal {
    max-width: 90%;
  }

  .formulario-container-modal .tabla-permisos-grupo {
    border-spacing: 3px;
    font-size: 12px;
  }

  .formulario-container-modal .tabla-permisos-grupo tbody tr td {
    max-width: 100px;
  }

  .ver-perfil-empleado .vpe-body .vpe-body-flexbox .vpe-body-group {
    width: 100%;
  }

  .ver-perfil-empleado .vpe-body .vpe-body-controls {
    flex-direction: column;
  }

  .formulario-container-modal .form-group-modal {
    flex-direction: column;
    max-width: 100%;
  }

  .formulario-container-modal h1 {
    font-size: 18px;
    font-weight: 600;
    text-align: center;
  }

  .card-profile {
    display: flex;
    flex-direction: column;
    gap: 25px;
    padding: 15px;
  }

  .card-profile .card-image-container {
    width: 100%;
  }

  .card-form-contaiter .card-controls {
    display: flex;
    flex-direction: column;
    gap: 15px;
    width: 100%;
    text-align: center;
  }

  .controls-table-header .header-input-grupo .hi-grupo {
    width: 100%;
  }

  .card-form-contaiter .form.form-grid-2 {
    display: grid;
    grid-template-columns: 1fr;
    gap: 15px;
    width: 100%;
  }

  .card-profile .card-form-contaiter .form.ocultar-form-card {
    display: none;
  }

  .controls-table-header .control-search,
  .controls-table-header .header-input-grupo {
    flex-direction: column;
    width: 100%;
  }

  .controls-table-header .header-input-grupo input {
    width: 100%;
  }

  .formulario-container-modal .grid-2-formulario {
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .formulario-container-modal .form-group-modal {
    width: 100%;
  }

  .formulario-container-modal .grid-2-formulario h2 {
    grid-column: 1 span;
  }
  .formulario-container-modal .fg-modal-botones .fg-boton {
    padding: 5px 25px;
  }

  .controls-table-header.controls .header-input-grupo {
    width: 100%;
  }

  .controls-table-header.controls {
    align-items: center;
  }

  .card-profile .card-image-container p {
    text-align: center;
    font-size: 12px;
  }

  .login-section .ap-container {
    display: none;
  }

  .login-section .form-login-container,
  .registro-section {
    width: 100%;
    padding: 5px;
  }

  .registro-section {
    background: rgba(255, 255, 255, 0.5);
    backdrop-filter: blur(10px);
  }

  body.effect-active .login-section video,
  body.effect-active .registro-section video {
    width: 100%;
  }
  .titulo {
    text-align: center;
  }
  .bn {
    text-align: center;
  }
  .tables-home-container {
    flex-direction: column;
    padding: 15px;
  }
  .tables-home-container .table-1,
  .tables-home-container .table-2 {
    width: 100%;
  }
  .th-footer {
    margin-top: 20px;
  }
  .th-footer a {
    text-align: center;
    padding: 8px 5px;
  }
  .login-section .formulario {
    width: 100%;
    padding: 25px;
  }
  .login-section .counter {
    display: none;
  }
  .login-section h3 {
    left: 25px;
  }

  /* POS */
  .ventas-container .ventas-flexbox {
    flex-direction: column;
  }

  .ventas-container .v-header {
    padding: 25px;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
  }

  .ventas-container .v-header .productos-controls {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-top: 25px;

    margin-bottom: 25px;
  }
  .ventas-container .v-header .productos-controls input,
  .ventas-container .v-header .productos-controls select {
    width: 100%;
  }
  .ventas-container .v-header a {
    width: 100%;
    position: relative;
  }
  .ventas-container .ventas-flexbox .cuenta-container {
    width: 100%;
    padding: 0 25px 25px;
  }
  .ventas-container .ventas-flexbox .productos-container {
    width: 100%;
    padding: 15px 25px;
  }
  .ventas-container .listado_productos {
    /* display: flex; */
    justify-content: center;
  }
  .boxes-container .boxes.boxes-m .boxs {
    min-height: 180px;
    width: 100%;
    padding: 25px;
  }
  .grid-span-2 {
    grid-column: 1 span;
  }
}

/* Select2 Libreria */



/* Fondo negro y texto blanco del selector */
.select2-container--default .select2-selection--single {
    background-color: #000;
    color: #fff;
    border: 1px solid #444;
}

/* Texto que aparece seleccionado */
.select2-container--default .select2-selection--single .select2-selection__rendered {
    color: #fff;
}

/* Placeholder visible con gris claro */
.select2-container--default .select2-selection--single .select2-selection__placeholder {
    color: #bbb;
}

/* Fondo negro para la lista desplegable */
.select2-container--default .select2-results > .select2-results__options {
    background-color: #000;
    color: #fff;
}

/* Hover en opciones */
.select2-container--default .select2-results__option--highlighted[aria-selected] {
    background-color: #444;
    color: #fff;
}

/* Texto que escribes dentro del input de búsqueda */
.select2-container--default .select2-search--dropdown .select2-search__field {
    color: #fff !important;
    background-color: #000 !important;
    caret-color: #fff; /* Cursor blanco */
}

/* Placeholder dentro del input de búsqueda */
.select2-container--default .select2-search--dropdown .select2-search__field::placeholder {
    color: #bbb;
}

.select2-container--open {
  z-index: 999999 !important; /* Asegura que el menú se vea sobre el modal */
}

.form-group-modal {
  position: relative; /* Necesario para ubicar correctamente el dropdown */
}

.select2-container {
  width: 100% !important; /* Asegura que no se recorte */
}

