@charset "UTF-8";
@font-face {
  font-family: "Montserrat";
  src: url("../fonts/Montserrat-Regular.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
}
@font-face {
  font-family: "Montserrat";
  src: url("../fonts/Montserrat-Medium.ttf") format("truetype");
  font-weight: 500;
  font-style: normal;
}
@font-face {
  font-family: "Montserrat";
  src: url("../fonts/Montserrat-SemiBold.ttf") format("truetype");
  font-weight: 600;
  font-style: normal;
}
@font-face {
  font-family: "Montserrat";
  src: url("../fonts/Montserrat-Bold.ttf") format("truetype");
  font-weight: 700;
  font-style: normal;
}
@font-face {
  font-family: "Montserrat";
  src: url("../fonts/Montserrat-ExtraBold.ttf") format("truetype");
  font-weight: 800;
  font-style: normal;
}
body {
  font-family: "Montserrat", sans-serif;
}

:root {
  --dt-primary-color: #00ACD0;
  --dt-secundary-color: #59D49A;
  --dt-bg-color: #fff;
  --dt-bg-color-rgb: 255 255 255;
  --dt-link-color: #000;
  --dt-headline-color: #111827;
  --dt-text-color: #1A1C1E;
  --dt-small-text-color: #6C7278;
  --dt-border-stroke: #718096;
  --dt-stroke: #EDF1F3;
  --dt-bold-font: #1B2559;
  --dt-neutral-300: #EFF0F6;
  --dt-neutral-400: #FAFAFA;
  --dt-box-shadow-color: rgba(19, 18, 66, 0.0705882353);
}

[data-theme=dark] {
  --dt-primary-color: #00ACD0;
  --dt-bg-color: #181818;
  --dt-bg-color-rgb: 24 24 24;
  --dt-link-color: #fff;
  --dt-headline-color: #fff;
  --dt-text-color: #fff;
  --dt-small-text-color: #fff;
  --dt-border-stroke: invert-color(#EDF1F3);
  --dt-stroke: invert-color(#EDF1F3);
  --dt-bold-font: #fff;
  --dt-neutral-300: invert-color(#EFF0F6);
  --dt-neutral-400: invert-color(#FAFAFA);
  --dt-box-shadow-color: rgba(255, 255, 255, 0.7490196078);
}

.container {
  width: 100%;
  margin-right: auto;
  margin-left: auto;
}
@media (min-width: 576px) {
  .container {
    max-width: 540px;
  }
}

.container {
  width: 100%;
  margin-right: auto;
  margin-left: auto;
}
@media (min-width: 768px) {
  .container {
    max-width: 720px;
  }
}

.container {
  width: 100%;
  margin-right: auto;
  margin-left: auto;
}
@media (min-width: 992px) {
  .container {
    max-width: 960px;
  }
}

.container {
  width: 100%;
  margin-right: auto;
  margin-left: auto;
}
@media (min-width: 1200px) {
  .container {
    max-width: 1140px;
  }
}

.container {
  width: 100%;
  margin-right: auto;
  margin-left: auto;
}
@media (min-width: 1400px) {
  .container {
    max-width: 1320px;
  }
}

.container-fluid {
  width: 100%;
  margin-right: auto;
  margin-left: auto;
}

.row {
  display: flex;
  flex-wrap: wrap;
}
.row > * {
  padding-right: 0.25rem;
  padding-left: 0.25rem;
}

.col-1 {
  flex: 0 0 auto;
  width: 8.3333333333%;
}

.col-2 {
  flex: 0 0 auto;
  width: 16.6666666667%;
}

.col-3 {
  flex: 0 0 auto;
  width: 25%;
}

.col-4 {
  flex: 0 0 auto;
  width: 33.3333333333%;
}

.col-5 {
  flex: 0 0 auto;
  width: 41.6666666667%;
}

.col-6 {
  flex: 0 0 auto;
  width: 50%;
}

.col-7 {
  flex: 0 0 auto;
  width: 58.3333333333%;
}

.col-8 {
  flex: 0 0 auto;
  width: 66.6666666667%;
}

.col-9 {
  flex: 0 0 auto;
  width: 75%;
}

.col-10 {
  flex: 0 0 auto;
  width: 83.3333333333%;
}

.col-11 {
  flex: 0 0 auto;
  width: 91.6666666667%;
}

.col-12 {
  flex: 0 0 auto;
  width: 100%;
}

.col-xs-1 {
  width: 8.3333333333%;
}

.col-xs-2 {
  width: 16.6666666667%;
}

.col-xs-3 {
  width: 25%;
}

.col-xs-4 {
  width: 33.3333333333%;
}

.col-xs-5 {
  width: 41.6666666667%;
}

.col-xs-6 {
  width: 50%;
}

.col-xs-7 {
  width: 58.3333333333%;
}

.col-xs-8 {
  width: 66.6666666667%;
}

.col-xs-9 {
  width: 75%;
}

.col-xs-10 {
  width: 83.3333333333%;
}

.col-xs-11 {
  width: 91.6666666667%;
}

.col-xs-12 {
  width: 100%;
}

@media (min-width: 576px) {
  .col-sm-1 {
    width: 8.3333333333%;
  }
  .col-sm-2 {
    width: 16.6666666667%;
  }
  .col-sm-3 {
    width: 25%;
  }
  .col-sm-4 {
    width: 33.3333333333%;
  }
  .col-sm-5 {
    width: 41.6666666667%;
  }
  .col-sm-6 {
    width: 50%;
  }
  .col-sm-7 {
    width: 58.3333333333%;
  }
  .col-sm-8 {
    width: 66.6666666667%;
  }
  .col-sm-9 {
    width: 75%;
  }
  .col-sm-10 {
    width: 83.3333333333%;
  }
  .col-sm-11 {
    width: 91.6666666667%;
  }
  .col-sm-12 {
    width: 100%;
  }
}
@media (min-width: 768px) {
  .col-md-1 {
    width: 8.3333333333%;
  }
  .col-md-2 {
    width: 16.6666666667%;
  }
  .col-md-3 {
    width: 25%;
  }
  .col-md-4 {
    width: 33.3333333333%;
  }
  .col-md-5 {
    width: 41.6666666667%;
  }
  .col-md-6 {
    width: 50%;
  }
  .col-md-7 {
    width: 58.3333333333%;
  }
  .col-md-8 {
    width: 66.6666666667%;
  }
  .col-md-9 {
    width: 75%;
  }
  .col-md-10 {
    width: 83.3333333333%;
  }
  .col-md-11 {
    width: 91.6666666667%;
  }
  .col-md-12 {
    width: 100%;
  }
}
@media (min-width: 992px) {
  .col-lg-1 {
    width: 8.3333333333%;
  }
  .col-lg-2 {
    width: 16.6666666667%;
  }
  .col-lg-3 {
    width: 25%;
  }
  .col-lg-4 {
    width: 33.3333333333%;
  }
  .col-lg-5 {
    width: 41.6666666667%;
  }
  .col-lg-6 {
    width: 50%;
  }
  .col-lg-7 {
    width: 58.3333333333%;
  }
  .col-lg-8 {
    width: 66.6666666667%;
  }
  .col-lg-9 {
    width: 75%;
  }
  .col-lg-10 {
    width: 83.3333333333%;
  }
  .col-lg-11 {
    width: 91.6666666667%;
  }
  .col-lg-12 {
    width: 100%;
  }
}
@media (min-width: 1200px) {
  .col-xl-1 {
    width: 8.3333333333%;
  }
  .col-xl-2 {
    width: 16.6666666667%;
  }
  .col-xl-3 {
    width: 25%;
  }
  .col-xl-4 {
    width: 33.3333333333%;
  }
  .col-xl-5 {
    width: 41.6666666667%;
  }
  .col-xl-6 {
    width: 50%;
  }
  .col-xl-7 {
    width: 58.3333333333%;
  }
  .col-xl-8 {
    width: 66.6666666667%;
  }
  .col-xl-9 {
    width: 75%;
  }
  .col-xl-10 {
    width: 83.3333333333%;
  }
  .col-xl-11 {
    width: 91.6666666667%;
  }
  .col-xl-12 {
    width: 100%;
  }
}
@media (min-width: 1400px) {
  .col-xxl-1 {
    width: 8.3333333333%;
  }
  .col-xxl-2 {
    width: 16.6666666667%;
  }
  .col-xxl-3 {
    width: 25%;
  }
  .col-xxl-4 {
    width: 33.3333333333%;
  }
  .col-xxl-5 {
    width: 41.6666666667%;
  }
  .col-xxl-6 {
    width: 50%;
  }
  .col-xxl-7 {
    width: 58.3333333333%;
  }
  .col-xxl-8 {
    width: 66.6666666667%;
  }
  .col-xxl-9 {
    width: 75%;
  }
  .col-xxl-10 {
    width: 83.3333333333%;
  }
  .col-xxl-11 {
    width: 91.6666666667%;
  }
  .col-xxl-12 {
    width: 100%;
  }
}
.col {
  flex: 1 0 0;
}

.col-auto {
  flex: 0 0 auto;
  width: auto;
}

.grid {
  display: grid;
}

.col-g-100 {
  grid-column: 1/-1;
}

.nav-user-tools-wrapper {
  justify-content: space-between;
  align-items: center;
}
.nav-user-tools-wrapper .ai-model-select-wrapper {
  display: flex;
  align-items: center;
}
.nav-user-tools-wrapper .ai-model-select-wrapper .select-ai-model {
  border-radius: 30px;
  border: 1px solid #EFF0F6;
  background: var(--dt-bg-color);
  box-shadow: 0px 2px 6px 0px rgba(112, 144, 176, 0.07);
  padding: 4px;
}
.nav-user-tools-wrapper .ai-model-select-wrapper .select-ai-model:first-child {
  display: none;
}
.nav-user-tools-wrapper .ai-model-select-wrapper .select-ai-model select {
  border-radius: 30px;
  margin: 0;
  background: var(--dt-bg-color);
}
.nav-user-tools-wrapper .nav-user-tools {
  display: flex;
  gap: 0.75rem;
  border-radius: 30px;
  border: 1px solid #EFF0F6;
  background: var(--dt-bg-color);
  box-shadow: 0px 2px 6px 0px rgba(112, 144, 176, 0.07);
  padding: 4px;
  margin-right: 1rem;
}
.nav-user-tools-wrapper .nav-user-tools .search-form input[type=search], .nav-user-tools-wrapper .nav-user-tools .search-form [type=search].tag-list {
  border-radius: 30px;
  margin: 0;
  background: var(--dt-bg-color) url(../img/SearchIcon.svg) no-repeat 1rem center;
  padding-left: 2.5rem;
}
.nav-user-tools-wrapper .nav-user-tools nav {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.nav-user-tools-wrapper .nav-user-tools .select-lang-wrapper {
  position: relative;
  border-radius: 10px;
}
.nav-user-tools-wrapper .nav-user-tools .select-lang-wrapper:before, .nav-user-tools-wrapper .nav-user-tools .select-lang-wrapper:after {
  display: block;
  content: "";
  position: absolute;
  top: 50%;
  transform: translateY(-60%);
  z-index: 5;
}
.nav-user-tools-wrapper .nav-user-tools .select-lang-wrapper:before {
  width: 18px;
  height: 18px;
  background: url("../img/grommet-icons_language.svg");
  left: 0.75em;
}
.nav-user-tools-wrapper .nav-user-tools .select-lang-wrapper:after {
  width: 16px;
  height: 16px;
  background: url("../img/ep_arrow-left-bold.svg");
  right: 0.75em;
}
.nav-user-tools-wrapper .nav-user-tools .select-lang-wrapper select {
  position: relative;
  appearance: none;
  border: none;
  padding: 12px 30px 12px 35px;
  margin: 0;
  color: var(--dt-text-color);
  z-index: 1;
  background-color: var(--dt-bg-color);
  box-shadow: none;
  font-size: 14px;
  color: var(--dt-border-stroke);
}
.nav-user-tools-wrapper .nav-user-tools .select-lang-wrapper select option {
  color: var(--dt-headline-color);
}
.nav-user-tools-wrapper .nav-user-tools .select-lang {
  text-transform: uppercase;
}
.nav-user-tools-wrapper .nav-user-tools .select-lang .dropdown {
  min-width: 50%;
  max-width: 100%;
  top: 100%;
  left: auto;
  right: 13px;
}
.nav-user-tools-wrapper .nav-user-tools .select-lang .dropdown .dropdown-item:not(:last-child) {
  margin-bottom: 0.7rem;
}
.nav-user-tools-wrapper .nav-user-tools .user {
  align-self: center;
}
.nav-user-tools-wrapper .nav-user-tools .user a[data-toggle=dropdown] {
  padding: 0;
}
.nav-user-tools-wrapper .nav-user-tools .user img {
  height: 40px;
  aspect-ratio: 1/1;
  object-fit: cover;
  object-position: center;
  border-radius: 50%;
}
.nav-user-tools-wrapper .nav-user-tools .user .dropdown {
  right: 0;
  left: auto;
  top: calc(100% + 0.5rem);
}
.nav-user-tools-wrapper .nav-user-tools .user .dropdown .dropdown-item {
  margin-bottom: 0.7rem;
}
.nav-user-tools-wrapper .nav-user-tools .user .dropdown .dropdown-item:last-child {
  margin-bottom: 0;
}
.nav-user-tools-wrapper #modalPerfil .modal-content {
  max-width: 55%;
}
.nav-user-tools-wrapper #modalPerfil .user-avatar-container {
  position: relative;
  width: 80%;
  margin: 0 auto;
  display: inline-block;
}
.nav-user-tools-wrapper #modalPerfil .user-avatar {
  width: 100%;
  display: block;
  aspect-ratio: 1/1;
  object-fit: cover;
  object-position: center;
  border-radius: 50%;
}
.nav-user-tools-wrapper #modalPerfil .edit-avatar-btn {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--dt-primary-color);
  border: 2px solid var(--dt-bg-color);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.2s ease;
  box-shadow: 0px 2px 8px rgba(0, 0, 0, 0.15);
}
.nav-user-tools-wrapper #modalPerfil .edit-avatar-btn:hover {
  background: var(--dt-primary-hover);
  transform: scale(1.05);
  box-shadow: 0px 4px 12px rgba(0, 0, 0, 0.2);
  color: var(--dt-primary-color);
}
.nav-user-tools-wrapper #modalPerfil .edit-avatar-btn .material-symbols-rounded {
  font-size: 16px;
  color: white;
  font-variation-settings: "FILL" 0, "wght" 400, "GRAD" 0, "opsz" 24;
}
.nav-user-tools-wrapper #modalPerfil .change-email {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  justify-content: space-between;
  margin: 0.5rem 0;
}
.nav-user-tools-wrapper #modalPerfil .change-email button {
  padding: 8px;
}
.nav-user-tools-wrapper #modalPerfil .change-email input, .nav-user-tools-wrapper #modalPerfil .change-email .tag-list {
  margin: 0px;
}
.nav-user-tools-wrapper #modalPerfil .change-email input:disabled, .nav-user-tools-wrapper #modalPerfil .change-email .tag-list:disabled {
  opacity: 0.9;
}
.nav-user-tools-wrapper #modalPerfil #newEmail {
  display: none;
}
.nav-user-tools-wrapper #modalPerfil #newEmail #btnCambiarEmailNew {
  min-width: 105px;
}
.nav-user-tools-wrapper #modalPerfil #codeConfirm {
  display: none;
}
.nav-user-tools-wrapper #modalPerfil #codeConfirm #btnCambiarEmailCode {
  min-width: 105px;
}
.nav-user-tools-wrapper #modalPerfil .modal-footer {
  margin-top: 2rem;
  padding: 1rem 0 0 0;
  display: flex;
  justify-content: flex-end;
  gap: 1rem;
}
.nav-user-tools-wrapper #modalPerfil .modal-footer #btnGuardarPerfil {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1.5rem;
}
.nav-user-tools-wrapper #modalPerfil .modal-footer #btnGuardarPerfil .material-symbols-rounded {
  font-size: 18px;
  font-variation-settings: "FILL" 0, "wght" 400, "GRAD" 0, "opsz" 24;
}

.btnTheme .light {
  display: none;
}

[data-theme=dark] .btnTheme {
  color: #fff;
}
[data-theme=dark] .btnTheme .light {
  display: inline-block;
}
[data-theme=dark] .btnTheme .dark {
  display: none;
}

.site-header {
  position: fixed;
  top: 0;
  right: 0;
  left: 0;
  z-index: 999;
}
.site-header .container > .row {
  padding-top: 1.5rem;
  padding-bottom: 1rem;
  justify-content: space-between;
  align-items: center;
}
.site-header .brand img {
  height: 50px;
  width: auto;
}
.site-header ul.dt-nav-menu {
  display: flex;
  flex-direction: row;
  list-style: none;
  padding: 0;
  margin: 0;
  align-items: center;
}
.site-header ul.dt-nav-menu li {
  display: list-item;
}
.site-header ul.dt-nav-menu li a.nav-link {
  display: block;
  color: var(--dt-border-stroke);
  padding: 0.5rem;
  margin: 0 1rem;
}
.site-header ul.dt-nav-menu li a.nav-link path {
  fill: var(--dt-border-stroke);
}
.site-header .nav-user-tools {
  margin: 0;
}

button {
  background-color: transparent;
  border: none;
  cursor: pointer;
}

.button {
  display: inline-block;
  padding: 14px 40px;
  text-align: center;
  text-decoration: none;
  font-weight: 500;
  cursor: pointer;
  line-height: 1.3;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.625rem;
}

.button-full {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}

.primary-button, .input-group-button button {
  color: #fff;
  border-radius: 10px;
  background: linear-gradient(0deg, #00ACD0, #00ACD0), linear-gradient(180deg, rgba(255, 255, 255, 0.12) 0%, rgba(255, 255, 255, 0) 100%);
  border: 1px solid;
  border-image-source: linear-gradient(180deg, rgba(239, 240, 246, 0.12) 0%, rgba(239, 240, 246, 0) 100%);
  box-shadow: 0px 0px 0px 1px #00ACD0;
  box-shadow: 0px 1px 2px 0px rgba(37, 62, 167, 0.4784313725);
}

.gradient-button {
  border-radius: 10px;
  background: linear-gradient(15deg, var(--dt-primary-color) 26.3%, var(--dt-secundary-color) 86.4%);
  box-shadow: 0px 21px 27px -10px rgba(0, 172, 208, 0.25);
  color: #fff;
  border: none;
}

.gray-button {
  color: var(--dt-link-color);
  border-radius: 10px;
  background: linear-gradient(0deg, var(--dt-bg-color), var(--dt-bg-color)), linear-gradient(180deg, rgba(255, 255, 255, 0.12) 0%, rgba(255, 255, 255, 0) 100%);
  border: 1px solid;
  border-image-source: linear-gradient(180deg, rgba(239, 240, 246, 0.12) 0%, rgba(239, 240, 246, 0) 100%);
  box-shadow: 0px 0px 0px 1px var(--dt-bg-color);
  box-shadow: 0px 1px 2px 0px trasnparent;
  box-shadow: 0px -3px 6px 0px var(box-shadow-color) inset;
  border: 1px solid #EFF0F6;
}

.outline-button {
  border-radius: 10px;
  border: 1px solid #59D49A;
  background: var(--dt-bg-color);
  color: var(--dt-link-color);
  box-shadow: 0px -3px 6px 0px var(box-shadow-color) inset;
  gap: 0.625rem;
}

/* Modal de confirmación personalizado */
.confirm-modal {
  z-index: 9999;
}
.confirm-modal .modal-content {
  max-width: 450px;
  text-align: center;
}
.confirm-modal .modal-top {
  padding: 2rem 2rem 1rem;
}
.confirm-modal .modal-top img {
  width: 48px;
  height: 48px;
  margin-bottom: 1rem;
  opacity: 0.8;
}
.confirm-modal .modal-top h2 {
  font-size: 1.25rem;
  font-weight: 600;
  margin: 0 0 0.75rem 0;
  color: var(--dt-headline-color);
}
.confirm-modal .modal-top p {
  font-size: 0.95rem;
  color: var(--dt-small-text-color);
  margin: 0;
  line-height: 1.5;
}
.confirm-modal .modal-body {
  padding: 1rem 2rem 2rem;
}
.confirm-modal .confirm-actions {
  display: flex;
  gap: 0.75rem;
  justify-content: center;
  align-items: center;
}
.confirm-modal .confirm-actions .button {
  min-width: 100px;
  padding: 0.75rem 1.5rem;
  font-size: 0.9rem;
  border-radius: 8px;
  border: 1px solid transparent;
  cursor: pointer;
  transition: all 0.2s ease;
}
.confirm-modal .confirm-actions .button:focus {
  outline: 2px solid var(--dt-primary-color);
  outline-offset: 2px;
}
.confirm-modal .confirm-actions .button.gray-button {
  background: #f5f5f5;
  color: #666;
  border-color: #ddd;
}
.confirm-modal .confirm-actions .button.gray-button:hover {
  background: #e8e8e8;
  border-color: #ccc;
}
.confirm-modal .confirm-actions .button.primary-button, .confirm-modal .confirm-actions .input-group-button button.button, .input-group-button .confirm-modal .confirm-actions button.button {
  background: var(--dt-primary-color);
  color: white;
}
.confirm-modal .confirm-actions .button.primary-button:hover, .confirm-modal .confirm-actions .input-group-button button.button:hover, .input-group-button .confirm-modal .confirm-actions button.button:hover {
  background: #0098b8;
}
.confirm-modal .confirm-actions .button.danger-button {
  background: #dc3545;
  color: white;
}
.confirm-modal .confirm-actions .button.danger-button:hover {
  background: #c82333;
}
.confirm-modal .confirm-actions .button.warning-button {
  background: #ffc107;
  color: #212529;
}
.confirm-modal .confirm-actions .button.warning-button:hover {
  background: #e0a800;
}
@media (max-width: 768px) {
  .confirm-modal .modal-content {
    max-width: 90%;
    margin: 20% auto;
  }
  .confirm-modal .confirm-actions {
    flex-direction: column;
    gap: 0.5rem;
  }
  .confirm-modal .confirm-actions .button {
    width: 100%;
  }
}

* {
  box-sizing: border-box;
  scrollbar-width: thin; /* thin | auto | none */
  scrollbar-color: #EDF1F3 var(--dt-bg-color);
}

body {
  background-color: var(--dt-bg-color);
  color: var(--dt-text-color);
  margin: 0;
  padding: 0;
  font-family: "Montserrat", sans-serif;
  font-size: 0.875rem;
  font-weight: 400;
}

h1 {
  font-size: 2rem;
  color: var(--dt-headline-color);
}

small {
  font-size: 0.75rem;
  color: var(--dt-small-text-color);
}

input, .tag-list, select, textarea {
  width: 100%;
  gap: 10px;
  border-radius: 10px;
  padding: 14px 27px;
  background: var(--dt-bg-color);
  color: var(--dt-link-color);
  border: 1px solid #EDF1F3;
  box-shadow: 0px 1px 2px 0px rgba(228, 229, 231, 0.2392156863);
  margin-bottom: 1rem;
  font-family: "Montserrat", sans-serif;
  font-size: 14px;
}

textarea {
  resize: vertical;
}

[disabled] {
  opacity: 0.5;
}

input[type=radio], [type=radio].tag-list, input[type=checkbox], [type=checkbox].tag-list {
  display: none;
}

input[type=radio] + label, [type=radio].tag-list + label, input[type=checkbox] + label, [type=checkbox].tag-list + label {
  background: var(--dt-bg-color);
  border-radius: 16px;
  gap: 10px;
  padding: 21px 16px;
  border: 2px solid #EFF0F6;
  box-shadow: 0px 2px 6px 0px rgba(19, 18, 66, 0.0705882353);
  cursor: pointer;
  align-items: center;
  color: var(--dt-bold-font);
  height: 100%;
}
input[type=radio] + label .step-label-text h3, [type=radio].tag-list + label .step-label-text h3, input[type=checkbox] + label .step-label-text h3, [type=checkbox].tag-list + label .step-label-text h3 {
  margin: 0;
}
input[type=radio] + label .step-label-text small, [type=radio].tag-list + label .step-label-text small, input[type=checkbox] + label .step-label-text small, [type=checkbox].tag-list + label .step-label-text small {
  color: #6C7278;
}

input[type=radio]:checked + label, [type=radio].tag-list:checked + label,
input[type=checkbox]:checked + label,
[type=checkbox].tag-list:checked + label,
input[type=radio]:hover + label,
[type=radio].tag-list:hover + label,
input[type=checkbox]:hover + label,
[type=checkbox].tag-list:hover + label {
  border: 2px solid var(--dt-primary-color);
}

input[type=checkbox] + label, [type=checkbox].tag-list + label {
  text-align: center;
}

input[type=text], [type=text].tag-list, select, input[type=number], [type=number].tag-list, input[type=url], [type=url].tag-list, textarea {
  margin-top: 0.75rem;
}

.input-group {
  display: flex;
  margin-top: 0.75rem;
  margin-bottom: 1rem;
}
.input-group .input-group-text {
  display: flex;
  align-items: center;
  padding: 14px;
  border-top-left-radius: 10px;
  border-bottom-left-radius: 10px;
  border: 1px solid #EDF1F3;
  border-right: 0;
}
.input-group input, .input-group .tag-list {
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
  margin: 0;
}

.input-group-button {
  display: flex;
  margin-top: 0.75rem;
  margin-bottom: 1rem;
}
.input-group-button input, .input-group-button .tag-list, .input-group-button select {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
  border: 1px solid #EDF1F3;
  border-right: 0;
  margin: 0;
}
.input-group-button button {
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
  padding-right: 1rem;
  padding-left: 1rem;
}

a {
  text-decoration: none;
  color: var(--dt-link-color);
}

hr {
  border: 1px solid #D9DBE9;
}

img {
  height: auto;
  max-width: 100%;
  max-height: 100%;
}

ul {
  padding: 0;
  margin: 0;
  list-style: none;
}

@keyframes spinPause {
  /* 0–1s: gira de 0° a 360° */
  0% {
    transform: rotate(0deg);
  }
  25% {
    transform: rotate(360deg);
  }
  /* 1–2s: pausa en 360° */
  50% {
    transform: rotate(360deg);
  }
  /* 2–3s: gira de 360° a 720° */
  75% {
    transform: rotate(720deg);
  }
  /* 3–4s: pausa en 720° */
  100% {
    transform: rotate(720deg);
  }
}
.loader {
  width: 100%;
  height: 100vh;
  position: fixed;
  top: 0px;
  left: 0px;
  z-index: 3000;
  background-color: var(--dt-bg-color);
  overflow-x: hidden;
  display: none;
}
.loader * {
  z-index: 2;
}
.loader:before {
  content: "";
  background: radial-gradient(79.85% 79.85% at 84.09% 0%, rgba(89, 212, 154, 0.5) 26.04%, rgba(var(--dt-bg-color-rgb)/0.5) 100%);
  display: block;
  position: absolute;
  width: 500px;
  height: 500px;
  top: 0;
  right: 0;
  z-index: 1;
}
.loader:after {
  content: "";
  background: radial-gradient(79.85% 79.85% at 84.09% 0%, rgba(89, 212, 154, 0.5) 26.04%, rgba(var(--dt-bg-color-rgb)/0.5) 100%);
  display: block;
  position: absolute;
  width: 100px;
  height: 100px;
  bottom: 0;
  right: 0;
  z-index: 1;
  rotate: 90deg;
}
.loader .loaderContent {
  width: 100%;
  height: 100%;
  /*flex*/
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 20;
  position: relative;
  z-index: 3;
}
.loader img {
  width: 150px;
  aspect-ratio: 1/1;
  border-radius: 50%;
}
.loader h1 {
  color: var(--dt-text-color);
}

.has-secondary-color {
  color: var(--dt-secondary-color);
}

.ai-panel-canva {
  padding: 0.438rem;
}

#previewMediaContainer #btnRemoveMedia::after {
  color: var(--dt-text-color);
}

.overlay-active:before {
  content: "";
  display: block;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 10;
  width: 100%;
  height: 100%;
  overflow-x: hidden;
  overflow-y: auto;
  outline: 0;
  background-color: rgba(var(--dt-bg-color-rgb)/0.75);
}

.modal {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 10;
  display: none;
  width: 100%;
  height: 100%;
  overflow-x: hidden;
  overflow-y: auto;
  outline: 0;
  background-color: rgba(var(--dt-bg-color-rgb)/0.75);
}
.modal.show {
  display: block !important;
}
.modal .modal-dialog {
  display: flex;
  height: 100%;
  width: 100%;
  justify-content: center;
  align-items: center;
}
.modal .modal-dialog .close-modal {
  position: absolute;
  right: 0.5rem;
  top: 0.5rem;
}
.modal .modal-dialog .modal-content {
  padding: 2rem;
  border-radius: 14px;
  background: var(--dt-bg-color);
  box-shadow: 14px 14px 45px 4px rgba(112, 144, 176, 0.2);
  min-width: 450px;
  max-width: 75%;
  max-height: 80vh;
  overflow-y: scroll;
  position: relative;
}
.modal .modal-dialog .modal-content .modal-footer {
  margin-top: 1rem;
}
.modal .modal-dialog.modal-two-column .modal-content {
  max-width: 50%;
  min-height: 65vh;
  padding: 0;
}
.modal .modal-dialog.modal-two-column .modal-content .col-12 {
  padding: 0;
}
.modal .modal-dialog.modal-two-column .modal-content .modal-bg-image {
  padding: 0;
  background-size: cover !important;
  background-position: center !important;
  position: relative;
}
.modal .modal-dialog.modal-two-column .modal-content .modal-bg-image img {
  position: absolute;
  bottom: 1rem;
  right: 1rem;
}
.modal .modal-dialog.modal-two-column .modal-content .modal-top {
  padding: 1rem 2rem;
  border-bottom: 1px solid #EFF0F6;
  text-align: center;
}
.modal .modal-dialog.modal-two-column .modal-content .modal-body {
  padding: 2rem;
  display: flex;
  flex-direction: column;
}
.modal .modal-dialog.modal-two-column .modal-content .modal-body img {
  max-width: 60%;
  margin: 0 auto 1.5rem;
}
.modal .blog-create-preview hr {
  margin-bottom: 1.5rem;
}
.modal .blog-create-preview .row > .col-12 {
  padding: 0.5rem;
}
.modal .blog-create-preview .report-download-buttons {
  margin-top: 0.75rem;
  margin-bottom: 1rem;
}

.dropend {
  position: relative;
  padding: 0;
  margin: 0;
}
.dropend [data-toggle=dropdown] {
  display: flex;
  align-items: center;
  padding: 0.75rem;
  gap: 0.5rem;
}
.dropend .dropdown {
  display: none;
  border-radius: 10px;
  border: 1px solid #EFF0F6;
  background: rgba(var(--dt-bg-color-rgb)/0.8);
  backdrop-filter: blur(5px);
  padding: 0.625rem;
  position: absolute;
  top: 0;
  left: calc(100% + 0.5rem);
  z-index: 5;
  transition: opacity 0.2s ease-in-out;
}
.dropend .dropdown.show {
  display: block;
}
.dropend .dropdown .dropdown-menu {
  display: flex;
  flex-direction: column;
  gap: 1.063rem;
  min-width: 115px;
}
.dropend .dropdown .dropdown-menu .dropdown-item {
  color: #1B2559;
  font-size: 12px;
  white-space: nowrap;
}
.dropend .dropdown .dropdown-menu .dropdown-item a {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.dropend .dropdown.dropup {
  right: 0;
  left: 0;
  top: -75%;
}
.dropend .dropdown.dropend {
  top: calc(100% + 0.5rem);
  right: 0;
  left: auto;
}

.has-tooltip {
  position: relative;
}
.has-tooltip::after {
  content: attr(data-tooltip);
  display: none;
  padding: 0.625rem;
  font-size: 12px;
  border-radius: 10px;
  border: 1px solid #EFF0F6;
  background: var(--dt-bg-color);
  box-shadow: 0px -3px 6px 0px rgba(244, 245, 250, 0.6) inset;
  position: absolute;
  top: 50%;
  left: 110%;
  transform: translateY(-50%);
  transition: opacity 0.2s ease-in-out;
  white-space: nowrap;
  z-index: 5;
}
.has-tooltip:not([disabled]):hover::after {
  display: block;
}

.notification {
  border-radius: 0.5rem;
  padding: 1rem;
  box-shadow: 0px -3px 6px 0px rgba(244, 245, 250, 0.6) inset;
  margin-bottom: 15px;
}
.notification a {
  font-weight: 700;
}
.notification.notification-info {
  background-color: #cff4fc;
  color: #055160;
  border: 1px solid #9eeaf9;
}
.notification.notification-info a {
  color: #055160;
}
.notification.notification-warning {
  background-color: #fff3cd;
  color: #664d03;
  border: 1px solid #ffe69c;
}
.notification.notification-warning a {
  color: #664d03;
}
.notification.notification-success {
  background-color: #d1e7dd;
  color: #0a3622;
  border: 1px solid #a3cfbb;
}
.notification.notification-success a {
  color: #0a3622;
}
.notification.notification-danger {
  background-color: #f8d7da;
  color: #58151c;
  border: 1px solid #f1aeb5;
}
.notification.notification-danger a {
  color: #58151c;
}

.alert {
  position: fixed;
  top: 90px;
  right: 1rem;
  width: 250px;
  max-width: 100%;
  border-radius: 0.25rem;
  padding: 1rem 1.25rem;
  background-color: var(--dt-bg-color);
  color: var(--dt-text-color);
  border: 1px solid #EFF0F6;
  border-bottom: 4px solid transparent;
  box-shadow: 0px -3px 6px 0px rgba(244, 245, 250, 0.6) inset;
  z-index: 3000;
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  overflow: hidden;
}
.alert.hidden {
  opacity: 0;
  pointer-events: none;
}
.alert .alert-icon {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  margin-top: 2px;
}
.alert .alert-icon .material-symbols-rounded {
  font-size: 20px;
  line-height: 1;
}
.alert .message {
  flex: 1;
  min-width: 0;
}
.alert .message #alertText {
  display: block;
  font-size: 0.875rem;
  line-height: 1.4;
  word-wrap: break-word;
  margin: 0;
}
.alert .progress {
  position: absolute;
  bottom: -1px;
  left: -1px;
  right: -1px;
  height: 4px;
  border-radius: 0 0 0.25rem 0.25rem;
  animation: progressBar 3s linear forwards;
}
.alert a {
  font-weight: 700;
}
.alert.alert-info {
  color: #055160;
}
.alert.alert-info .progress {
  background-color: #9eeaf9;
}
.alert.alert-info .alert-icon .material-symbols-rounded {
  color: #055160;
}
.alert.alert-info a {
  color: #055160;
}
.alert.alert-warning {
  color: #664d03;
}
.alert.alert-warning .progress {
  background-color: #ffe69c;
}
.alert.alert-warning .alert-icon .material-symbols-rounded {
  color: #664d03;
}
.alert.alert-warning a {
  color: #664d03;
}
.alert.alert-success {
  color: #0a3622;
}
.alert.alert-success .progress {
  background-color: #a3cfbb;
}
.alert.alert-success .alert-icon .material-symbols-rounded {
  color: #0a3622;
}
.alert.alert-success a {
  color: #0a3622;
}
.alert.alert-danger {
  color: #58151c;
}
.alert.alert-danger .progress {
  background-color: #f1aeb5;
}
.alert.alert-danger .alert-icon .material-symbols-rounded {
  color: #58151c;
}
.alert.alert-danger a {
  color: #58151c;
}

.dropzone {
  border: 2px dashed rgba(0, 0, 0, 0.3);
  border-radius: 1rem;
}

#companyDropzone {
  width: 100%;
  margin: 15px 0px;
}

.logo-preview {
  display: block;
  height: 80px;
  margin: 15px 0px;
}

#btnCambiarLogo {
  margin: 15px 0px;
}

.integrations-options {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  padding: 2rem 0;
}
.integrations-options .button {
  display: flex;
  align-items: center;
}
.integrations-options .button img {
  width: 32px;
  margin-right: 0.5rem;
}
.integrations-options .button span {
  font-weight: 700;
}
.integrations-options .button.active {
  border: 2px solid green;
}

@keyframes progressBar {
  from {
    width: 100%;
  }
  to {
    width: 0%;
  }
}
.nav-tabs {
  display: flex;
  border-bottom: 1px solid var(--dt-primary-color);
  margin-bottom: 1rem;
  gap: 1rem;
}
.nav-tabs li .nav-link {
  border-top-left-radius: 0.375rem;
  border-top-right-radius: 0.375rem;
  border-bottom: 2px solid transparent;
  display: block;
  padding: 0.5rem;
}
.nav-tabs li .nav-link.active {
  border-color: var(--dt-primary-color);
  font-weight: 700;
  color: var(--dt-primary-color);
}

.tab-content .tab-pane {
  display: none;
  padding: 1rem;
}
.tab-content .tab-pane.active {
  display: block;
}
.tab-content hr {
  margin-bottom: 20px;
}

.brand-briefing .row {
  display: flex;
  gap: 15px;
}
.brand-briefing .col-12.col-lg-6 {
  flex: 1;
  min-width: 0;
}
.brand-briefing input[type=text],
.brand-briefing textarea {
  border: 1px solid var(--dt-border-stroke);
  border-radius: 8px;
  background: var(--dt-bg-color);
  color: var(--dt-text-color);
  padding: 0.75rem;
  box-sizing: border-box;
}
.brand-briefing input[type=text]:focus,
.brand-briefing textarea:focus {
  outline: none;
  border-color: var(--dt-primary-color);
  box-shadow: 0 0 0 2px rgba(89, 212, 154, 0.1);
}
.brand-briefing textarea {
  min-height: 80px;
  resize: vertical;
}
.brand-briefing .input-group {
  position: relative;
}
.brand-briefing .input-group .input-group-text {
  padding: 9px;
  border-color: var(--dt-border-stroke);
}
.brand-briefing .input-group .input-group-text .material-symbols-rounded {
  font-size: 18px;
  opacity: 0.6;
  color: var(--dt-text-color);
}
.brand-briefing .input-group [type=text] {
  border-radius: 0;
}
.brand-briefing .input-group [type=color] {
  width: 40px;
  padding: 0;
  height: 44px;
  border-color: var(--dt-border-stroke);
  border-left: 0;
}
.brand-briefing .input-group input[type=color]::-webkit-color-swatch-wrapper {
  padding: 2px;
  border-radius: 8px;
}
.brand-briefing .input-group input[type=color]::-webkit-color-swatch {
  border: none;
  border-radius: 6px;
}
.brand-briefing .input-group input[type=color]::-moz-color-swatch {
  border: none;
  border-radius: 6px;
}
.brand-briefing .brand-color-input.is-invalid {
  border-color: #dc3545;
  box-shadow: 0 0 0 2px rgba(220, 53, 69, 0.1);
}

.briefingSearch {
  margin-bottom: 10px;
  /*flex*/
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
}

#modalStorage .contentBox {
  height: calc(100% - 100px);
  padding: 25px;
  overflow: hidden;
  display: grid;
  grid-template-columns: repeat(6, 150px);
  grid-auto-rows: 150px;
  gap: 1rem;
}
#modalStorage .storagePreview {
  height: 80%;
}
#modalStorage .storagePreview img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
#modalStorage .storageTitle {
  height: 20%;
  word-wrap: break-word;
  overflow: hidden;
  display: flex;
  gap: 5px;
}

#previewImg {
  object-fit: contain;
  object-position: center;
}

#modalPublish .modal-content {
  max-width: 800px;
  min-height: 600px;
}
#modalPublish .modal-top {
  text-align: center;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid var(--dt-border-stroke);
  margin-bottom: 1.5rem;
}
#modalPublish .modal-top h3 {
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--dt-headline-color);
  margin: 0 0 0.5rem 0;
}
#modalPublish .modal-top p {
  color: var(--dt-small-text-color);
  margin: 0;
  font-size: 0.95rem;
}
#modalPublish .modal-body {
  padding: 0;
}
#modalPublish .modal-body .nav-tabs {
  margin-bottom: 1.5rem;
  border-bottom: 1px solid var(--dt-border-stroke);
}
#modalPublish .modal-body .nav-tabs li .nav-link {
  padding: 0.75rem 1.5rem;
  font-weight: 500;
  color: var(--dt-text-color);
  border: none;
  background: none;
  position: relative;
}
#modalPublish .modal-body .nav-tabs li .nav-link:hover {
  color: var(--dt-primary-color);
}
#modalPublish .modal-body .nav-tabs li .nav-link.active {
  color: var(--dt-primary-color);
  font-weight: 600;
}
#modalPublish .modal-body .nav-tabs li .nav-link.active::after {
  content: "";
  position: absolute;
  bottom: -1px;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--dt-primary-color);
  border-radius: 1px;
}
#modalPublish .modal-body .tab-content .tab-pane {
  padding: 0;
}
#modalPublish .modal-body .tab-content .tab-pane.active {
  display: block;
}
#modalPublish .search-section {
  margin-bottom: 1.5rem;
}
#modalPublish .search-section .input-group {
  position: relative;
}
#modalPublish .search-section .input-group .input-group-text {
  position: absolute;
  left: 0.75rem;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
  background: none;
  border: none;
  padding: 0;
}
#modalPublish .search-section .input-group .input-group-text .material-symbols-rounded {
  font-size: 18px;
  opacity: 0.6;
  color: var(--dt-text-color);
}
#modalPublish .search-section .input-group .form-control {
  padding-left: 2.5rem;
  border: 1px solid var(--dt-border-stroke);
  border-radius: 8px;
  height: 44px;
  font-size: 0.9rem;
}
#modalPublish .search-section .input-group .form-control:focus {
  border-color: var(--dt-primary-color);
  box-shadow: 0 0 0 2px rgba(89, 212, 154, 0.1);
}
#modalPublish .search-section .input-group .form-control::placeholder {
  color: var(--dt-small-text-color);
}
#modalPublish .lists-container,
#modalPublish .contacts-container {
  position: relative;
  min-height: 300px;
}
#modalPublish .lists-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1rem;
  max-height: 400px;
  overflow-y: auto;
  padding-right: 0.5rem;
}
#modalPublish .lists-grid::-webkit-scrollbar {
  width: 6px;
}
#modalPublish .lists-grid::-webkit-scrollbar-track {
  background: #f5f5f5;
  border-radius: 3px;
}
#modalPublish .lists-grid::-webkit-scrollbar-thumb {
  background: var(--dt-border-stroke);
  border-radius: 3px;
}
#modalPublish .lists-grid::-webkit-scrollbar-thumb:hover {
  background: var(--dt-primary-color);
}
#modalPublish .contacts-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
  gap: 1rem;
  max-height: 400px;
  overflow-y: auto;
  padding-right: 0.5rem;
}
#modalPublish .contacts-grid::-webkit-scrollbar {
  width: 6px;
}
#modalPublish .contacts-grid::-webkit-scrollbar-track {
  background: #f5f5f5;
  border-radius: 3px;
}
#modalPublish .contacts-grid::-webkit-scrollbar-thumb {
  background: var(--dt-border-stroke);
  border-radius: 3px;
}
#modalPublish .contacts-grid::-webkit-scrollbar-thumb:hover {
  background: var(--dt-primary-color);
}
#modalPublish .list-card {
  background: var(--dt-bg-color);
  border: 2px solid var(--dt-border-stroke);
  border-radius: 12px;
  padding: 1.25rem;
  cursor: pointer;
  transition: all 0.2s ease;
  position: relative;
}
#modalPublish .list-card:hover {
  border-color: var(--dt-primary-color);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(89, 212, 154, 0.15);
}
#modalPublish .list-card.selected {
  border-color: var(--dt-primary-color);
  background: rgba(89, 212, 154, 0.05);
}
#modalPublish .list-card.selected::before {
  content: "✓";
  position: absolute;
  top: 0.75rem;
  right: 0.75rem;
  width: 20px;
  height: 20px;
  background: var(--dt-primary-color);
  color: white;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: bold;
}
#modalPublish .list-card .list-header {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 0.75rem;
}
#modalPublish .list-card .list-header .list-icon {
  width: 40px;
  height: 40px;
  background: linear-gradient(135deg, var(--dt-primary-color), #4CAF50);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
}
#modalPublish .list-card .list-header .list-icon .material-symbols-rounded {
  font-size: 20px;
  color: white;
}
#modalPublish .list-card .list-header .list-info {
  flex: 1;
}
#modalPublish .list-card .list-header .list-info .list-name {
  font-weight: 600;
  color: var(--dt-headline-color);
  margin: 0 0 0.25rem 0;
  font-size: 0.95rem;
}
#modalPublish .list-card .list-header .list-info .list-meta {
  font-size: 0.8rem;
  color: var(--dt-small-text-color);
  margin: 0;
}
#modalPublish .list-card .list-stats {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 0.75rem;
  border-top: 1px solid var(--dt-border-stroke);
}
#modalPublish .list-card .list-stats .stat-item {
  text-align: center;
}
#modalPublish .list-card .list-stats .stat-item .stat-value {
  font-weight: 600;
  color: var(--dt-headline-color);
  font-size: 0.9rem;
}
#modalPublish .list-card .list-stats .stat-item .stat-label {
  font-size: 0.75rem;
  color: var(--dt-small-text-color);
  margin-top: 0.25rem;
}
#modalPublish .contact-card {
  background: var(--dt-bg-color);
  border: 2px solid var(--dt-border-stroke);
  border-radius: 12px;
  padding: 1rem;
  cursor: pointer;
  transition: all 0.2s ease;
  position: relative;
}
#modalPublish .contact-card:hover {
  border-color: var(--dt-primary-color);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(89, 212, 154, 0.15);
}
#modalPublish .contact-card.selected {
  border-color: var(--dt-primary-color);
  background: rgba(89, 212, 154, 0.05);
}
#modalPublish .contact-card.selected::before {
  content: "✓";
  position: absolute;
  top: 0.5rem;
  right: 0.5rem;
  width: 20px;
  height: 20px;
  background: var(--dt-primary-color);
  color: white;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: bold;
}
#modalPublish .contact-card .contact-header {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 0.75rem;
}
#modalPublish .contact-card .contact-header .contact-avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  overflow: hidden;
  background: #f5f5f5;
  display: flex;
  align-items: center;
  justify-content: center;
}
#modalPublish .contact-card .contact-header .contact-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
#modalPublish .contact-card .contact-header .contact-avatar .avatar-placeholder {
  width: 20px;
  height: 20px;
  opacity: 0.5;
}
#modalPublish .contact-card .contact-header .contact-info {
  flex: 1;
}
#modalPublish .contact-card .contact-header .contact-info .contact-name {
  font-weight: 600;
  color: var(--dt-headline-color);
  margin: 0 0 0.25rem 0;
  font-size: 0.9rem;
}
#modalPublish .contact-card .contact-header .contact-info .contact-email {
  font-size: 0.8rem;
  color: var(--dt-small-text-color);
  margin: 0;
  word-break: break-all;
}
#modalPublish .contact-card .contact-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.75rem;
  color: var(--dt-small-text-color);
}
#modalPublish .contact-card .contact-meta .contact-company {
  font-weight: 500;
}
#modalPublish .contact-card .contact-meta .contact-status {
  padding: 0.25rem 0.5rem;
  border-radius: 4px;
  font-size: 0.7rem;
  font-weight: 500;
}
#modalPublish .contact-card .contact-meta .contact-status.activo {
  background: rgba(76, 175, 80, 0.1);
  color: #4CAF50;
}
#modalPublish .contact-card .contact-meta .contact-status.inactivo {
  background: rgba(244, 67, 54, 0.1);
  color: #F44336;
}
#modalPublish .loading-spinner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 300px;
}
#modalPublish .loading-spinner .spinner {
  width: 40px;
  height: 40px;
  border: 3px solid var(--dt-border-stroke);
  border-top: 3px solid var(--dt-primary-color);
  border-radius: 50%;
  animation: spin 1s linear infinite;
  margin-bottom: 1rem;
}
#modalPublish .loading-spinner p {
  color: var(--dt-small-text-color);
  margin: 0;
  font-size: 0.9rem;
}
#modalPublish .empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 300px;
  text-align: center;
}
#modalPublish .empty-state .empty-icon {
  font-size: 80px;
  opacity: 0.5;
  margin-bottom: 1rem;
  color: var(--dt-small-text-color);
}
#modalPublish .empty-state p {
  color: var(--dt-small-text-color);
  margin: 0;
  font-size: 0.9rem;
}
#modalPublish .modal-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 1.5rem;
  border-top: 1px solid var(--dt-border-stroke);
  margin-top: 1.5rem;
}
#modalPublish .modal-footer .selected-info {
  font-size: 0.9rem;
  color: var(--dt-text-color);
  font-weight: 500;
}
#modalPublish .modal-footer .modal-actions {
  display: flex;
  gap: 0.75rem;
}
#modalPublish .modal-footer .modal-actions .button {
  padding: 0.75rem 1.5rem;
  font-size: 0.9rem;
  border-radius: 8px;
  font-weight: 500;
  transition: all 0.2s ease;
}
#modalPublish .modal-footer .modal-actions .button:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
@media (max-width: 768px) {
  #modalPublish .modal-content {
    max-width: 95%;
    margin: 1rem;
  }
  #modalPublish .lists-grid,
  #modalPublish .contacts-grid {
    grid-template-columns: 1fr;
  }
  #modalPublish .modal-footer {
    flex-direction: column;
    gap: 1rem;
    align-items: stretch;
  }
  #modalPublish .modal-footer .modal-actions {
    justify-content: center;
  }
}

@keyframes spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
.view-only-form .view-field {
  margin-bottom: 1.5rem;
}
.view-only-form .view-field label {
  display: block;
  margin-bottom: 0.5rem;
  font-weight: 600;
  color: var(--dt-text-color);
  font-size: 0.9rem;
}
.view-only-form .view-field .input-group {
  position: relative;
}
.view-only-form .view-field .input-group .readonly-input {
  padding-left: 2.5rem;
  padding-right: 0.75rem;
  padding-top: 0.75rem;
  padding-bottom: 0.75rem;
  border: 1px solid var(--dt-border-stroke);
  border-radius: 8px;
  min-height: 44px;
  font-size: 0.9rem;
  background-color: var(--dt-bg-color);
  color: var(--dt-text-color);
  line-height: 1.4;
  display: flex;
  align-items: center;
  word-wrap: break-word;
  word-break: break-word;
  margin: 0;
  width: 100%;
  box-sizing: border-box;
}
.view-only-form .view-field .input-group .readonly-input .no-data {
  color: var(--dt-small-text-color);
  font-style: italic;
  margin: 0;
  padding: 0;
}
.view-only-form .view-field .input-group .readonly-textarea {
  padding-left: 2.5rem;
  padding-right: 0.75rem;
  padding-top: 0.75rem;
  padding-bottom: 0.75rem;
  border: 1px solid var(--dt-border-stroke);
  border-radius: 8px;
  min-height: 80px;
  font-size: 0.9rem;
  background-color: var(--dt-bg-color);
  color: var(--dt-text-color);
  line-height: 1.4;
  white-space: pre-wrap;
  word-wrap: break-word;
  word-break: break-word;
  font-family: inherit;
  overflow-x: auto;
  margin: 0;
  width: 100%;
  box-sizing: border-box;
  display: block;
}
.view-only-form .view-field .input-group .readonly-textarea:empty::before {
  content: attr(placeholder);
  color: var(--dt-small-text-color);
  font-style: italic;
}

.help-fab {
  position: fixed;
  bottom: 20px;
  right: 20px;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--dt-primary-color);
  color: white;
  border: none;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 1000;
  transition: background 0.3s ease;
}
.help-fab:hover {
  background: rgba(var(--dt-secondary-color-rgb), 0.8);
}
.help-fab .material-symbols-rounded {
  font-size: 24px;
}

.app-main {
  position: relative;
  overflow-x: hidden;
}
.app-main * {
  z-index: 2;
}
.app-main:before {
  content: "";
  background: radial-gradient(79.85% 79.85% at 84.09% 0%, rgba(89, 212, 154, 0.5) 26.04%, rgba(var(--dt-bg-color-rgb)/0.5) 100%);
  display: block;
  position: absolute;
  width: 500px;
  height: 500px;
  top: 0;
  right: 0;
  z-index: 1;
}
.app-main:after {
  content: "";
  background: radial-gradient(79.85% 79.85% at 84.09% 0%, rgba(89, 212, 154, 0.5) 26.04%, rgba(var(--dt-bg-color-rgb)/0.5) 100%);
  display: block;
  position: absolute;
  width: 100px;
  height: 100px;
  bottom: 0;
  right: 0;
  z-index: 1;
  rotate: 90deg;
}
.app-main .dt-login {
  min-height: 100vh;
}
.app-main .dt-login .dt-login-quote-wrapper {
  display: flex;
  justify-content: end;
  align-items: end;
  background-color: var(--dt-bg-color);
  background-image: linear-gradient(rgba(0, 0, 0, 0.4), rgba(0, 0, 0, 0.4)), url(../img/login-eli1.jpg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  padding-bottom: 5rem;
}
.app-main .dt-login .dt-login-quote {
  max-width: 80%;
}
.app-main .dt-login .dt-login-quote blockquote {
  color: #fff;
}
.app-main .dt-login .dt-login-quote blockquote blockquote p {
  font-size: 18px;
}
.app-main .dt-login .dt-login-quote blockquote .author-block {
  border-left: 3px solid #fff;
  padding-left: 1rem;
}
.app-main .dt-login .dt-login-quote blockquote .author-block p {
  margin: 0;
}
.app-main .dt-login .dt-login-quote blockquote .author-block p.author {
  font-weight: 800;
}
.app-main .dt-login .dt-login-form-wrapper {
  align-self: center;
  padding: 7.5rem 0 3rem;
}
.app-main .dt-login .dt-login-form-wrapper .dt-login-form {
  background: rgba(var(--dt-bg-color-rgb)/0.6);
  width: 70%;
  margin: auto;
  padding: 2rem 3rem;
  border-radius: 10px;
}
.app-main .dt-login .dt-login-form-wrapper .dt-login-form .dt-social-login {
  display: flex;
  gap: 2rem;
  margin-top: 1.5rem;
  margin-bottom: 1.5rem;
}
.app-main .dt-login .dt-login-form-wrapper .dt-login-form .dt-social-login .button {
  flex: 1 0 0;
  padding-right: 0;
  padding-left: 0;
}
.app-main .dt-login .dt-login-form-wrapper .dt-login-form .dt-social-login .button img {
  height: 25px;
}
.app-main .dt-login .dt-login-form-wrapper .dt-login-form .dt-mail-login {
  margin-top: 1.5rem;
  margin-bottom: 1.5rem;
}
.app-main .dt-login .dt-login-form-wrapper .dt-login-form .dt-mail-login form {
  margin-bottom: 1rem;
}
.app-main .dt-login .dt-login-form-wrapper .dt-login-form .dt-mail-login .button:after {
  content: url("../img/arrow-narrow-right.png");
  margin-left: 1rem;
  float: right;
}
.app-main .dt-login .dt-login-form-wrapper .dt-login-form .dt-mail-login #emailCodeForm {
  display: none;
}
.app-main .dt-login .dt-login-form-wrapper .dt-login-form .code-inputs {
  gap: 1rem;
  margin-top: 1rem;
}
.app-main .dt-login .dt-login-form-wrapper .dt-login-form .code-inputs .code-box {
  text-align: center;
}
.app-main .dt-login .dt-login-form-wrapper .dt-login-form .errorP {
  margin: 10px 0px;
  display: none;
}
.app-main .dt-login .dt-login-form-wrapper .partners-logos .logos {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  align-items: stretch;
  gap: 0.5rem;
}
.app-main .dt-login .dt-login-form-wrapper .partners-logos .logos img {
  width: 100%;
  height: 75px;
  object-fit: contain;
}

/*# sourceMappingURL=dt_login.css.map */
