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

.dl-newsletter-toast {
  position: fixed;
  top: 24px;
  right: 24px;
  z-index: 99999;
  max-width: min(420px, calc(100vw - 32px));
  padding: 14px 18px;
  border-radius: 12px;
  box-shadow: 0 16px 40px rgba(15, 23, 42, 0.22);
  color: #ffffff;
  font-size: 14px;
  line-height: 1.45;
  font-weight: 600;
  opacity: 1;
  transform: translate3d(0, 0, 0);
  transition: opacity 0.28s ease, transform 0.28s ease;
}

.dl-newsletter-toast.is-success {
  background: #16a34a;
}

.dl-newsletter-toast.is-error {
  background: #dc2626;
}

.dl-newsletter-toast.is-hidden {
  opacity: 0;
  transform: translate3d(0, -10px, 0);
  pointer-events: none;
}

@media (max-width: 640px) {
  .dl-newsletter-toast {
    top: 16px;
    right: 16px;
    left: 16px;
    max-width: none;
  }
}

/* File: assets/css/front.css
 * Descripción: Estilos para Frontend
 * Version: 1.0.0
 */

/* ==========================================================================
   Base de botones del plugin: permitir salto de linea sin fragmentar la caja
   ========================================================================== */
.dl-btn,
.dlterapias-elementor-widget-link {
    display: inline-block;
    max-width: 100%;
    box-sizing: border-box;
    white-space: normal;
    overflow-wrap: anywhere;
    word-break: break-word;
    text-align: center;
    vertical-align: middle;
}

.dlterapias-elementor-widget-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
    width: 100%;
}

.dlterapias-elementor-widget-item {
    display: flex;
    width: 100%;
}

.dl-catalog-button-wrap {
    display: flex;
    flex-direction: column;
    width: 100%;
}

/* ==========================================================================
   1) Contenedor principal de pestañas y contenido
   ========================================================================== */
   .dlterapias-mi-cuenta-tabs {
    display: flex !important;
    flex-direction: column !important;
    min-height: 100vh !important;
    background: #2a2c3a !important; /* Fondo oscuro de todo el panel */
    color: #fff !important;          /* Texto claro */
}

/* ==========================================================================
   2) Lista de pestañas (header)
   ========================================================================== */
.dlterapias-tab-list {
    display: flex !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
    border-bottom: 1px solid #555 !important; /* Línea separadora */
}
.dlterapias-tab-list li {
    padding: .75em 1.5em !important;
    cursor: pointer !important;
    background: #2a2c3a !important;
    border: 1px solid #555 !important;
    border-bottom: none !important;
    color: #ccc !important;
    margin-right: 4px !important; /* Espacio entre pestañas */
    border-top-left-radius: 8px !important;
    border-top-right-radius: 8px !important;
}
/* El primer y último ítem ajustan bordes */
.dlterapias-tab-list li:first-child { border-left: 1px solid #555 !important; }
.dlterapias-tab-list li:last-child  { margin-right: 0 !important; }

.dlterapias-tab-list li.active {
    background: #3a3d5e !important;  /* Pestaña activa */
    color: #fff !important;
    border-bottom: 1px solid #3a3d5e !important; /* Conecta con contenido */
}

/* ==========================================================================
   3) Zona de contenido de cada pestaña
   ========================================================================== */
.dlterapias-tab-content {
    flex: 1 !important;
    padding: 1.5em !important;
    background: #333547 !important;
    overflow: auto !important; /* Permite scroll interno si excede */
}

/* ==========================================================================
   4) Scroll lateral para la tabla de terapias
   ========================================================================== */
.dlterapias-terapias-wrapper {
    overflow-x: auto !important;
    margin-top: 1rem !important;
}

/* ==========================================================================
   5) Estilos generales de tabla de terapias
   ========================================================================== */
   .dlterapias-terapias {
    width: max-content !important;
    table-layout: auto !important;
    border-collapse: collapse !important;
    background: transparent !important;
    color: #eee !important;
}
.dlterapias-terapias th,
.dlterapias-terapias td {
    padding: 8px !important;
    border: 1px solid #555 !important;
    text-align: left !important;
    white-space: nowrap !important; /* 5.2) No wrap por defecto en todas */
}

/* ==========================================================================
   6) Permitir wrap SOLO en la columna “Informes” (ajusta el número si cambia)
   ========================================================================== */
.dlterapias-terapias th:nth-child(7),
.dlterapias-terapias td:nth-child(7) {
    white-space: normal !important;        /* 6.1) Permitir salto de línea */
    word-break: break-word !important;     /* 6.2) Parte palabras largas */
    overflow-wrap: anywhere !important;    /* 6.3) Soporte Chrome/otros */
}

/* ==========================================================================
   7) Cabecera y enlaces de la tabla
   ========================================================================== */
.dlterapias-terapias th {
    background: #44475a !important;
    color: #fff !important;
}
.dlterapias-terapias a {
    color: #8be9fd !important;
    text-decoration: underline !important;
}

/* ==========================================================================
   8) Estilos Mis Productos (separación entre línea y botón)
   ========================================================================== */
.dlterapias-productos ul {
    list-style: none;
    padding: 0;
    margin: 0;
}
.dlterapias-productos ul li {
    margin-bottom: 0.75em;    /* 8.1) Separación vertical */
    display: flex;            /* 8.2) Flex para gap */
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5em;               /* 8.3) Espacio entre texto y botón */
}
.dlterapias-productos ul li .dlterapias-descargar-pdf {
    display: inline-block;    /* Asegura que el botón mantenga su tamaño */
}

/* ==========================================================================
   9) Responsive: Pestañas en móviles (<590px)
   ========================================================================== */
@media (max-width: 590px) {
    /* 9.1) Permitir wrap de pestañas para ocupar varias líneas */
    .dlterapias-tab-list {
        flex-wrap: wrap !important;
    }
    /* 9.2) Cada pestaña ocupa línea completa y ajusta padding/font */
    .dlterapias-tab-list li {
        flex: 1 1 100% !important;
        margin-right: 0 !important;
        margin-bottom: 4px !important;
        padding: .5em 1em !important;
        font-size: .85em !important;
        text-align: center !important;
    }
    /* 9.3) Opcional: oculta el primer carácter (emoji) */
    .dlterapias-tab-list li::first-letter {
        display: none;
    }
}


/* ==========================================================================
   10) Mi Perfil: forzar labels en blanco
   ========================================================================== */
   .dlterapias-perfil label {
    color: #ffffff !important; /* 1) Texto de las etiquetas siempre en blanco */
  }


  /* ==========================================================================
   11) AVATAR: tamaño fijo y círculo perfecto
   ========================================================================== */

    /* 1) Contenedor del avatar en el header y en el perfil */
    .dlterapias-avatar,
    .dlterapias-perfil img {
    /* 1.1) Tamaño estándar: 80×80px */
    width: 80px !important;
    height: 80px !important;
    /* 1.2) Círculo perfecto */
    border-radius: 50% !important;
    /* 1.3) Ajustar imagen al contenedor, recortando si hace falta */
    object-fit: cover !important;
    /* 1.4) Evitar que el elemento estire el contenedor padre */
    display: inline-block !important;
    }

    /* 2) En el menú de avatar, reducir un poco para encajar mejor */
    .dlterapias-avatar-container .dlterapias-avatar {
    width: 40px !important;    /* mismo tamaño que ya definías */
    height: 40px !important;
    }


    /* ==========================================================================
   Ajustes para el botón “Eliminar cuenta”
   ========================================================================== */
/* 1) Restaurar tamaño de fuente normal */
.dlterapias-form-danger .button-danger {
    font-size: 14px !important;             /* Mismo tamaño que el resto del texto */
    line-height: 1.2 !important;            /* Alineación vertical óptima */
    border-radius: 10px !important;
  }
  
  /* 2) Colores rojo de advertencia */
  .dlterapias-form-danger .button-danger {
    background-color: #e53e3e !important;   /* Fondo rojo */
    border-color:     #e53e3e !important;   /* Borde rojo */
    color:            #ffffff !important;   /* Texto en blanco */
  }
  
  /* 3) Efecto hover más claro */
  .dlterapias-form-danger .button-danger:hover {
    background-color: #c53030 !important;   /* Rojo más oscuro al pasar el ratón */
    border-color:     #c53030 !important;
  }
  
  /* 4) Asegurar que el emoji / icono use el mismo tamaño de la fuente */
.dlterapias-form-danger .button-danger::before,
.dlterapias-form-danger .button-danger > .emoji {
  font-size: inherit !important;          /* Hereda el 14px */
}

/* ==========================================================================
   12) Dashboard resumen de cliente (Mi cuenta)
   ========================================================================== */
.dlterapias-cliente-dashboard {
  background: linear-gradient(160deg, #232635 0%, #2d3147 55%, #25344f 100%) !important;
  border: 1px solid rgba(255, 255, 255, 0.12) !important;
  border-radius: 14px !important;
  padding: 1rem 1.1rem !important;
  margin: 0 0 1rem 0 !important;
}

.dlterapias-cliente-dashboard-head h2 {
  margin: 0 0 0.35rem 0 !important;
  font-size: 1.3rem !important;
  color: #fff !important;
}

.dlterapias-cliente-dashboard-head p {
  margin: 0 0 1rem 0 !important;
  color: #c7cee3 !important;
}

.dlterapias-cliente-dashboard-cards {
  display: grid !important;
  grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
  gap: 0.6rem !important;
  margin-bottom: 0.8rem !important;
}

.dlterapias-resumen-card {
  background: rgba(255, 255, 255, 0.06) !important;
  border: 1px solid rgba(255, 255, 255, 0.12) !important;
  border-radius: 12px !important;
  padding: 0.7rem !important;
}

.dlterapias-resumen-card span {
  display: block !important;
  color: #b8c2df !important;
  font-size: 0.8rem !important;
}

.dlterapias-resumen-card strong {
  display: block !important;
  margin-top: 0.25rem !important;
  color: #fff !important;
  font-size: 1.25rem !important;
  line-height: 1 !important;
}

.dlterapias-cliente-dashboard-next {
  background: rgba(139, 233, 253, 0.08) !important;
  border: 1px solid rgba(139, 233, 253, 0.25) !important;
  border-radius: 12px !important;
  padding: 0.8rem !important;
  margin-bottom: 0.8rem !important;
}

.dlterapias-cliente-dashboard-next p {
  margin: 0 0 0.6rem 0 !important;
}

.dlterapias-cliente-dashboard-next p:last-child {
  margin-bottom: 0 !important;
}

@media (max-width: 1100px) {
  .dlterapias-cliente-dashboard-cards {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 640px) {
  .dlterapias-cliente-dashboard-cards {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .dlterapias-cliente-dashboard-head h2 {
    font-size: 1.08rem !important;
  }
}

/* ==========================================================================
   13) Override "Mi cuenta" adaptado al theme activo
   ========================================================================== */
.dlterapias-mi-cuenta-tabs {
  --dl-mc-shell: rgba(10, 18, 38, 0.82);
  --dl-mc-text: #eef4ff;
  --dl-mc-muted: #c4d0ea;
  --dl-mc-border: rgba(255, 255, 255, 0.14);
  --dl-mc-tabs-bg: rgba(8, 15, 32, 0.42);
  --dl-mc-pill-bg: rgba(255, 255, 255, 0.06);
  --dl-mc-pill-text: #eef4ff;
  --dl-mc-accent: #0f7dc2;
  --dl-mc-accent-text: #ffffff;
  --dl-mc-hero-a: rgba(15, 125, 194, 0.18);
  --dl-mc-hero-b: rgba(10, 18, 38, 0.08);
  --dl-mc-card: rgba(10, 18, 38, 0.56);
  --dl-mc-note: rgba(15, 125, 194, 0.16);
  --dl-mc-note-border: rgba(143, 211, 255, 0.26);
  --dl-mc-th: rgba(255, 255, 255, 0.08);
  --dl-mc-link: #8fd3ff;
  --dl-mc-input-bg: rgba(255, 255, 255, 0.96);
  --dl-mc-input-text: #182235;
  --dl-mc-input-border: rgba(255, 255, 255, 0.2);
  min-height: auto !important;
  background: transparent !important;
  color: var(--dl-mc-text) !important;
  font: inherit !important;
  border: 1px solid var(--dl-mc-border) !important;
  border-radius: 16px !important;
  overflow: hidden !important;
}

.dlterapias-tab-list {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 0 !important;
  margin: 0 !important;
  padding: 0.35rem !important;
  list-style: none !important;
  background: var(--dl-mc-tabs-bg) !important;
  border-bottom: 1px solid var(--dl-mc-border) !important;
}

.dlterapias-tab-list li {
  margin: 0 0.35rem 0.35rem 0 !important;
  padding: 0.6rem 0.9rem !important;
  border-radius: 999px !important;
  border: 1px solid var(--dl-mc-border) !important;
  background: var(--dl-mc-pill-bg) !important;
  color: var(--dl-mc-pill-text) !important;
  font-size: 0.95rem !important;
  line-height: 1.2 !important;
}

.dlterapias-tab-list li.active {
  color: var(--dl-mc-accent-text) !important;
  border-color: var(--dl-mc-accent) !important;
  background: var(--dl-mc-accent) !important;
}

.dlterapias-tab-content {
  background: transparent !important;
  color: var(--dl-mc-text) !important;
  padding: 1rem !important;
}

.dlterapias-cliente-dashboard {
  margin: 0 !important;
  border-radius: 0 !important;
  border: 0 !important;
  border-bottom: 1px solid var(--dl-mc-border) !important;
  background:
    linear-gradient(
      135deg,
      var(--dl-mc-hero-a) 0%,
      var(--dl-mc-hero-b) 100%
    ),
    var(--dl-mc-shell) !important;
}

.dlterapias-cliente-dashboard-head h2,
.dlterapias-resumen-card strong,
.dlterapias-cliente-dashboard-next p,
.dlterapias-mi-cuenta-tabs .dlterapias-perfil,
.dlterapias-mi-cuenta-tabs .dlterapias-clases,
.dlterapias-mi-cuenta-tabs .dlterapias-productos,
.dlterapias-mi-cuenta-tabs .dlterapias-comunidad {
  color: var(--dl-mc-text) !important;
}

.dlterapias-cliente-dashboard-head p,
.dlterapias-resumen-card span {
  color: var(--dl-mc-muted) !important;
}

.dlterapias-cliente-dashboard-cards {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 0.75rem !important;
}

.dlterapias-resumen-card {
  background: var(--dl-mc-card) !important;
  border: 1px solid var(--dl-mc-border) !important;
  box-shadow: 0 6px 18px rgba(16, 33, 64, 0.06) !important;
}

.dlterapias-cliente-dashboard-next {
  background: var(--dl-mc-note) !important;
  border: 1px solid var(--dl-mc-note-border) !important;
}

.dlterapias-terapias {
  background: transparent !important;
  color: var(--dl-mc-text) !important;
}

.dlterapias-terapias th {
  background: var(--dl-mc-th) !important;
  color: var(--dl-mc-text) !important;
}

.dlterapias-terapias th,
.dlterapias-terapias td {
  border-color: var(--dl-mc-border) !important;
}

.dlterapias-terapias a {
  color: var(--dl-mc-link) !important;
}

.dlterapias-perfil label {
  color: var(--dl-mc-text) !important;
}

.dlterapias-mi-cuenta-tabs input:not([type="checkbox"]):not([type="radio"]):not([type="file"]),
.dlterapias-mi-cuenta-tabs select,
.dlterapias-mi-cuenta-tabs textarea {
  background: var(--dl-mc-input-bg) !important;
  color: var(--dl-mc-input-text) !important;
  border: 1px solid var(--dl-mc-input-border) !important;
}

.dlterapias-mi-cuenta-tabs .button.button-primary {
  background: var(--dl-mc-accent) !important;
  border-color: var(--dl-mc-accent) !important;
  color: var(--dl-mc-accent-text) !important;
}

@media (max-width: 900px) {
  .dlterapias-cliente-dashboard-cards {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 590px) {
  .dlterapias-tab-list {
    padding: 0.45rem !important;
  }

  .dlterapias-tab-list li {
    flex: 1 1 calc(50% - 0.35rem) !important;
    margin-right: 0.35rem !important;
    text-align: center !important;
  }

  .dlterapias-tab-content {
    padding: 0.8rem !important;
  }
}

/* Elementor - DL Card widget */
.dl-cards-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
}

.dl-cards-grid .dl-card {
  width: 100%;
  height: 100%;
}

:where(.dl-card) {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 16px;
  width: 100%;
  padding: 20px;
  border: 1px solid #e4e7ec;
  border-radius: 16px;
  background: #fff;
  overflow: hidden;
}

.dl-card__media img {
  display: block;
  width: 100%;
  height: 220px;
  object-fit: cover;
}

.dl-card--media-bleed.dl-card--img-top {
  gap: 0;
}

.dl-card--media-bleed.dl-card--img-top .dl-card__media {
  margin-top: calc(var(--dl-card-pad-top, 20px) * -1);
  margin-right: calc(var(--dl-card-pad-right, 20px) * -1);
  margin-left: calc(var(--dl-card-pad-left, 20px) * -1);
}

.dl-card--media-bleed.dl-card--img-left .dl-card__media {
  margin-top: calc(var(--dl-card-pad-top, 20px) * -1);
  margin-bottom: calc(var(--dl-card-pad-bottom, 20px) * -1);
  margin-left: calc(var(--dl-card-pad-left, 20px) * -1);
}

.dl-card--media-bleed.dl-card--img-right .dl-card__media {
  margin-top: calc(var(--dl-card-pad-top, 20px) * -1);
  margin-right: calc(var(--dl-card-pad-right, 20px) * -1);
  margin-bottom: calc(var(--dl-card-pad-bottom, 20px) * -1);
}

.dl-card__body {
  display: flex;
  flex-direction: column;
  gap: 10px;
  position: relative;
  z-index: 2;
}

:where(.dl-card__badge) {
  display: inline-flex;
  align-self: flex-start;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 12px;
  line-height: 1.2;
  background: #eef2ff;
  color: #1d4ed8;
}

.dl-card--badge-top-left .dl-card__badge,
.dl-card--badge-top-right .dl-card__badge {
  position: absolute;
  top: 12px;
  z-index: 4;
}

.dl-card--badge-top-left .dl-card__badge {
  left: 12px;
}

.dl-card--badge-top-right .dl-card__badge {
  right: 12px;
}

.dl-card__title {
  margin: 0;
}

.dl-card__subtitle,
.dl-card__meta,
.dl-card__description,
.dl-card__price {
  margin: 0;
}

.dl-card__list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.dl-card__list-item {
  display: flex;
  align-items: flex-start;
  gap: 8px;
}

.dl-card__list-icon {
  flex: 0 0 auto;
  line-height: 1.2;
}

.dl-card__list-text {
  flex: 1 1 auto;
}

.dl-card__price {
  font-weight: 700;
}

.dl-card__cta-row {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.dl-card__footer {
  display: flex;
  width: 100%;
}

.dl-card--cta-inline .dl-card__cta-row {
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.dl-card--cta-inline .dl-card__price {
  margin-bottom: 0;
  flex: 1 1 auto;
}

.dl-card--cta-inline .dl-card__footer {
  margin-top: 0 !important;
  margin-left: auto;
  flex: 0 0 auto;
}

:where(.dl-card__button) {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 10px 16px;
  border-radius: 10px;
  border: 1px solid #0f172a;
  background: #0f172a;
  color: #fff;
  text-decoration: none;
}

:where(.dl-card--preset.dl-card--clase) {
  background: linear-gradient(160deg, #fff9ed 0%, #ffffff 100%);
  border-color: #f3d8a6;
}

:where(.dl-card--preset.dl-card--clase) .dl-card__badge,
:where(.dl-card--preset.dl-card--clase) .dl-card__button {
  background: #b7791f;
  border-color: #b7791f;
  color: #fff;
}

:where(.dl-card--preset.dl-card--sesion) {
  background: linear-gradient(160deg, #edf7ff 0%, #ffffff 100%);
  border-color: #bcdfff;
}

:where(.dl-card--preset.dl-card--sesion) .dl-card__badge,
:where(.dl-card--preset.dl-card--sesion) .dl-card__button {
  background: #0369a1;
  border-color: #0369a1;
  color: #fff;
}

:where(.dl-card--preset.dl-card--producto) {
  background: linear-gradient(160deg, #eefcf2 0%, #ffffff 100%);
  border-color: #b9e8c5;
}

:where(.dl-card--preset.dl-card--producto) .dl-card__badge,
:where(.dl-card--preset.dl-card--producto) .dl-card__button {
  background: #15803d;
  border-color: #15803d;
  color: #fff;
}

:where(.dl-card--preset.dl-card--comunidad) {
  background: linear-gradient(160deg, #f4f0ff 0%, #ffffff 100%);
  border-color: #d2c5ff;
}

:where(.dl-card--preset.dl-card--comunidad) .dl-card__badge,
:where(.dl-card--preset.dl-card--comunidad) .dl-card__button {
  background: #5b21b6;
  border-color: #5b21b6;
  color: #fff;
}

.dl-grid-img-top .dl-card,
.dl-card-layout-top .dl-card {
  flex-direction: column;
  align-items: stretch;
}

.dl-grid-img-top .dl-card .dl-card__media,
.dl-card-layout-top .dl-card .dl-card__media,
.dl-grid-img-left .dl-card .dl-card__media,
.dl-card-layout-left .dl-card .dl-card__media,
.dl-grid-img-right .dl-card .dl-card__media,
.dl-card-layout-right .dl-card .dl-card__media {
  position: static;
  inset: auto;
  z-index: auto;
}

.dl-grid-img-top .dl-card .dl-card__body,
.dl-card-layout-top .dl-card .dl-card__body,
.dl-grid-img-left .dl-card .dl-card__body,
.dl-card-layout-left .dl-card .dl-card__body,
.dl-grid-img-right .dl-card .dl-card__body,
.dl-card-layout-right .dl-card .dl-card__body {
  margin-top: 0;
}

.dl-grid-img-top .dl-card .dl-card__media,
.dl-card-layout-top .dl-card .dl-card__media {
  order: 1;
  flex: 0 0 auto;
}

.dl-grid-img-top .dl-card .dl-card__media img,
.dl-card-layout-top .dl-card .dl-card__media img {
  height: 220px;
  min-height: 0;
}

.dl-grid-img-top .dl-card .dl-card__body,
.dl-card-layout-top .dl-card .dl-card__body {
  order: 2;
  flex: 1 1 auto;
}

.dl-grid-img-left .dl-card,
.dl-card-layout-left .dl-card,
.dl-grid-img-right .dl-card,
.dl-card-layout-right .dl-card {
  flex-direction: row;
  align-items: stretch;
}

.dl-grid-img-left .dl-card .dl-card__media,
.dl-card-layout-left .dl-card .dl-card__media,
.dl-grid-img-right .dl-card .dl-card__media,
.dl-card-layout-right .dl-card .dl-card__media {
  flex: 0 0 40%;
}

.dl-grid-img-left .dl-card .dl-card__media img,
.dl-card-layout-left .dl-card .dl-card__media img,
.dl-grid-img-right .dl-card .dl-card__media img,
.dl-card-layout-right .dl-card .dl-card__media img {
  height: 100%;
  min-height: 220px;
}

.dl-grid-img-left .dl-card .dl-card__body,
.dl-card-layout-left .dl-card .dl-card__body,
.dl-grid-img-right .dl-card .dl-card__body,
.dl-card-layout-right .dl-card .dl-card__body {
  flex: 1 1 auto;
}

.dl-grid-img-left .dl-card .dl-card__media,
.dl-card-layout-left .dl-card .dl-card__media {
  order: 1;
}

.dl-grid-img-left .dl-card .dl-card__body,
.dl-card-layout-left .dl-card .dl-card__body {
  order: 2;
}

.dl-grid-img-right .dl-card .dl-card__media,
.dl-card-layout-right .dl-card .dl-card__media {
  order: 2;
}

.dl-grid-img-right .dl-card .dl-card__body,
.dl-card-layout-right .dl-card .dl-card__body {
  order: 1;
}

.dl-card-layout-bg .dl-card {
  min-height: 320px;
}

.dl-card-layout-bg .dl-card .dl-card__media {
  position: absolute;
  inset: 0;
  z-index: 1;
}

.dl-card-layout-bg .dl-card .dl-card__media img {
  height: 100%;
}

.dl-card-layout-bg .dl-card .dl-card__body {
  margin-top: auto;
}

.dl-grid-ribbon-top-left .dl-card__ribbon {
  left: var(--dl-grid-ribbon-x, 12px) !important;
  right: auto !important;
}

.dl-grid-ribbon-top-right .dl-card__ribbon {
  right: var(--dl-grid-ribbon-x, 12px) !important;
  left: auto !important;
}

.dl-card--img-left,
.dl-card--img-right {
  flex-direction: row;
  align-items: stretch;
}

.dl-card--img-left .dl-card__media,
.dl-card--img-right .dl-card__media {
  flex: 0 0 40%;
}

.dl-card--img-left .dl-card__media img,
.dl-card--img-right .dl-card__media img {
  height: 100%;
  min-height: 220px;
}

.dl-card--img-left .dl-card__body,
.dl-card--img-right .dl-card__body {
  flex: 1 1 auto;
}

.dl-card--img-right .dl-card__media {
  order: 2;
}

.dl-card--img-right .dl-card__body {
  order: 1;
}

.dl-card--bg {
  min-height: 320px;
}

.dl-card--bg .dl-card__media {
  position: absolute;
  inset: 0;
  z-index: 1;
}

.dl-card--bg .dl-card__media img {
  height: 100%;
}

.dl-card--bg .dl-card__body {
  margin-top: auto;
}

@media (max-width: 767px) {
  .dl-cards-grid {
    grid-template-columns: repeat(1, minmax(0, 1fr));
  }

  .dl-grid-ribbon-mobile-top-left .dl-card__ribbon {
    left: var(--dl-grid-ribbon-x, 12px) !important;
    right: auto !important;
  }

  .dl-grid-ribbon-mobile-top-right .dl-card__ribbon {
    right: var(--dl-grid-ribbon-x, 12px) !important;
    left: auto !important;
  }

  .dl-grid-img-mobile-top .dl-card,
  .dl-card-layout-mobile-top .dl-card {
    flex-direction: column;
    align-items: stretch;
  }

  .dl-grid-img-mobile-top .dl-card .dl-card__media,
  .dl-card-layout-mobile-top .dl-card .dl-card__media,
  .dl-grid-img-mobile-left .dl-card .dl-card__media,
  .dl-card-layout-mobile-left .dl-card .dl-card__media,
  .dl-grid-img-mobile-right .dl-card .dl-card__media,
  .dl-card-layout-mobile-right .dl-card .dl-card__media {
    position: static;
    inset: auto;
    z-index: auto;
  }

  .dl-grid-img-mobile-top .dl-card .dl-card__body,
  .dl-card-layout-mobile-top .dl-card .dl-card__body,
  .dl-grid-img-mobile-left .dl-card .dl-card__body,
  .dl-card-layout-mobile-left .dl-card .dl-card__body,
  .dl-grid-img-mobile-right .dl-card .dl-card__body,
  .dl-card-layout-mobile-right .dl-card .dl-card__body {
    margin-top: 0;
  }

  .dl-grid-img-mobile-top .dl-card .dl-card__media,
  .dl-card-layout-mobile-top .dl-card .dl-card__media {
    order: 1;
    flex: 0 0 auto;
  }

  .dl-grid-img-mobile-top .dl-card .dl-card__media img,
  .dl-card-layout-mobile-top .dl-card .dl-card__media img {
    height: 220px;
    min-height: 0;
  }

  .dl-grid-img-mobile-top .dl-card .dl-card__body,
  .dl-card-layout-mobile-top .dl-card .dl-card__body {
    order: 2;
  }

  .dl-grid-img-mobile-left .dl-card,
  .dl-card-layout-mobile-left .dl-card,
  .dl-grid-img-mobile-right .dl-card,
  .dl-card-layout-mobile-right .dl-card {
    flex-direction: row;
    align-items: stretch;
  }

  .dl-grid-img-mobile-left .dl-card .dl-card__media,
  .dl-card-layout-mobile-left .dl-card .dl-card__media,
  .dl-grid-img-mobile-right .dl-card .dl-card__media,
  .dl-card-layout-mobile-right .dl-card .dl-card__media {
    flex: 0 0 40%;
  }

  .dl-grid-img-mobile-left .dl-card .dl-card__media img,
  .dl-card-layout-mobile-left .dl-card .dl-card__media img,
  .dl-grid-img-mobile-right .dl-card .dl-card__media img,
  .dl-card-layout-mobile-right .dl-card .dl-card__media img {
    height: 100%;
    min-height: 220px;
  }

  .dl-grid-img-mobile-left .dl-card .dl-card__media,
  .dl-card-layout-mobile-left .dl-card .dl-card__media {
    order: 1;
  }

  .dl-grid-img-mobile-left .dl-card .dl-card__body,
  .dl-card-layout-mobile-left .dl-card .dl-card__body {
    order: 2;
  }

  .dl-grid-img-mobile-right .dl-card .dl-card__media,
  .dl-card-layout-mobile-right .dl-card .dl-card__media {
    order: 2;
  }

  .dl-grid-img-mobile-right .dl-card .dl-card__body,
  .dl-card-layout-mobile-right .dl-card .dl-card__body {
    order: 1;
  }

  .dl-card-layout-mobile-bg .dl-card {
    min-height: 320px;
  }

  .dl-card-layout-mobile-bg .dl-card .dl-card__media {
    position: absolute;
    inset: 0;
    z-index: 1;
  }

  .dl-card-layout-mobile-bg .dl-card .dl-card__media img {
    height: 100%;
  }

  .dl-card-layout-mobile-bg .dl-card .dl-card__body {
    margin-top: auto;
  }

  .dl-card--img-left,
  .dl-card--img-right {
    flex-direction: column;
  }

  .dl-card--img-right .dl-card__media {
    order: 1;
  }

  .dl-card--img-right .dl-card__body {
    order: 2;
  }
}

@media (min-width: 768px) and (max-width: 1024px) {
  .dl-grid-ribbon-tablet-top-left .dl-card__ribbon {
    left: var(--dl-grid-ribbon-x, 12px) !important;
    right: auto !important;
  }

  .dl-grid-ribbon-tablet-top-right .dl-card__ribbon {
    right: var(--dl-grid-ribbon-x, 12px) !important;
    left: auto !important;
  }

  .dl-grid-img-tablet-top .dl-card,
  .dl-card-layout-tablet-top .dl-card {
    flex-direction: column;
    align-items: stretch;
  }

  .dl-grid-img-tablet-top .dl-card .dl-card__media,
  .dl-card-layout-tablet-top .dl-card .dl-card__media,
  .dl-grid-img-tablet-left .dl-card .dl-card__media,
  .dl-card-layout-tablet-left .dl-card .dl-card__media,
  .dl-grid-img-tablet-right .dl-card .dl-card__media,
  .dl-card-layout-tablet-right .dl-card .dl-card__media {
    position: static;
    inset: auto;
    z-index: auto;
  }

  .dl-grid-img-tablet-top .dl-card .dl-card__body,
  .dl-card-layout-tablet-top .dl-card .dl-card__body,
  .dl-grid-img-tablet-left .dl-card .dl-card__body,
  .dl-card-layout-tablet-left .dl-card .dl-card__body,
  .dl-grid-img-tablet-right .dl-card .dl-card__body,
  .dl-card-layout-tablet-right .dl-card .dl-card__body {
    margin-top: 0;
  }

  .dl-grid-img-tablet-top .dl-card .dl-card__media,
  .dl-card-layout-tablet-top .dl-card .dl-card__media {
    order: 1;
    flex: 0 0 auto;
  }

  .dl-grid-img-tablet-top .dl-card .dl-card__media img,
  .dl-card-layout-tablet-top .dl-card .dl-card__media img {
    height: 220px;
    min-height: 0;
  }

  .dl-grid-img-tablet-top .dl-card .dl-card__body,
  .dl-card-layout-tablet-top .dl-card .dl-card__body {
    order: 2;
  }

  .dl-grid-img-tablet-left .dl-card,
  .dl-card-layout-tablet-left .dl-card,
  .dl-grid-img-tablet-right .dl-card,
  .dl-card-layout-tablet-right .dl-card {
    flex-direction: row;
    align-items: stretch;
  }

  .dl-grid-img-tablet-left .dl-card .dl-card__media,
  .dl-card-layout-tablet-left .dl-card .dl-card__media,
  .dl-grid-img-tablet-right .dl-card .dl-card__media,
  .dl-card-layout-tablet-right .dl-card .dl-card__media {
    flex: 0 0 40%;
  }

  .dl-grid-img-tablet-left .dl-card .dl-card__media img,
  .dl-card-layout-tablet-left .dl-card .dl-card__media img,
  .dl-grid-img-tablet-right .dl-card .dl-card__media img,
  .dl-card-layout-tablet-right .dl-card .dl-card__media img {
    height: 100%;
    min-height: 220px;
  }

  .dl-grid-img-tablet-left .dl-card .dl-card__media,
  .dl-card-layout-tablet-left .dl-card .dl-card__media {
    order: 1;
  }

  .dl-grid-img-tablet-left .dl-card .dl-card__body,
  .dl-card-layout-tablet-left .dl-card .dl-card__body {
    order: 2;
  }

  .dl-grid-img-tablet-right .dl-card .dl-card__media,
  .dl-card-layout-tablet-right .dl-card .dl-card__media {
    order: 2;
  }

  .dl-grid-img-tablet-right .dl-card .dl-card__body,
  .dl-card-layout-tablet-right .dl-card .dl-card__body {
    order: 1;
  }

  .dl-card-layout-tablet-bg .dl-card {
    min-height: 320px;
  }

  .dl-card-layout-tablet-bg .dl-card .dl-card__media {
    position: absolute;
    inset: 0;
    z-index: 1;
  }

  .dl-card-layout-tablet-bg .dl-card .dl-card__media img {
    height: 100%;
  }

  .dl-card-layout-tablet-bg .dl-card .dl-card__body {
    margin-top: auto;
  }
}
