:root{--color-primary:#99ac3a;--color-secondary:#007ab8;--color-tertiary:#1ea4a9;--color-body-background:#fbfbfb;--color-state:#313131;--color-state-hover:#3c6721;--color-state-focus:#3c6721;--color-state-active:#30541a;--color-state-highlight:#f6f9d7;--color-state-highlight-neutral:var(--color-neutral-3);--color-state-disabled:var(--color-neutral-5);--color-link-lateral-block:var(--color-state);--color-link-central-block:var(--color-state);--color-title-blocks:#fff;--color-title-catalog-box:var(--color-state);--color-icons:var(--color-state);--color-icons-star-rating:var(--color-state);--color-icons-rss-footer:#fff;--color-neutral-1:#fff;--color-neutral-2:#fafafa;--color-neutral-3:#f7f7f7;--color-neutral-4:#e6e4e4;--color-neutral-5:#c7c7c7;--color-neutral-6:#767676;--color-neutral-7:#262626;--color-background:var(--color-neutral-1);--color-border:var(--color-neutral-5);--color-text:#666666;--color-text-disabled:var(--color-neutral-5);--color-text-hint:var(--color-neutral-6);--link-color:#313131;--link-color-hover:var(--color-state-hover);--color-title-main:var(--color-text);--nav-bg-color:#313131;--nav-text-color:#ffffff;--nav-text-color-hover:var(--color-state-active);--nav-side-seperator-color:var(--nav-text-color);--nav-side-text-color-focus:var(--nav-text-color-hover);--nav-tab-expand-text-color:var(--color-text);--color-header-highlight:#2ABB9C;--font-size-custom:1;--btn-accent-color:#2ABB9C;--btn-accent-color-active:var(--color-state-active);--btn-accent-color-focus:var(--color-state-focus);--btn-accent-color-disabled:var(--color-state-disabled);--btn-prim-accent-color:#2ABB9C;--btn-prim-accent-color-active:var(--color-state-active);--btn-prim-accent-color-focus:var(--color-state-focus);--btn-prim-accent-color-disabled:var(--color-state-disabled);--btn-button-border-radius:4px;--footer-background-color:#313131;--footer-text-color:#FFFFFF;--second-footer-background-color:#313131;--second-footer-text-color:#FFFFFF;--block-background-color:#FFFFFF;--block-radius:4px;--block-border:0px solid #f00;--block-shadow:0 1px 3px 1px #ddd;--block-pre-header-color:#FFFFFF;--block-pre-header-background:#FDC151}:root{--select-icon-size:var(--gap-1)}.tui-select__input{display:inline-block;width:auto;max-width:none;height:auto;max-height:none;margin:0;padding:0;color:black;font:400 13.3333px Arial;font-size:inherit;line-height:inherit;letter-spacing:normal;white-space:pre;text-align:start;text-transform:none;text-indent:0;text-shadow:none;word-spacing:normal;background-color:white;border-color:darkgrey;border-style:solid;border-width:1px;border-radius:0;border-image:initial;box-shadow:none;cursor:default;transition-delay:0s;transition-timing-function:ease;transition-duration:0s;transition-property:all;text-rendering:auto;-webkit-appearance:menulist;appearance:menulist}.tui-select__input[disabled]{color:#3d444b;background:#dadada;cursor:default}.tui-select__input[multiple]{height:auto;overflow-x:hidden;overflow-y:visible}.tui-select__input:focus{border-color:#dadada;outline-width:3px;outline-style:auto;outline-color:Highlight;outline-color:-webkit-focus-ring-color;outline-offset:-2px;box-shadow:none;-moz-user-focus:normal}.tui-select{position:relative;display:flex;flex-grow:unset;width:100%;min-width:0;height:var(--form-input-height)}.tui-select--charLength-2{max-width:calc(2 * var(--form-input-font-size))}.tui-select--charLength-3{max-width:calc(3 * var(--form-input-font-size))}.tui-select--charLength-4{max-width:calc(4 * var(--form-input-font-size))}.tui-select--charLength-5{max-width:calc(5 * var(--form-input-font-size))}.tui-select--charLength-10{max-width:calc(10 * var(--form-input-font-size))}.tui-select--charLength-15{max-width:calc(15 * var(--form-input-font-size))}.tui-select--charLength-20{max-width:calc(20 * var(--form-input-font-size))}.tui-select--charLength-25{max-width:calc(25 * var(--form-input-font-size))}.tui-select--charLength-30{max-width:calc(30 * var(--form-input-font-size))}.tui-select--charLength-50{max-width:calc(50 * var(--form-input-font-size))}.tui-select--charLength-75{max-width:calc(75 * var(--form-input-font-size))}.tui-select--charLength-100{max-width:calc(100 * var(--form-input-font-size))}.tui-form--inputWidth-limited .tui-select:not(.tui-input--customSize){max-width:var(--form-input-limited-width)}.tui-form--inputWidth-limited .tui-inputSet--split .tui-select:not(.tui-input--customSize){max-width:none}.tui-select::after{position:absolute;top:calc((var(--form-input-height) - var(--select-icon-size)) / 2);right:calc((var(--form-input-height) - var(--select-icon-size) * 2) / 2);display:block;width:0;height:0;border:var(--select-icon-size) solid transparent;border-top-color:var(--form-input-text-color);content:'';pointer-events:none}.tui-select--disabled::after{border-top-color:var(--form-input-text-color-disabled)}.tui-select--multiple::after{display:none}.tui-select--large{height:var(--form-input-height-large)}.tui-select--large::after{top:calc((var(--form-input-height-large) - var(--select-icon-size)) / 2);right:calc((var(--form-input-height-large) - var(--select-icon-size) * 2) / 2)}.tui-select__input{flex-grow:1;box-sizing:border-box;width:100%;min-width:0;padding:0 var(--gap-6) 0 var(--gap-1);color:var(--form-input-text-color);font-size:var(--form-input-font-size);background:var(--form-input-bg-color);border:var(--form-input-border-size) solid;border-color:var(--form-input-border-color);-webkit-appearance:none;appearance:none}.tui-select__input[multiple]{height:auto}.tui-select__input[disabled]{color:var(--form-input-text-color-disabled);background:var(--form-input-bg-color-disabled);border-color:var(--form-input-border-color-disabled)}.tui-select__input:focus{background:var(--form-input-bg-color-focus);border:var(--form-input-border-size) solid;border-color:var(--form-input-border-color-focus);outline:none;box-shadow:var(--form-input-shadow-focus)}.tui-contextInvalid .tui-select__input:focus{background:var(--form-input-bg-color-invalid-focus);border-color:var(--form-input-border-color-invalid);box-shadow:var(--form-input-shadow-invalid-focus)}.tui-select__input:-moz-focusring{color:transparent;text-shadow:0 0 0 #000}.tui-select__input::-ms-expand{display:none}.tui-select__input::-ms-value{color:inherit;background-color:transparent}.tui-contextInvalid .tui-select__input{border-color:var(--form-input-border-color-invalid);box-shadow:var(--form-input-shadow-invalid)}:root{--nav-bg-color: #FFFFFF;--nav-text-color: #006975;--color-primary: #00B7BD;--btn-prim-accent-color: #008897;--btn-accent-color: #006975;--link-color: #313131;--color-state: #666666;--color-text: #666666;--block-background-color: #FFFFFF;--block-radius: 20px;--block-border: 0px solid #f00;--block-shadow: 0 1px 3px 1px #ddd;--block-pre-header-color: #FFFFFF;--block-pre-header-background: #00B7BD;--color-link-lateral-block: #008897;--color-link-central-block: #008897;--color-title-main: #006975;--color-title-blocks: #006975;--color-title-catalog-box: #006975;--color-icons: #F58C7C;--color-header-highlight: #00B7BD;--color-icons-star-rating: #DB7500;--color-body-background: #F9F9F9;--color-icons-rss-footer: #F58C7C;--btn-button-border-radius: 60px;--nav-text-color-hover: #004b57;--btn-prim-accent-color-focus: #007e8d;--btn-prim-accent-color-active: #006d7c;--btn-accent-color-focus: #005f6b;--btn-accent-color-active: #004e5a;--link-color-hover: #131313;--color-state-hover: #5c5c5c;--color-state-focus: #5c5c5c;--color-state-active: #4b4b4b;--font-size-custom: 1.0714;--footer-background-color: #006975;--footer-text-color: #FFFFFF;--second-footer-background-color: #006975;--second-footer-text-color: #FFFFFF;}
#inst9372 .block-totara-featured-links-layout .block-totara-featured-links-content::before {
background: rgba(255, 255, 255, 0.0)!important;
}

#inst9372 .block-totara-featured-links-layout .block-totara-featured-links-content.block-totara-featured-links-content-bottom h3{
color:white!important;
padding-bottom:5px!important;
}

#page-course-view-onetopicas .section .activity .contentafterlink {
    background-color: #f0f5f680;
    padding: 1em 0.5em 0 1em;
    border-radius: 12px 0 0 0;
    margin-left: 65px;
margin-top:0px!important;
}
body.course-1061 #region-top .content.block-content{
margin-top:-68px!important;
}

#inst9929.one-tech-launch .content.block-content,
#inst10654.one-tech-launch .content.block-content{
    background-image: url('https://ivirmacampus.com/pluginfile.php/1/local_uploadfiles/additionalimages/0/bg-one-tech.png');
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    text-align:center;
    padding:2em 1em!important;
}

#inst9929.one-tech-launch .content.block-content a,
#inst10654.one-tech-launch .content.block-content a{
    padding: 12px 25px;
    background-color: white;
    border-radius: 25px;
    color: var(--color-secondary);
    font-size: 15px;
    font-weight: 500;
    border: 1.5px solid white;
    transition: background-color 0.3s ease-in, transform 0.3s ease-in;
    margin-top:20px!important;
}

#inst9929.one-tech-launch .content.block-content a:hover,
#inst10654.one-tech-launch .content.block-content a:hover {
    color: white!important;
    background-color: #ffffff40 !important;
    transform: scale(1.03);
}

#inst9929.one-tech-launch .content.block-content img,
#inst10654.one-tech-launch .content.block-content img {
    margin-bottom:20px!important;
}

#inst9929 .no-overflow,
#inst10654 .no-overflow{
    overflow: hidden !important;
    padding: 10px;
}


/* ============================================
   ESTILOS SOLO PARA EL BLOQUE inst10405
   ============================================ */


/* Icono ordenar */
#inst10405 th .iconsort {
    color: #0F6C72 !important;
}

/* === FILAS === */
#inst10405 table.totaratable tbody tr {
    background: #ffffff !important;
    margin-bottom: 10px;
}

#inst10405 table.totaratable tbody tr {
    background: #ffffff !important;
    margin: 10px;
}

#inst10405 table.totaratable tbody tr td {
    padding: 12px 16px; /* el padding va aquí */
}

#inst10405 table.totaratable td {
    padding: 10px 10px 2px 10px !important;
    border: none !important;
    font-size: 15px !important;
}



/* Línea fina separadora entre filas */
/* #inst10405 table.totaratable tbody tr:not(:last-child) {
#    border-bottom: 1px solid #F2F2F2 !important;
# } */

/* Enlaces del nombre del curso */
#inst10405 table.totaratable a {
    color: #0F6C72 !important;
    font-weight: 600;
    text-decoration: none;
}

/* === BARRAS DE PROGRESO === */

#inst10405 .progressbar_container .bar {
    border-radius: 20px !important;
}

/* Color gris 0% */
#inst10405 .bar[aria-valuenow="0"] {
    background: #D2D2D2 !important;
}

/* Color naranja 50% */
#inst10405 .bar[aria-valuenow="50"] {
    background: #FF9F37 !important;
}

/* Texto del % */
#inst10405 .progressbar__text {
    color: #444 !important;
    font-size: 14px !important;
    margin-left: 6px;
}

/* Quitar pie "Ver informe completo" */
#inst10405 .footer,
#inst10405 .footer a {
    display: none !important;
}


/* ===== ICONO FA DE DOCUMENTO CON LÍNEAS DE TEXTO ===== */
/* Solo aplica al bloque inst10405 */

#inst10405 table.totaratable td.course_courselink a {
    position: relative;
    padding-left: 26px !important;
    display: inline-flex;
    align-items: center;
}

/* Iconos FontAwesome */
#inst10405 table.totaratable td.course_courselink a::before {
    font-family: "FontAwesome";
    content: "\f0f6";   /* ICONO: fa-file-text-o */
    font-size: 20px;
    color: #F58C7C;
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    opacity: 0.95;
}



#inst10405 table.totaratable td.base_timecompleted::before {
    font-family: "Font Awesome 6 Free"; /* obligatorio */
    font-weight: 400; /* regular (outline) */
    content: "\f058"; /* circle-check */
    padding-right: 10px;
    font-size: 18px;
    color: #4fcb3e;
    position: relative;
    left: 0;
    top: 40%;
    opacity: 0.95;
}


/* Hover */
#inst10405 table.totaratable td.course_courselink a:hover::before {
    opacity: 1;
}

/* Quitar padding extra del contenedor */
#inst10507 .content.block-content {
    padding: 0 !important;
}




/* =======================================================
   DASHBOARD PNTS – Estilos encapsulados
   Page ID: #page-totara-dashboard-33
   ======================================================= */



/* ===========================
   Informe PNTs Globales (inst10607 / inst11103 / inst11136)
   =========================== */

/* Tabla principal */
#page-totara-dashboard-33 #inst10607 table.totaratable,
#page-totara-dashboard-33 #inst11103 table.totaratable,
#page-totara-dashboard-33 #inst11136 table.totaratable {
    display: block !important;
    width: 100% !important;
    border-collapse: unset !important;
    border-spacing: 0 !important;
    border-radius: 0 !important;
    overflow: visible !important;
    background: #ffffff !important;
}

/* Tabla → grid */
#page-totara-dashboard-33 #inst10607 table.totaratable tbody,
#page-totara-dashboard-33 #inst11103 table.totaratable tbody,
#page-totara-dashboard-33 #inst11136 table.totaratable tbody {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 16px !important;
    padding: 20px !important;
    box-sizing: border-box !important;
    width: 100% !important;
}

/* Fila como tile */
#page-totara-dashboard-33 #inst10607 table.totaratable tr,
#page-totara-dashboard-33 #inst11103 table.totaratable tr,
#page-totara-dashboard-33 #inst11136 table.totaratable tr {
    display: block !important;
    background: #ffffff !important;
    border-radius: 12px !important;
    overflow: hidden !important;
    border: 1px solid #e5e7eb !important;
    transition: box-shadow 0.2s ease !important;
}

#page-totara-dashboard-33 #inst10607 table.totaratable tr:hover,
#page-totara-dashboard-33 #inst11103 table.totaratable tr:hover,
#page-totara-dashboard-33 #inst11136 table.totaratable tr:hover {
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1) !important;
    cursor: pointer !important;
}

/* Celda principal */
#page-totara-dashboard-33 #inst10607 table.totaratable td.c0,
#page-totara-dashboard-33 #inst11103 table.totaratable td.c0,
#page-totara-dashboard-33 #inst11136 table.totaratable td.c0 {
    display: block !important;
    padding: 0 !important;
    border: none !important;
    background: transparent !important;
    font-size: 14px !important;
    font-weight: 500 !important;
}

/* Imagen superior del tile */
#page-totara-dashboard-33 #inst10607 table.totaratable td.c0::before,
#page-totara-dashboard-33 #inst11103 table.totaratable td.c0::before,
#page-totara-dashboard-33 #inst11136 table.totaratable td.c0::before {
    content: '' !important;
    display: block !important;
    width: 100% !important;
    aspect-ratio: 16 / 9 !important;
    background: url('https://ivirmacampus.com/pluginfile.php/1/course/defaultcourseimage/2545/microscopio-lwfi7vnuibs.jpg') center / cover no-repeat !important;
}

/* Ocultar icono original */
#page-totara-dashboard-33 #inst10607 table.totaratable td .course_icon,
#page-totara-dashboard-33 #inst11103 table.totaratable td .course_icon,
#page-totara-dashboard-33 #inst11136 table.totaratable td .course_icon {
    display: none !important;
}

/* Etiqueta "CURSO" */
#page-totara-dashboard-33 #inst10607 table.totaratable td.c0 a::before,
#page-totara-dashboard-33 #inst11103 table.totaratable td.c0 a::before,
#page-totara-dashboard-33 #inst11136 table.totaratable td.c0 a::before {
    content: 'CURSO' !important;
    display: block !important;
    font-size: 11px !important;
    font-weight: bold !important;
    color: var(--color-primary) !important;
    letter-spacing: 0.05em !important;
    margin-bottom: 4px !important;
}

/* Título del curso */
#page-totara-dashboard-33 #inst10607 table.totaratable td.c0 a,
#page-totara-dashboard-33 #inst11103 table.totaratable td.c0 a,
#page-totara-dashboard-33 #inst11136 table.totaratable td.c0 a {
    display: block !important;
    padding: 12px !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    color: #006d7c !important;
    text-decoration: none !important;
    line-height: 1.4 !important;
}

#page-totara-dashboard-33 #inst10607 table.totaratable td.c0 a:hover,
#page-totara-dashboard-33 #inst11103 table.totaratable td.c0 a:hover,
#page-totara-dashboard-33 #inst11136 table.totaratable td.c0 a:hover {
    text-decoration: underline !important;
    color: #008897 !important;
}

/* Barra inferior (progreso) */
#page-totara-dashboard-33 #inst10607 table.totaratable td.c0::after,
#page-totara-dashboard-33 #inst11103 table.totaratable td.c0::after,
#page-totara-dashboard-33 #inst11136 table.totaratable td.c0::after {
    content: '' !important;
    display: block !important;
    height: 4px !important;
    background: #e5e7eb !important;
    margin: 4px 12px 12px !important;
    border-radius: 4px !important;
}

/* Mostrar paginacion, ocultar tabla y grafico */
#page-totara-dashboard-33 #inst10607 .totara-table-container,
#page-totara-dashboard-33 #inst11103 .totara-table-container,
#page-totara-dashboard-33 #inst11136 .totara-table-container {
    display: block !important;
    margin-top: 12px;
}

#page-totara-dashboard-33 #inst10607 .totara-table-container .totara-toolbar-top,
#page-totara-dashboard-33 #inst11103 .totara-table-container .totara-toolbar-top,
#page-totara-dashboard-33 #inst11136 .totara-table-container .totara-toolbar-top,
#page-totara-dashboard-33 #inst10607 .totara-table-container .totara-toolbar-bottom,
#page-totara-dashboard-33 #inst11103 .totara-table-container .totara-toolbar-bottom,
#page-totara-dashboard-33 #inst11136 .totara-table-container .totara-toolbar-bottom,
#page-totara-dashboard-33 #inst10607 .totara-table-container .paging,
#page-totara-dashboard-33 #inst11103 .totara-table-container .paging,
#page-totara-dashboard-33 #inst11136 .totara-table-container .paging {
    display: none !important;
}

#page-totara-dashboard-33 #inst10607 .totara-table-container table.totaratable,
#page-totara-dashboard-33 #inst11103 .totara-table-container table.totaratable,
#page-totara-dashboard-33 #inst11136 .totara-table-container table.totaratable {
    display: none !important;
}

#page-totara-dashboard-33 #inst10607 .rb-report-svggraph,
#page-totara-dashboard-33 #inst11103 .rb-report-svggraph,
#page-totara-dashboard-33 #inst11136 .rb-report-svggraph {
    display: none !important;
}

/* Tiles generadas por JS */
#page-totara-dashboard-33 #inst10607 .pnts-filter-bar,
#page-totara-dashboard-33 #inst11103 .pnts-filter-bar,
#page-totara-dashboard-33 #inst11136 .pnts-filter-bar {
    padding: 12px 15px;
}

#page-totara-dashboard-33 #inst10607 .nav.nav-tabs,
#page-totara-dashboard-33 #inst11103 .nav.nav-tabs,
#page-totara-dashboard-33 #inst11136 .nav.nav-tabs {
    background: transparent !important;
    background-color: transparent !important;
}

#page-totara-dashboard-33 #inst10607 .nav.nav-tabs li,
#page-totara-dashboard-33 #inst11103 .nav.nav-tabs li,
#page-totara-dashboard-33 #inst11136 .nav.nav-tabs li {
    padding: 20px;
}

#page-totara-dashboard-33 #inst10607 .nav.nav-tabs li.active a,
#page-totara-dashboard-33 #inst11103 .nav.nav-tabs li.active a,
#page-totara-dashboard-33 #inst11136 .nav.nav-tabs li.active a {
    border-radius: var(--border-radius-medium);
}

#page-totara-dashboard-33 #inst10607 .pnts-tiles-wrap,
#page-totara-dashboard-33 #inst11103 .pnts-tiles-wrap,
#page-totara-dashboard-33 #inst11136 .pnts-tiles-wrap {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
    padding: 20px;
    align-items: stretch;
    grid-auto-flow: row dense;
}

#page-totara-dashboard-33 #inst10607 .pnts-tile,
#page-totara-dashboard-33 #inst11103 .pnts-tile,
#page-totara-dashboard-33 #inst11136 .pnts-tile {
    background: #ffffff;
    border-radius: 20px;
    overflow: hidden;
    box-shadow: var(--shadow-2);
    transition: box-shadow 0.2s ease;
    position: relative;
    display: flex;
    flex-direction: column;
    height: 100%;
    box-sizing: border-box;
}

#page-totara-dashboard-33 #inst10607 .pnts-tile:hover,
#page-totara-dashboard-33 #inst11103 .pnts-tile:hover,
#page-totara-dashboard-33 #inst11136 .pnts-tile:hover {
    box-shadow: 0 4px 12px rgba(0,0,0,0.1);
    cursor: pointer;
}

#page-totara-dashboard-33 #inst10607 .pnts-tile__img,
#page-totara-dashboard-33 #inst11103 .pnts-tile__img,
#page-totara-dashboard-33 #inst11136 .pnts-tile__img {
    width: 100%;
    aspect-ratio: 16/9;
    background-size: cover;
    background-position: center;
    max-height: 180px;
}

#page-totara-dashboard-33 #inst10607 .pnts-tile__body,
#page-totara-dashboard-33 #inst11103 .pnts-tile__body,
#page-totara-dashboard-33 #inst11136 .pnts-tile__body {
    padding: 20px 20px 40px;
    flex: 1;
    display: flex;
    flex-direction: column;
}

#page-totara-dashboard-33 #inst10607 .pnts-tile__type,
#page-totara-dashboard-33 #inst11103 .pnts-tile__type,
#page-totara-dashboard-33 #inst11136 .pnts-tile__type {
    display: block;
    font-size: 11px;
    font-weight: bold;
    color: var(--color-primary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 4px;
}

#page-totara-dashboard-33 #inst10607 .pnts-tile__title,
#page-totara-dashboard-33 #inst11103 .pnts-tile__title,
#page-totara-dashboard-33 #inst11136 .pnts-tile__title {
    font-size: var(--font-size-16);
    font-weight: bold;
    color: #006d7c;
    line-height: 1.4;
    margin: 0 0 10px;
}

#page-totara-dashboard-33 #inst10607 .pnts-tile__badge,
#page-totara-dashboard-33 #inst11103 .pnts-tile__badge,
#page-totara-dashboard-33 #inst11136 .pnts-tile__badge {
    position: absolute;
    top: 12px;
    left: 12px;
    z-index: 2;
    font-size: 12px;
    font-weight: 700;
    color: #ffffff;
    padding: 6px 10px;
    border-radius: 999px;
    text-transform: none;
    line-height: 1;
    letter-spacing: 0.01em;
    box-shadow: 0 2px 6px rgba(0,0,0,0.15);
}

#page-totara-dashboard-33 #inst10607 .pnts-tile__badge--success,
#page-totara-dashboard-33 #inst11103 .pnts-tile__badge--success,
#page-totara-dashboard-33 #inst11136 .pnts-tile__badge--success {
    background: #28a745;
}

#page-totara-dashboard-33 #inst10607 .pnts-tile__badge--warning,
#page-totara-dashboard-33 #inst11103 .pnts-tile__badge--warning,
#page-totara-dashboard-33 #inst11136 .pnts-tile__badge--warning {
    background: #ffc107;
}

#page-totara-dashboard-33 #inst10607 .pnts-tile__badge--orange,
#page-totara-dashboard-33 #inst11103 .pnts-tile__badge--orange,
#page-totara-dashboard-33 #inst11136 .pnts-tile__badge--orange {
    background: #fd7e14;
}

#page-totara-dashboard-33 #inst10607 .pnts-tile__badge--danger,
#page-totara-dashboard-33 #inst11103 .pnts-tile__badge--danger,
#page-totara-dashboard-33 #inst11136 .pnts-tile__badge--danger {
    background: #dc3545;
}

#page-totara-dashboard-33 #inst10607 .pnts-tile__badge--completed,
#page-totara-dashboard-33 #inst11103 .pnts-tile__badge--completed,
#page-totara-dashboard-33 #inst11136 .pnts-tile__badge--completed {
    background: #ffffff;
    color: var(--color-primary, #0F6C72);
    border: 1.5px solid var(--color-primary, #0F6C72);
}

#page-totara-dashboard-33 #inst10607 .pnts-tile__badge--completed i,
#page-totara-dashboard-33 #inst11103 .pnts-tile__badge--completed i,
#page-totara-dashboard-33 #inst11136 .pnts-tile__badge--completed i {
    color: var(--color-primary, #0F6C72);
}

#page-totara-dashboard-33 #inst10607 .pnts-badge-tooltip,
#page-totara-dashboard-33 #inst11103 .pnts-badge-tooltip,
#page-totara-dashboard-33 #inst11136 .pnts-badge-tooltip {
    font-weight: 400;
    position: absolute;
    line-height: 1.5rem;
    top: calc(100% + 3px);
    left: 0;
    min-width: 300px;
    max-width: 450px;
    background: #ffffffe6;
    color: #1f2937;
    border: 1px solid #e5e7eb;
    border-radius: 5px;
    padding: 5px 15px 10px 10px;
    box-shadow: 0 8px 24px rgba(0,0,0,0.12);
    opacity: 0;
    visibility: hidden;
    transform: translateY(-4px);
    transition: opacity 0.15s ease, transform 0.15s ease, visibility 0.15s ease;
    z-index: 3;
    pointer-events: none;
}

#page-totara-dashboard-33 #inst10607 .pnts-tile__badge:hover .pnts-badge-tooltip,
#page-totara-dashboard-33 #inst11103 .pnts-tile__badge:hover .pnts-badge-tooltip,
#page-totara-dashboard-33 #inst11136 .pnts-tile__badge:hover .pnts-badge-tooltip {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

#page-totara-dashboard-33 #inst10607 .pnts-badge-tooltip__title,
#page-totara-dashboard-33 #inst11103 .pnts-badge-tooltip__title,
#page-totara-dashboard-33 #inst11136 .pnts-badge-tooltip__title {
    font-size: 12px;
    font-weight: 700;
    margin-bottom: 6px;
    color: #111827;
}

#page-totara-dashboard-33 #inst10607 .pnts-badge-tooltip__item,
#page-totara-dashboard-33 #inst11103 .pnts-badge-tooltip__item,
#page-totara-dashboard-33 #inst11136 .pnts-badge-tooltip__item {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    color: #374151;
    margin-top: 4px;
}

#page-totara-dashboard-33 #inst10607 .pnts-badge-tooltip__dot,
#page-totara-dashboard-33 #inst11103 .pnts-badge-tooltip__dot,
#page-totara-dashboard-33 #inst11136 .pnts-badge-tooltip__dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    display: inline-block;
    flex: 0 0 auto;
}

#page-totara-dashboard-33 #inst10607 .pnts-badge-tooltip__dot--success,
#page-totara-dashboard-33 #inst11103 .pnts-badge-tooltip__dot--success,
#page-totara-dashboard-33 #inst11136 .pnts-badge-tooltip__dot--success { background: #28a745; }
#page-totara-dashboard-33 #inst10607 .pnts-badge-tooltip__dot--warning,
#page-totara-dashboard-33 #inst11103 .pnts-badge-tooltip__dot--warning,
#page-totara-dashboard-33 #inst11136 .pnts-badge-tooltip__dot--warning { background: #ffc107; }
#page-totara-dashboard-33 #inst10607 .pnts-badge-tooltip__dot--orange,
#page-totara-dashboard-33 #inst11103 .pnts-badge-tooltip__dot--orange,
#page-totara-dashboard-33 #inst11136 .pnts-badge-tooltip__dot--orange { background: #fd7e14; }
#page-totara-dashboard-33 #inst10607 .pnts-badge-tooltip__dot--danger,
#page-totara-dashboard-33 #inst11103 .pnts-badge-tooltip__dot--danger,
#page-totara-dashboard-33 #inst11136 .pnts-badge-tooltip__dot--danger { background: #dc3545; }
#page-totara-dashboard-33 #inst10607 .pnts-badge-tooltip__dot--completed,
#page-totara-dashboard-33 #inst11103 .pnts-badge-tooltip__dot--completed,
#page-totara-dashboard-33 #inst11136 .pnts-badge-tooltip__dot--completed {
    background: #ffffff;
    border: 1px solid var(--color-primary, #0F6C72);
}

#page-totara-dashboard-33 #inst10607 .progress.progress-success .bar,
#page-totara-dashboard-33 #inst11103 .progress.progress-success .bar,
#page-totara-dashboard-33 #inst11136 .progress.progress-success .bar,
#page-totara-dashboard-33 #inst10607 .progress-success .bar,
#page-totara-dashboard-33 #inst11103 .progress-success .bar,
#page-totara-dashboard-33 #inst11136 .progress-success .bar {
    background-color: #008897 !important;
    background-image: none !important;
}

/* ===========================
   Mandatory SOPs (inst10360)
   =========================== */

#page-totara-dashboard-33 #inst10360 .tabtree ul.nav.nav-tabs {
    margin: 0px 12px;
    padding: 10px 8px 12px 10px;
    background: none !important;
}

#page-totara-dashboard-33 #inst10360 .nav.nav-tabs li {
    padding-right: 20px;
    padding-bottom: 8px;
}

#page-totara-dashboard-33 #inst10360 .content.block-content {
    border-radius: 10px !important;
    /* box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1) !important; */
    overflow: hidden !important;
}

#page-totara-dashboard-33 #inst10360 .block .block-header {
    padding-top: 3rem !important;
}

#page-totara-dashboard-33 #inst10360 .panel-footer {
    border-top: 0 !important;
    padding: 0 20px 20px 20px !important;
}

#page-totara-dashboard-33 #inst10360 .block_current_learningas-tiles {
    padding: 30px 15px 30px 15px;
}

.pnts-empty-msg {
    text-align: center;
    padding: 0px 20px;
}

/* ===========================
  PNTs Completados (inst10405)
   =========================== */

/* ==============================
   BLOQUES PNT'S
   ============================== */

#inst10405 .totara-table-container {
    display: flex;
    margin-left: auto;
    margin-right: auto;
    width: auto;
}

#inst10405 thead {
  display: none;
}


#inst10405 .footer {
  display: none;
}


#inst10405 tbody {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
}


div#region-main #inst10405.block .content {
  border-radius: 0px;
  border: none;
  box-shadow: none;
  background: transparent !important;
}


#inst10405 tr {
  width: calc(31%);
  border-top: 0;
  background: transparent;
  box-shadow: 0 3px 10px rgba(0,0,0,0.08);
  padding: 10px;
  border-radius: 15px;
  margin: 5px;
}


#inst10405 td {
  display: flex;
  border-top: 0;
  background: transparent;
  width: 100%;
  flex-direction: row;
  align-items: center;
}


#inst10405 td a {
  width: 100% !important;
  display: flex;
  flex-direction: row;
  align-items: center;
  background-color: #fff;
  gap: var(--spacing-large);
  font-weight: 700;
}


#inst10405 td a img.course_icon {
  background: var(--color-primary-light);
  padding: 14px;
  max-width: 65px !important;
  max-height: 65px !important;
  border-top-left-radius: var(--border-radius);
  border-bottom-left-radius: var(--border-radius);
}


#page-totara-dashboard-33 #inst10360 .content.block-content {
   margin:5px;
}


#page-totara-dashboard-33 #inst10405 .totara-table-container .totara-toolbar-top {
    display: none !important;
}

#page-totara-dashboard-33 #inst10405 #instance-10405-header {
    padding-top: 10px;
}

#page-totara-dashboard-33 #inst10405 .totara-table-container .toolbar-cell {
    padding: 10px 20px !important;
}


#page-totara-dashboard-33 #report_finalizacion_del_curso_incluye_historial th.c2,
#page-totara-dashboard-33 #report_finalizacion_del_curso_incluye_historial td.c2 {
    display: none !important;
}

/* === ESTILOS PARA PAGINACIÓN ACTIVA === */
#page-totara-dashboard-33 [class*="pagination"] .active,
#page-totara-dashboard-33 [class*="pagination"] .current,
#page-totara-dashboard-33 [class*="paging"] .active,
#page-totara-dashboard-33 [class*="paging"] .current,
#page-totara-dashboard-33 [class*="pager"] .active,
#page-totara-dashboard-33 [class*="pager"] .current {
    font-weight: bold !important;
    text-decoration: underline !important;
    color: #0F6C72 !important;
    pointer-events: auto !important;
}

/* ===========================
   Barra de búsqueda PNTs
   =========================== */

#page-totara-dashboard-33 .pnts-search-container {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 0 5px 8px 5px;
}

#page-totara-dashboard-33 .pnts-search-box {
    position: relative;
    flex: 1;
    min-width: 220px;
    max-width: 400px;
}

#page-totara-dashboard-33 .pnts-search-icon {
    position: absolute;
    left: 14px;
    top: 50%;
    transform: translateY(-50%);
    color: #9ca3af;
    font-size: 14px;
    pointer-events: none;
    z-index: 1;
}

#page-totara-dashboard-33 .pnts-search-input {
    width: 100%;
    padding: 10px 38px 10px 38px;
    border: 1.5px solid #e5e7eb;
    border-radius: 25px;
    font-size: 14px;
    color: #1f2937;
    background: #ffffff;
    outline: none;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
    box-sizing: border-box;
}

#page-totara-dashboard-33 .pnts-search-input:focus {
    border-color: var(--color-primary, #0F6C72);
    box-shadow: 0 0 0 3px rgba(15, 108, 114, 0.12);
}

#page-totara-dashboard-33 .pnts-search-input::placeholder {
    color: #9ca3af;
    font-style: italic;
}

#page-totara-dashboard-33 .pnts-search-clear {
    position: absolute;
    right: 8px;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    cursor: pointer;
    color: #9ca3af;
    font-size: 14px;
    padding: 4px 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    transition: color 0.15s ease, background 0.15s ease;
    text-decoration: none;
}

#page-totara-dashboard-33 .pnts-search-clear:hover {
    color: #1f2937;
    background: #f3f4f6;
}

/* === Paginación personalizada PNTs (cliente) === */
#page-totara-dashboard-33 #inst10607 .pnts-pagination,
#page-totara-dashboard-33 #inst11103 .pnts-pagination,
#page-totara-dashboard-33 #inst11136 .pnts-pagination {
    display: flex;
    justify-content: center;
    padding: 4px 20px 20px;
}

#page-totara-dashboard-33 #inst10607 .pnts-pagination__list,
#page-totara-dashboard-33 #inst11103 .pnts-pagination__list,
#page-totara-dashboard-33 #inst11136 .pnts-pagination__list {
    display: flex;
    list-style: none;
    margin: 0;
    padding: 0;
    gap: 4px;
    flex-wrap: wrap;
}

#page-totara-dashboard-33 #inst10607 .pnts-pagination__item a,
#page-totara-dashboard-33 #inst11103 .pnts-pagination__item a,
#page-totara-dashboard-33 #inst11136 .pnts-pagination__item a {
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 36px;
    height: 36px;
    padding: 0 10px;
    border-radius: 8px;
    border: 1.5px solid #e5e7eb;
    background: #ffffff;
    color: #374151;
    font-size: 14px;
    font-weight: 500;
    text-decoration: none !important;
    transition: all 0.15s ease;
    cursor: pointer;
}

#page-totara-dashboard-33 #inst10607 .pnts-pagination__item a:hover,
#page-totara-dashboard-33 #inst11103 .pnts-pagination__item a:hover,
#page-totara-dashboard-33 #inst11136 .pnts-pagination__item a:hover {
    background: #f3f4f6;
    border-color: var(--color-primary, #0F6C72);
    color: var(--color-primary, #0F6C72);
}

#page-totara-dashboard-33 #inst10607 .pnts-pagination__item.active a,
#page-totara-dashboard-33 #inst11103 .pnts-pagination__item.active a,
#page-totara-dashboard-33 #inst11136 .pnts-pagination__item.active a {
    background: var(--color-primary, #0F6C72) !important;
    border-color: var(--color-primary, #0F6C72) !important;
    color: #ffffff !important;
    font-weight: 700;
}

#page-totara-dashboard-33 #inst10607 .pnts-pagination__item.disabled a,
#page-totara-dashboard-33 #inst11103 .pnts-pagination__item.disabled a,
#page-totara-dashboard-33 #inst11136 .pnts-pagination__item.disabled a {
    opacity: 0.35;
    cursor: not-allowed;
    pointer-events: none;
}

/* ============================================================
   ciberseguridad-standalone.css  v4
   ============================================================ */

/* ── Header del bloque Totara (instance-11277-header) ─────── */
#inst11277 .block-header {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 0 1.25rem !important;
}

#instance-11277-header,
#inst11277 .block-title h2 {
  font-family: 'VAG Rounded Std', 'VAG Rounded', sans-serif;
  font-size: 30px !important;
  font-weight: 700 !important;
  color: #17417B !important;
  margin: 0 !important;
  padding: 0 !important;
  letter-spacing: 0.01em !important;
  background: transparent !important;
  border: none !important;
}

/* ── Anula fondo/sombra del bloque host ────────────────────── */
#inst11277,
#inst11277 > .content,
#inst11277 .block-content,
#inst11277 .no-overflow {
  background: transparent !important;
  background-color: transparent !important;
  box-shadow: none !important;
  border: none !important;
  padding: 0 !important;
}

/* ── Contenedor raíz ───────────────────────────────────────── */
.cyber-standalone {
  padding: 0;
  width: 100%;
}

.cyber-standalone__title {
  display: none;
}

/* ── Grid 3 columnas ───────────────────────────────────────── */
.cyber-standalone__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  list-style: none;
  margin: 0;
  padding: 0;
  align-items: stretch;
}

@media (max-width: 900px) {
  .cyber-standalone__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 600px) {
  .cyber-standalone__grid { grid-template-columns: 1fr; }
}

/* El <li> también debe estirarse */
.cyber-standalone__grid > li {
  display: flex;
  flex-direction: column;
}

/* ── Card ──────────────────────────────────────────────────── */
.cyber-card {
  position: relative;
  display: flex;
  flex-direction: column;
  flex: 1;
  background: #ffffff;
  border-radius: 25px;
  border: 0.5px solid rgba(0,0,0,0.07);
  overflow: hidden;
  cursor: pointer;
  text-decoration: none;
  color: inherit;
  box-shadow: 0 2px 8px rgba(0,0,0,0.07), 0 1px 2px rgba(0,0,0,0.05);
  transition: border-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}

.cyber-card:hover {
  border-color: #17417B;
  transform: translateY(-2px);
  box-shadow: 0 6px 18px rgba(23,65,123,0.12), 0 2px 4px rgba(0,0,0,0.06);
  text-decoration: none;
  color: inherit;
}

/* ── Card desactivada ──────────────────────────────────────── */

/*
 * Variables para controlar la card desactivada sin tocar el CSS:
 *
 *   --disabled-badge-opacity   : opacidad del badge        (0–1, defecto 0.85)
 *   --disabled-badge-bg        : color de fondo del badge
 *   --disabled-overlay-opacity : opacidad del título sobre la imagen (0–1, defecto 0.18)
 *   --disabled-text-opacity    : opacidad del cuerpo y pie (0–1, defecto 0.18)
 *
 * Ejemplo:
 *   :root {
 *     --disabled-badge-opacity: 0.5;
 *     --disabled-badge-bg: var(--color-primary);
 *     --disabled-text-opacity: 0.2;
 *   }
 */

.cyber-card.is-disabled {
  cursor: default;
  pointer-events: none;
}

.cyber-card.is-disabled:hover {
  border-color: rgba(0,0,0,0.07);
  transform: none;
  box-shadow: 0 2px 8px rgba(0,0,0,0.07), 0 1px 2px rgba(0,0,0,0.05);
}

/* Fondo: oscurecido y desaturado */
.cyber-card.is-disabled .cyber-card__bg {
  filter: blur(2px) grayscale(30%) brightness(0.9);
  opacity: 0.7;
}

/* Título y subtítulo sobre la imagen: muy transparentes */
.cyber-card.is-disabled .cyber-card__overlay {
  opacity: var(--disabled-overlay-opacity, 0.4);
}

/* Badge "Próximamente": bastante más visible que el resto del texto */
.cyber-card.is-disabled .cyber-card__soon {
  opacity: var(--disabled-badge-opacity, 0.8);
  background: var(--disabled-badge-bg, var(--color-primary));
}

/* Cuerpo y pie: muy transparentes */
.cyber-card.is-disabled .cyber-card__body,
.cyber-card.is-disabled .cyber-card__footer {
  opacity: var(--disabled-text-opacity, 0.25);
}


/* ── Imagen de cabecera ────────────────────────────────────── */
.cyber-card__image {
  position: relative;
  height: 140px;
  overflow: hidden;
  background: #ffffff;
  flex-shrink: 0;
}

.cyber-card__image::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(14,43,83,0.1) 0%, rgba(14,43,83,0.65) 100%);
  z-index: 1;
}

.cyber-card__bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

/* ── Badge "Próximamente: fecha" ───────────────────────────── */
.cyber-card__soon {
  position: absolute;
  top: 12px;
  left: 12px;
  z-index: 3;
  background: var(--color-primary-light);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  border: 1px solid rgba(255,255,255,0.35);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.3px;
  padding: 5px 11px 5px 9px;
  border-radius: 999px;
  display: flex;
  align-items: center;
  gap: 6px;
  line-height: 1.3;
  text-shadow: 0 1px 3px rgba(0,0,0,0.4);
  box-shadow: 0 2px 8px rgba(0,0,0,0.25);
}

.cyber-card__soon .fa {
  font-size: 10px;
  color: #fff;
  flex-shrink: 0;
}

/* ── Overlay título sobre imagen ───────────────────────────── */
.cyber-card__overlay {
  position: absolute;
  bottom: 14px;
  left: 16px;
  right: 16px;
  z-index: 2;
  pointer-events: none;
}

.cyber-card__overlay-title {
  display: block;
  color: #fff;
  font-size: 19px;
  font-weight: 700;
  line-height: 1.25;
  text-shadow: 0 1px 4px rgba(0,0,0,0.5);
  margin: 0;
  padding-right: 3em;
}

.cyber-card__overlay-sub {
  display: block;
  color: rgba(255,255,255,0.88);
  font-size: 12px;
  margin-top: 2px;
  text-shadow: 0 1px 3px rgba(0,0,0,0.5);
}

/* ── Cuerpo ────────────────────────────────────────────────── */
.cyber-card__body {
  padding: 16px 18px 10px;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 4px;
  background: #ffffff;
}

.cyber-card__bloque {
  font-size: 20px;
  font-weight: 700;
  color: #223C84;
  letter-spacing: 0.4px;
  margin: 0;
}

.cyber-card__desc {
  font-size: 15px;
  color: #5C5F66;
  line-height: 1.5;
  margin: 4px 0 0;
  /* flex:1 eliminado — lo gestiona .cyber-card__body */
}

/* ── Pie: "Leer más" y vencimiento en la misma fila ────────── */
.cyber-card__footer {
  padding: 10px 18px 14px;
  background: #ffffff;
  display: flex;
  align-items: center;
  gap: 8px;
}

/* ── Etiqueta "Leer más" ───────────────────────────────────── */
.cyber-card__readmore {
  display: inline-block;
  background: #223C84;
  color: #fff;
  font-size: 11px;
  font-weight: 600;
  font-style: normal;
  padding: 4px 10px;
  border-radius: 999px;
  margin: 0;
  text-align: left;
  flex-shrink: 0;
}

/* ── Etiqueta de vencimiento ───────────────────────────────── */
.cyber-card__due {
  display: inline-block;
  background: #EFEFF0;
  color: #5C5F66;
  font-size: 11px;
  font-weight: 500;
  padding: 4px 10px;
  border-radius: 999px;
  flex-shrink: 0;
}


/* ── Modal ─────────────────────────────────────────────────── */
.ivirma-cyber-modal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 10000;
  align-items: center;
  justify-content: center;
}

.ivirma-cyber-modal.is-open { display: flex; }

.ivirma-cyber-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(14,43,83,0.55);
}

.ivirma-cyber-modal__dialog {
  position: relative;
  background: #fff;
  border-radius: 18px;
  width: 900px;
  max-width: 95%;
  max-height: 92vh;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: 0 20px 60px rgba(0,0,0,0.4);
}

/* ── Hero compacto ─────────────────────────────────────────── */
.ivirma-cyber-modal__hero {
  position: relative;
  min-height: 100px;
  background: linear-gradient(135deg, #0E2B53 0%, #17417B 100%);
  background-size: cover;
  background-position: center;
  padding: 35px;
  color: #fff;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 12px;
}

.ivirma-cyber-modal__hero.has-bg::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(14,43,83,0.25) 0%, rgba(14,43,83,0.8) 100%);
}

.ivirma-cyber-modal__hero > * { position: relative; z-index: 1; }

.ivirma-cyber-modal__hero-text {
  flex: 1;
  min-width: 0;
  text-align: left;
}

.ivirma-cyber-modal__close {
  position: absolute;
  padding:20px;
  top: 10px;
  right: 12px;
  left: auto;
  background: rgba(255,255,255,0);
  border: none;
  color: #fff;
  font-size: 22px;
  width: 28px; height: 28px;
  border-radius: 50%;
  cursor: pointer;
  z-index: 100;
  display: flex; align-items: center; justify-content: center;
  transition: background 0.15s;
  float: none;
}
.ivirma-cyber-modal__close:hover { background: rgba(255,255,255,0.3); }

/* El dialog es el padre posicionado del botón cerrar */
.ivirma-cyber-modal__dialog { position: relative; }

.ivirma-cyber-modal__title {
  font-size: 22px;
  font-weight: 500;
  margin: 0 0 3px;
  color: #fff;
  line-height: 1.2;
  text-align: left;
  padding-right: 0;
  text-shadow: 2px 2px 10px #000000b8;
}

.ivirma-cyber-modal__subtitle {
  padding-top: 20px;
  font-size: 14px;
  font-weight: 500;
  opacity: .85;
  margin: 0 0 6px;
  display: block;
}

.ivirma-cyber-modal__bloque {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  margin: 0;
  opacity: .8;
  display: block;
}

/* Duración — lado derecho del hero */
.ivirma-cyber-modal__duration {
  display: flex;
  align-items: center;
  gap: 8px;
  background: rgb(3 26 51);
  padding: 8px 12px;
  border-radius: 8px;
  flex-shrink: 0;
  align-self: flex-end;
}
.ivirma-cyber-modal__duration svg { width: 30px; height: 30px; flex-shrink: 0; }
.ivirma-cyber-modal__duration-label {
  font-size: 10px;
  opacity: .8;
  text-transform: uppercase;
  letter-spacing: .5px;
  display: block;
}
.ivirma-cyber-modal__duration-value {
  font-size: 14px;
  font-weight: 600;
  display: block;
}

/* ── Body ──────────────────────────────────────────────────── */
.ivirma-cyber-modal__body {
  display: grid;
  grid-template-columns: 1.4fr 0.6fr;
  gap: 26px;
  padding: 20px 20px 0;
  overflow-y: auto;
  flex: 1;
  padding: 45px;
}

.ivirma-cyber-modal__body h3 {
  font-size: 18px;
  font-family: 'VAG Rounded Std', 'VAG Rounded', sans-serif;
  font-weight: 600;
  text-transform: none;
  letter-spacing: normal;
  color: #17417B;
  margin: 0 0 6px;
}

.ivirma-cyber-modal__body p {
  font-size: 15px;
  color: #5C5F66;
  line-height: 1.55;
  margin: 0 0 16px;
}

.ivirma-cyber-modal__fechas { white-space: pre-line; }

.ivirma-cyber-modal__contenidos { display: flex; flex-direction: column; gap: 15px; }

/* ── Pills ─────────────────────────────────────────────────── */
.ivirma-cyber-modal__pill {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 15px;
  border-radius: 999px;
  border: none;
  background: #223C84 !important;
  text-decoration: none;
  color: #fff;
  font-size: 14px;
  font-weight: 500;
  transition: background 0.15s ease;
}
.ivirma-cyber-modal__pill:hover { background: #1a2f6a; text-decoration: none; color: #fff; }
.ivirma-cyber-modal__pill-text { flex: 1; min-width: 0; }
.ivirma-cyber-modal__pill-min {
  display: inline-block;
  flex-shrink: 0;
  margin-left: 8px;
  padding: 2px 8px;
  background: rgb(3, 26, 51);
  border-radius: 999px;
  font-size: 11px;
  font-weight: 600;
  color: #fff;
  white-space: nowrap;
}
.ivirma-cyber-modal__pill-arrow { color: #fff; font-size: 11px; flex-shrink: 0; }

.ivirma-cyber-modal__col-right {
  align-self: end;
}

.ivirma-cyber-modal__col-left h3{
  padding-bottom: 10px;
}

/* ── CTA pie ───────────────────────────────────────────────── */
.ivirma-cyber-modal__footer {
  padding: 20px 35px;
  border-top: 1px solid rgba(0,0,0,0.07);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  background: #012246;
  margin-top: 16px;
}
.ivirma-cyber-modal__footer-title {
  font-size: 16px;
  font-weight: 700;
  color: #fff;
  margin: 0 0 2px;
  display: block;
}
.ivirma-cyber-modal__footer-sub {
  font-size: 11px;
  color: #fff;
  margin: 0;
  display: block;
}
.ivirma-cyber-modal__cta {
  display: inline-block;
  background: #fff;
  color: #012246;
  font-size: 16px;
  font-weight: 600;
  padding: 8px 18px;
  border-radius: 999px;
  text-decoration: none;
  white-space: nowrap;
  flex-shrink: 0;
  transition: background 0.15s ease;
}
.ivirma-cyber-modal__cta:hover { background: #1a2f6a; text-decoration: none; color: #fff; }

@media (max-width: 600px) {
  .ivirma-cyber-modal__body { grid-template-columns: 1fr; }
  .ivirma-cyber-modal__footer { flex-direction: column; align-items: flex-start; }
}

body.ivirma-cyber-modal-open { overflow: hidden; }

/* ── Animación de entrada del modal ── */
@keyframes modalFadeIn {
  from {
    opacity: 0;
    transform: translateY(16px) scale(0.97);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes backdropFadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}

.ivirma-cyber-modal.is-open .ivirma-cyber-modal__dialog {
  animation: modalFadeIn 1s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.ivirma-cyber-modal.is-open .ivirma-cyber-modal__backdrop {
  animation: backdropFadeIn 0.5s ease both;
}

@keyframes modalFadeOut {
  from {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
  to {
    opacity: 0;
    transform: translateY(16px) scale(0.97);
  }
}

@keyframes backdropFadeOut {
  from { opacity: 1; }
  to   { opacity: 0; }
}

.ivirma-cyber-modal.is-closing .ivirma-cyber-modal__dialog {
  animation: modalFadeOut 1s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.ivirma-cyber-modal.is-closing .ivirma-cyber-modal__backdrop {
  animation: backdropFadeOut 0.5s ease both;
}


/* ── Blur suave en imagen de card ── */
.cyber-card__bg {
  filter: blur(2px);
  transform: scale(1.05);
}


/* ============================================================
   CTA-ONE-TECH
   ============================================================ */

/* ============================================================
   data-ai.css  ·  Bloque Data & AI (inst11275)
   Paleta principal: #17417B
   ============================================================ */

:root {
  --dai-primary:        #17417B;
  --dai-primary-hover:  #1F5499;
  --dai-primary-light:  #E8EEF7;
  --dai-primary-dark:   #0E2B53;

  --dai-text-secondary: #5C5F66;
  --dai-text-tertiary:  #8A8D94;
  --dai-border:         rgba(0, 0, 0, 0.08);

  --dai-radius-md: 10px;
  --dai-radius-lg: 20px;
}

/* ── Header del bloque Totara (inst11275 + inst11341) ─────── */
#inst11275 .block-header,
#inst11341 .block-header {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 0 1.25rem !important;
}

#instance-11275-header,
#instance-11341-header,
#inst11275 .block-title h2,
#inst11341 .block-title h2 {
  font-family: 'VAG Rounded Std', 'VAG Rounded', sans-serif;
  font-size: 30px !important;
  font-weight: 700 !important;
  color: #17417B !important;
  margin: 0 !important;
  padding: 0 !important;
  letter-spacing: 0.01em !important;
  background: transparent !important;
  border: none !important;
}

/* ===== CONTENEDOR ========================================= */

#inst11275 .content.block-content,
#inst11341 .content.block-content {
  padding: 0px;
  padding-bottom: 50px !important;
}

/* Anula el fondo blanco y la sombra que el tema aplica a
   div#region-main .block .content cuando esta vista
   contiene nuestro bloque Data & AI                            */
#region-main .block .content:has(.dai-wrap),
#region-main .block:has(.dai-wrap) > .content,
#region-main .block:has(.dai-wrap) {
  background: transparent !important;
  background-color: transparent !important;
  box-shadow: none !important;
  border: none !important;
}

.dai-section-title {
  font-size: 22px;
  font-weight: 500;
  color: var(--dai-primary);
  margin: 0 0 1.25rem;
  letter-spacing: -0.01em;
}

/* ===== SELECTORES (TABS) ================================== */
.dai-filters {
  display: flex;
  gap: 10px;
  margin-bottom: 1.5rem;
  flex-wrap: wrap;
  padding-bottom: 1.25rem;
}

.dai-filter-btn {
  position: relative;
  padding: 9px 22px;
  border-radius: 999px;
  border: 3px solid var(--dai-primary);
  background: transparent;
  color: var(--dai-primary);
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0.2px;
  cursor: pointer;
  outline: none;
  transition:
    background-color 0.18s ease,
    color 0.18s ease,
    border-color 0.18s ease,
    box-shadow 0.18s ease,
    transform 0.12s ease;
}

/* — Hover (estado no seleccionado) — */
.dai-filter-btn:hover:not(.active) {
  background: var(--dai-primary-light);
  color: var(--dai-primary-dark);
  border-color: var(--dai-primary);
  border: 3px solid var(--dai-primary);
}

/* — Focus accesible (teclado) — */
.dai-filter-btn:focus-visible {
  box-shadow: 0 0 0 3px rgba(23, 65, 123, 0.25);
}

/* — Click (no seleccionado) — */
.dai-filter-btn:active:not(.active) {
  transform: scale(0.97);
  border: 3px solid;
}

/* — Seleccionado — */
.dai-filter-btn.active {
  background: linear-gradient(135deg, var(--dai-primary) 0%, var(--dai-primary-dark) 100%);
  color: #fff;
  border: 3px solid var(--dai-primary-dark);;
}

.dai-filter-btn.active:hover {
  background: linear-gradient(135deg, var(--dai-primary-hover) 0%, var(--dai-primary) 100%);
  border: 3px solid var(--dai-primary);
}

/* ===== GRID DE CARDS ====================================== */
.dai-grid {
  display: grid;
  gap: 14px;
}

/* Riesgos y Normativa + Copilot → 3 columnas */
.dai-grid.cols-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

/* IVI RMA GenAI Portal → 2 columnas */
.dai-grid.cols-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

/* Reservado para configuraciones futuras → 4 columnas */
.dai-grid.cols-4 {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

/* Responsive: en pantallas pequeñas se colapsa a auto-fit */
@media (max-width: 720px) {
  .dai-grid.cols-2,
  .dai-grid.cols-3,
  .dai-grid.cols-4 {
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  }
}

.dai-card {
  background: #fff;
  border-radius: var(--dai-radius-lg);
  border: 0.5px solid var(--dai-border);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  cursor: pointer;
  min-height: 240px;
  transition:
    border-color 0.18s ease,
    transform 0.18s ease;
}

.dai-card:hover {
  border-color: var(--dai-primary);
  transform: translateY(-2px);
}

/* — Cabecera con color — */
.dai-card-img {
  height: 110px;
  position: relative;
  display: flex;
  align-items: flex-end;
  padding: 12px 14px;
}

.dai-card-img.b1 {
  background: linear-gradient(135deg, var(--dai-primary-dark) 0%, var(--dai-primary) 100%);
}
.dai-card-img.b2 {
  background: linear-gradient(135deg, var(--dai-primary) 0%, var(--dai-primary-hover) 100%);
}
.dai-card-img.b3 {
  background: linear-gradient(135deg, var(--dai-primary-hover) 0%, #2A6BB8 100%);
}

.dai-card-title-overlay {
  color: #fff;
  font-size: 14px;
  font-weight: 500;
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.35);
  line-height: 1.3;
}

/* — Cuerpo — */
.dai-card-body {
  padding: 12px 14px;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.dai-card-type {
  font-size: 10px;
  font-weight: 500;
  color: var(--dai-text-tertiary);
  letter-spacing: 0.5px;
  text-transform: uppercase;
}

.dai-card-name {
  font-size: 14px;
  font-weight: 500;
  color: var(--dai-primary);
  margin: 0;
  line-height: 1.3;
}

.dai-card-desc {
  font-size: 12px;
  color: var(--dai-text-secondary);
  line-height: 1.45;
  flex: 1;
  margin: 4px 0 0;
}

/* — Pie con metadata — */
.dai-card-meta {
  font-size: 10px;
  color: var(--dai-text-tertiary);
  padding: 10px 14px 12px;
  border-top: 0.5px solid var(--dai-border);
  margin-top: 8px;
}

/* ===== TAGS =============================================== */
.dai-pending-tag {
  display: inline-block;
  background: #FAEEDA;
  color: #854F0B;
  font-size: 10px;
  font-weight: 500;
  padding: 2px 8px;
  border-radius: 999px;
  margin-top: 4px;
}

.dai-eu-tag {
  display: inline-block;
  background: var(--dai-primary-light);
  color: var(--dai-primary-dark);
  font-size: 10px;
  font-weight: 500;
  padding: 2px 8px;
  border-radius: 4px;
  margin-top: 4px;
  margin-right: 4px;
  letter-spacing: 0.3px;
}

/* ===== ACCESIBILIDAD ====================================== */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}


/* ── CTA Catalog & OneTech — contenedor ── */

/* Fix sticky sidebar:
   Bootstrap 3 usa floats, por lo que #block-region-side-post solo
   tiene la altura de su contenido y sticky no puede moverse.
   Convertimos la fila en flex para que la columna lateral se estire
   hasta igualar la altura del contenido principal. */
div:has(> #region-main) {
  display: flex !important;
}
div:has(> #region-main) > #region-main,
div:has(> #region-main) > #block-region-side-post {
  float: none !important;
}
#block-region-side-post {
  overflow: visible !important;
}

#inst9796 {
  position: sticky !important;
  top: 0px;
}

#inst9796.cta-onetech .content.block-content {
  position: relative !important;
  overflow: hidden !important;
  position: sticky;
}

#inst9796.cta-onetech .content.block-content::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background-image: url("https://ivirmacampus.com/pluginfile.php/1/local_uploadfiles/additionalimages/0/one-tech-sidebar-bg.png") !important;
  background-position: center !important;
  background-size: cover !important;
  filter: blur(8px) !important;
  transform: scale(1.05) !important; /* evita los bordes blancos que deja el blur */
  z-index: 0 !important;
}

#inst9796.cta-onetech .content.block-content .no-overflow {
  position: relative !important;
  z-index: 1 !important; /* el contenido queda por encima del blur */
  min-height: 82vh !important; 
  justify-content: center !important;
  align-items: center !important;
}

/* ── no-overflow: base compartida ── */
.cta-catalog .content.block-content .no-overflow,
.cta-onetech .content.block-content .no-overflow {
  display: flex !important;
  font-size: 16px !important;
  padding: 1em !important;
}

/* ── no-overflow: catalog → fila, onetech → columna centrada ── */
.cta-catalog .content.block-content .no-overflow {
  flex-direction: row !important;
  justify-content: space-between !important;
  align-items: flex-end !important;
}

.cta-onetech .content.block-content .no-overflow {
  flex-direction: column !important;
  justify-content: center !important;
  align-items: center !important;
}

/* ── Título ── */
.cta-catalog .content.block-content h2.title,
.cta-onetech .content.block-content h2.title {
  color: #fff !important;
  margin: 0 0 12px !important;
}

/* ── Botón derecha (catalog) ── */
.cta-catalog .content.block-content .btn-dcha a,
.cta-onetech .content.block-content .btn-dcha a {
  display: inline-block !important;
  border: 1px solid #fff !important;
  padding: var(--spacing-small, 8px) 25px !important;
  border-radius: 25px !important;
  background-color: #fff !important;
  color: #2d6874 !important;
  font-weight: 500 !important;
  text-decoration: none !important;
  transition: background-color 0.25s ease, color 0.25s ease !important;
}

.cta-catalog .content.block-content .btn-dcha a:hover,
.cta-onetech .content.block-content .btn-dcha a:hover {
  background-color: rgba(255,255,255,0.12) !important;
  color: #fff !important;
  text-decoration: none !important;
}

/* ── Botón OneTech ── */
.cta-onetech .onetech-btn {
  display: inline-block;
  background: #fff !important;
  margin-top: 20px !important;
  padding: 15px 30px !important;
  border-radius: 32px !important;
  color: #223C84 !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  transition: background-color 0.25s ease, color 0.25s ease, transform 0.2s ease !important;
}

.cta-onetech .onetech-btn:hover {
  background: rgba(255,255,255,0.15) !important;
  color: #fff !important;
  transform: scale(1.03) !important;
  text-decoration: none !important;
}

/* ============================================================
   COPILOT CYBER CARDS
   Grid #dai-grid-cyber para la pestaña Copilot dentro del
   bloque Data & AI (inst11275). Usa las mismas clases .cyber-card
   que ya están definidas arriba.
   ============================================================ */

/* ── Grid <ul> cyber dentro del bloque DAI (inst11275 + inst11341) ── */
#dai-grid-cyber,
#dai-grid-cyber-aud {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 18px;
  align-items: stretch;
}

#dai-grid-cyber.cols-2,
#dai-grid-cyber-aud.cols-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

#dai-grid-cyber.cols-3,
#dai-grid-cyber-aud.cols-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

@media (max-width: 900px) {
  #dai-grid-cyber.cols-2,
  #dai-grid-cyber.cols-3,
  #dai-grid-cyber-aud.cols-2,
  #dai-grid-cyber-aud.cols-3 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 600px) {
  #dai-grid-cyber.cols-2,
  #dai-grid-cyber.cols-3,
  #dai-grid-cyber-aud.cols-2,
  #dai-grid-cyber-aud.cols-3 {
    grid-template-columns: 1fr;
  }
}

#dai-grid-cyber > li,
#dai-grid-cyber-aud > li {
  display: flex;
  flex-direction: column;
}

/* ── Imagen más alta en 2 columnas ─────────────────────────── */
#dai-grid-cyber.cols-2 .cyber-card__image,
#dai-grid-cyber-aud.cols-2 .cyber-card__image {
  height: 160px;
}

/* ── Título overlay más grande con 2 columnas ──────────────── */
#dai-grid-cyber.cols-2 .cyber-card__overlay-title,
#dai-grid-cyber-aud.cols-2 .cyber-card__overlay-title {
  font-size: 21px;
}

/* Descripción: no forzamos display para que --clamp use -webkit-box */
#dai-grid-cyber .cyber-card__desc,
#dai-grid-cyber-aud .cyber-card__desc {
  -webkit-line-clamp: unset;
  line-clamp: unset;
}

/* ── Sin imagen: fondo degradado azul Copilot ──────────────── */
#dai-grid-cyber .cyber-card__bg:not([style]),
#dai-grid-cyber-aud .cyber-card__bg:not([style]) {
  background: linear-gradient(135deg, #0E2B53 0%, #1F5499 60%, #2A6BB8 100%);
  filter: none;
  transform: none;
}

/* Con imagen: mantiene el blur */
#dai-grid-cyber .cyber-card__bg[style],
#dai-grid-cyber-aud .cyber-card__bg[style] {
  filter: blur(2px);
  transform: scale(1.05);
}

/* ── Descripción: máximo 4 líneas con "…" ──────────────────── */
.cyber-card__desc--clamp {
  display: -webkit-box !important;
  -webkit-box-orient: vertical !important;
  -webkit-line-clamp: 4;
  line-clamp: 4;
  overflow: hidden !important;
  text-overflow: ellipsis;
  flex: none !important;
  max-height: calc(1.5em * 4);
}

/* ── Altura uniforme: .cyber-card ocupa todo el alto del li ── */
#dai-grid-cyber > li,
#dai-grid-cyber-aud > li {
  display: flex;
}

#dai-grid-cyber .cyber-card,
#dai-grid-cyber-aud .cyber-card {
  display: flex;
  flex-direction: column;
  flex: 1;
  height: 100%;
}

#dai-grid-cyber .cyber-card__body,
#dai-grid-cyber-aud .cyber-card__body {
  flex: 1;
  display: flex;
  flex-direction: column;
}

#dai-grid-cyber .cyber-card__footer,
#dai-grid-cyber-aud .cyber-card__footer {
  margin-top: auto;
}

/* ── Cards pendientes (b1 / b3): cursor normal, sin hover ──── */
/* Las cards con pending:true usan is-disabled pero queremos
   que el cursor sea default, no not-allowed               */
.cyber-card.is-disabled {
  cursor: default;
}

/* ── Loader "Cargando cursos disponibles…" ─────────────────── */
.dai-copilot-loader {
  display: none; /* se activa por JS */
  align-items: center;
  gap: 10px;
  padding: 18px 22px;
  color: #17417B;
  font-size: 15px;
  font-weight: 500;
}

.dai-copilot-loader__spinner {
  display: inline-block;
  width: 18px;
  height: 18px;
  border: 2px solid rgba(23, 65, 123, 0.2);
  border-top-color: #17417B;
  border-radius: 50%;
  animation: dai-spin 0.7s linear infinite;
  flex-shrink: 0;
}

@keyframes dai-spin {
  to { transform: rotate(360deg); }
}

/* ── Aviso de sección sin cursos disponibles ───────────────── */
.dai-empty-notice {
  list-style: none;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 18px 22px;
  background: #F0F4FA;
  border: 1px solid #D0DCEE;
  border-radius: 12px;
  color: #17417B;
  font-size: 15px;
  font-weight: 500;
  line-height: 1.4;
}

.dai-empty-notice__icon {
  font-size: 20px;
  color: #17417B;
  flex-shrink: 0;
  opacity: 0.7;
}

                @font-face {
                    font-family: "Gotham";
                    src: url("https://ivirmacampus.com/theme/actua/webfont.php?nomfont=Gotham-Bold.woff") format("woff");
                    font-weight: bold;
                    font-style: normal;
                }
                @font-face {
                    font-family: "Gotham";
                    src: url("https://ivirmacampus.com/theme/actua/webfont.php?nomfont=Gotham-Book.woff") format("woff");
                    font-weight: normal;
                    font-style: normal;
                }
                @font-face {
                    font-family: "Gotham";
                    src: url("https://ivirmacampus.com/theme/actua/webfont.php?nomfont=Gotham-Medium.woff") format("woff");
                    font-weight: 500;
                    font-style: normal;
                }
            body {
                font-family: Gotham;
            }
        