@charset "UTF-8";

@font-face {
    font-family: "Open Sans";
    font-style: normal;
    font-weight: 400;
    src: local("Open Sans"), local("OpenSans"),
        url(fonts/open-sans.woff2) format("woff2"),
        url(fonts/open-sans.woff) format("woff");
}

@font-face {
    font-family: "Open Sans";
    font-style: normal;
    font-weight: 700;
    src: local("Open Sans Bold"), local("OpenSans-Bold"),
        url(fonts/open-sans-bold.woff2) format("woff2"),
        url(fonts/open-sans-bold.woff) format("woff");
}

@font-face {
    font-family: "Escolar 8";
    font-style: normal;
    font-weight: 400;
    src: url(fonts/escolar8.woff) format("woff");
}

body.infantil {
    font-family: "Escolar 8", "Open Sans", "Helvetica Neue", Helvetica, Arial, sans-serif !important;
}

body.infantil h1,
body.infantil h2,
body.infantil h3,
body.infantil h4,
body.infantil h5,
body.infantil h6,
body.infantil #siteNav a,
body.infantil .exe-content,
body.infantil .box-content,
body.infantil .iDevice_content,
body.infantil input,
body.infantil button,
body.infantil select,
body.infantil textarea,
body.infantil .fx-accordion-title,
body.infantil .exe-dl dt,
body.infantil .exe-dl dd {
    font-family: "Escolar 8", "Open Sans", "Helvetica Neue", Helvetica, Arial, sans-serif !important;
}

.page>header .package-title,
.siteNav-off .page>header .package-title,
.exe-single-page .package-header h1 {
    width: calc(100% - 470px);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/*.exe-teacher-mode-toggler .page>header .package-title,
.exe-teacher-mode-toggler.siteNav-off .page>header .package-title {
    width: calc(100% - 550px);
}*/



.exe-web-site main.page {
    box-sizing: border-box;
    width: 100%;
    padding-left: 300px;
    padding-bottom: 40px;
}

.exe-scorm .page>header .package-title,
.exe-scorm .siteNav-off .page>header .package-title,
.exe-ims .page>header .package-title,
.exe-ims .siteNav-off .page>header .package-title,
.exe-epub .page>header .package-title,
.exe-epub .siteNav-off .page>header .package-title,
.exe-ims .page>header .package-title {
    /*width: 100%;*/
    display: none;
}

.exe-single-page .package-header h1 {
    width: 100%;
}

.package-subtitle {
    width: 100%;
    position: absolute;
    left: 32px;
    bottom: -.2em;
    font-size: .9em;
    color: #777;
}

.exe-web-site .package-subtitle {
    max-width: 70%;
    white-space: nowrap;
    text-overflow: ellipsis;
    overflow: hidden;
}

@media (max-width: 750px) {
    .package-subtitle {
        font-size: 1em;
    }
}

body:has(.package-subtitle) .package-title,
body.exe-single-page:has(.package-subtitle) .package-node h1 {
    position: relative;
    top: -.33em;
}

.page>header {
    position: fixed;
    top: 0;
    right: 0;
    left: 0;
    z-index: 400;
    height: 50px;
    display: flex !important;
    align-items: center;
    background-color: #fff;
    /* background:#fff url(img/logo.png) no-repeat 32px 15px/ 132px; */
    border-bottom: 1px solid #e0e0e0;
}

.page-title {
    font-weight: bold;
}

.exe-single-page .page-title {
    margin-top: 20px;
}

.page>header .package-title {
    padding-left: 32px;
    color: #9c2a2a;
    margin: 0;
    border-bottom: 2px solid #9c2a2a;
    /*padding-bottom: 15px;*/
    width: 95%;
}

body.exe-export {
    padding: 1em 0;
}

body.exe-web-site {
    padding: 0;
}

.exe-web-site .package-header {
    width: 100%;
}

body.exe-scorm .package-title,
body.exe-ims .package-title,
body.exe-epub .package-title {
    position: absolute;
    top: 20px;
    left: 0;
    font-weight: normal;
    font-size: .95em;
    color: #777;
}

body.exe-scorm:has(.package-subtitle) .page-title,
body.exe-ims:has(.package-subtitle) .page-title,
body.exe-epub:has(.package-subtitle) .page-title {
    margin-top: 30px;
}

body.exe-scorm .page-counter,
body.exe-ims .page-counter,
body.exe-epub .page-counter {
    position: absolute;
    top: 12px;
    right: 60px;
}

body.exe-scorm #teacher-mode-toggler-wrapper,
body.exe-ims #teacher-mode-toggler-wrapper,
body.exe-epub #teacher-mode-toggler-wrapper {
    position: absolute;
    top: 30px;
    right: 20px;
}

body.exe-scorm .package-subtitle,
body.exe-ims .package-subtitle,
body.exe-epub .package-subtitle {
    position: absolute;
    clip: rect(1px 1px 1px 1px);
    /* IE6, IE7 */
    clip: rect(1px, 1px, 1px, 1px);
}

body.exe-scorm .page-title,
body.exe-ims .page-title,
body.exe-epub .page-title {
    padding: 0 32px;
}

/*UDL content*/
.exe-content .exe-udlContent .udl-btn {
    background-color: #9c2a2a !important;
}

.exe-content .exe-udlContent .udl-btn:hover {
    background-color: #cc1717 !important;
}

.exe-udlContent-alt-content-title h2 {
    color: #9c2a2a !important;
}

#node-content-container.exe-content .hidden-idevices .box-head {
    border-bottom-width: 1px !important;
}



@media (max-width: 750px) {

    body.exe-scorm .page-title,
    body.exe-ims .page-title,
    body.exe-epub .page-title {
        padding: 0 24px;
    }

    body.exe-scorm .page>header .package-title,
    body.exe-ims .page>header .package-title,
    body.exe-epub .page>header .package-title {
        padding-left: 24px;
    }
}

.exe-content a {
    color: #9c2a2a;
}

.exe-content a:hover,
.exe-content a:focus {
    color: #cc1717;
    text-decoration: none;
}

/* Effects */

.exe-accordion .fx-accordion-title,
.fx-pagination .fx-current a {
    background-color: #f4f4f4;
    border-color: #9c2a2a !important;
    border-style: solid !important;
    border-width: 1px !important;
}

.exe-accordion .fx-accordion-title {
    margin-top: -1px;
}

.exe-accordion .fx-accordion-title:first-child {
    margin-top: 0;
}


.js .exe-accordion h2 {
    color: #9c2a2a;
}

.exe-fx a {
    color: #9c2a2a;
}

.exe-fx a:hover,
.exe-fx a:focus {
    color: #cc1717;
}

.fx-pagination .fx-current a {
    color: #5a7f0c;
}

.exe-tabs .fx-tab-content {
    display: none;
    background: #fff;
    padding: 15px;
    border-radius: 5px;
    border-style: solid;
    border-color: #9c2a2a;
    border-width: thin;
    border-top-left-radius: 0px;
    border-top-width: 2px;
}

.fx-accordion-content {
    padding: 0 15px;
    display: none;
    border-style: solid;
    border-color: #9c2a2a;
    border-width: thin;
    margin-top: 0px;
}

.fx-tabs .fx-current a {
    background: #9c2a2a;
    border-top-left-radius: 5px;
    border-top-right-radius: 5px;
    color: #fff;
    border-radius: 0px;
    border-color: #9c2a2a;
}

/*.exe-fx .fx-current a:hover,
.exe-fx .fx-current a:focus {
    color: #fff;
}*/

.exe-fx .fx-current dt a:hover,
.exe-fx .fx-current dt a:focus {
    color: #cc1717;
}

.exe-tabs .fx-tabs a {
    display: block;
    padding: 10px 15px;
    outline: none;
    float: left;
    text-decoration: none;
    border-width: 1px;
    border-style: solid;
    margin-right: -1px;
}

/* definition list */
.exe-dl .icon {
    background: #9c2a2a !important;
}

.exe-download-package-link a {
    background: #9c2a2a;
    color: #fff;
}

.exe-download-package-link a:hover {
    background-color: #cc1717;
    color: #fff;
    text-decoration: none;
}

#node-content-container.exe-content #node-content {
    padding-top: 20px;
    padding-bottom: 20px;
    max-width: 1280px;
    margin: 0 auto;
    display: block;
}

body.exe-export,
.exe-content {
    font-family: "Open Sans";
    color: #333;
    background-color: #f4f4f424;
}

.js .exe-export .exe-content {
    min-height: calc(100vh - 30px);
}

.js .in-iframe .exe-content {
    min-height: 0;
}

.sr-av {
    display: none;
}

.exe-content .package-title {
    color: #333333;
    font-size: 1.7rem;
    text-align: left;
    font-weight: 700;
}

.exe-content .package-title,
.exe-single-page .package-header h1 {
    font-size: 1.7rem;
    text-align: left;
    font-weight: 700;
    color: #9c2a2a;
}

.exe-single-page .package-header>h1 {
    padding-left: 32px !important;
}

.exe-single-page .package-node {
    margin-bottom: 3.5em;
}

.exe-content .box {
    margin: 32px 0;
    border: none;
}

.exe-content .box-head {
    border-bottom: 0;
}

#node-content-container.exe-content .box {
    border: 2px solid #9c2a2a;
    background-color: #F6F9F5;
    border-radius: 12px;
    box-shadow: 0px 18px 16px -6px rgba(0, 0, 0, 0.37);
    margin-bottom: 30px;
}

#node-content-container.exe-content .box.hidden-idevices {
    border-style: solid;
}

.exe-content .box header {
    min-height: 40px;
    border-bottom: none;
    background-color: #f3f3f3;
    border-radius: 10px 10px 10px 10px;
    padding: 15px 0 15px 25px;
    position: relative;
    display: flex;
    align-items: center;
    border-style: solid;
    border-width: thin;
    border-color: #9c2a2a;
}

/*#node-content-container.exe-content article:hover header.box-head.idevice-element-in-content *,
#node-content-container.exe-content article:hover header.udlContentFormBlockHeader * {
    filter: brightness(0) invert(1);
}*/

.exe-content .box-head .box-title {
    color: #9c2a2a;
    font-size: 1.75rem !important;
    font-weight: 700;
    line-height: 1.2;
    margin: 0;
}

#node-content-container.exe-content .box-head .content-editable-title .box-title[contenteditable=true] {
    background: #fff;
    color: #000 !important;
}

.exe-content .box:hover {
    box-shadow: 2px 18px 18px -10px rgba(19, 41, 0, 0.664);
}

.exe-content .box:hover header:not(.exe-udlContent-alt-content-title) {
    background-color: #9c2a2a;
    color: #ffffff !important;
}

.exe-content .box:hover .box-title {
    color: #ffffff !important;
}

.exe-content .box-head .exe-icon {
    float: left;
}

.exe-web-site .page-content,
.exe-web-site .page-counter,
#exe-client-search,
.exe-web-site #siteFooterContent,
.exe-export .exe-content {
    max-width: 1280px;
    padding: 0 90px;
    margin: 0 auto 0 auto;
}

.exe-web-site main>header {
    width: 100%;
    max-width: none;
    padding: 0;
    margin: 0;
}

.exe-web-site main>header .package-header {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 170px;
}

.exe-web-site .page-content {
    margin: 30px auto 0 auto;
}

.exe-web-site .exe-content {
    max-width: none;
    padding: 0;
}

body.exe-export.exe-scorm {
    padding: 0;
}

.exe-export main {
    padding-top: 1.5em;
}

.exe-scorm .exe-export main {
    padding-top: 5em;
    padding-bottom: 1em;
}

.exe-web-site main {
    padding-top: 90px;
}

.exe-content.cover-on .exe-interactive-video,
.exe-content .exe-interactive-video {
    width: 100%;
}



body.exe-export.exe-scorm .exe-content,
body.exe-export.exe-ims .exe-content,
body.exe-export.exe-epub .exe-content {
    padding: 0 40px;
}

/* siteNav */
#siteNav {
    float: left;
    width: 279px;
    padding-top: 60px;
    padding-left: 0;
    margin: 0 0 70px 0;
    border-right: none;
    background-color: transparent;
    height: 100vh;
    z-index: 1;
    overflow: auto;
    scrollbar-width: none;
    transition: left 0.3s ease;
    left: 0;
    top: 50px;
    overflow: visible;
}

#siteNav::-webkit-scrollbar {
    display: none;
}

#siteNav>ul {
    max-height: calc(100vh - 230px);
    overflow-y: auto;
    margin: 0;
    padding: 20px;
    background-color: #ffffff;
    border: 1px solid #d1d1d1;
    border-left: none;
    box-shadow: 0px 4px 10px rgba(0, 0, 0, 0.1);
    border-radius: 0 8px 8px 0;
}

#siteNav>ul::-webkit-scrollbar {
    display: none;
}

#siteNav .other-section {
    display: none;
}

#sidebar-nav.fixed,
#sidebar-nav {
    position: fixed;
}

body.siteNav-off #siteNav {
    display: none;
}

.exe-web-site #siteFooter {
    padding-left: 320px;
    padding-right: 20px;
    transition: padding 0.3s ease;
}

.exe-web-site main.page {
    box-sizing: border-box;
    width: 100%;
    padding-left: 300px;
    padding-bottom: 40px;
    transition: padding 0.3s ease;
}

body.siteNav-off main.page,
body.siteNav-off #siteFooter {
    padding-left: 0;
}

#siteNav ul,
#siteNav li {
    margin: 0;
    padding: 0;
    list-style: none;
}

#siteNav li {
    margin-bottom: 0px;
}

#siteNav a {
    font-size: .95em;
    display: block;
    padding: 7px 10px 7px 39px;
    border-bottom: 1px solid #d1d1d1;
    color: #9c2a2a;
    background: #f4f4f4;
    font-weight: bold;
    text-decoration: none;
    border-radius: 0;
    max-width: none;
    margin-bottom: 0;
}

#siteNav a:hover,
#siteNav a:focus {
    /*color: #cc1717;*/
    background: #e0e0e0;
    border-color: #d1d1d1;
}

#siteNav a.active {
    color: #fff;
    background-color: #9c2a2a !important;
    border-color: #d1d1d1;
    font-weight: bold;
    margin-bottom: 0;
}

/*   El destacado 
#siteNav a.highlighted-link:hover,
#siteNav a.highlighted-link.daddy:hover,
#siteNav .current-page-parent>a.highlighted-link:hover,
#siteNav .current-page-parent>a.highlighted-link.daddy:hover {
    color: #9c2a2a;
    
    
    background: #e0e0e0 url(img/arrow_down.svg) no-repeat right 16px center / 22px;
    padding-left: 42px;
}   

#siteNav a.highlighted-link,
#siteNav a.highlighted-link.daddy,
#siteNav .current-page-parent>a.highlighted-link,
#siteNav .current-page-parent>a.highlighted-link.daddy {
    color: #9c2a2a;
    
    background: #f4f4f4 url(img/book_color.svg) no-repeat 8px center !important;
    padding-left: 42px;
}

#siteNav a.highlighted-link.active {
    background: #9c2a2a url(img/book_color.svg) no-repeat 8px center !important;
    color: #fff !important;
}
*/


#siteNav ul ul a {
    padding-left: 50px;
    font-size: .9em;
    background: #fff;
    border-color: #d1d1d1a1;
    color: #9c2a2a;
}

#siteNav ul ul a:hover,
#siteNav ul ul a:focus {
    /*background: #f9f9f9;*/
    border-color: #d1d1d1;
    /*color: #cc1717;*/
    /*text-decoration: underline;*/
}



.current-page-parent a {
    background-color: #e0e0e0;
    margin-bottom: 4px;
}

#siteNav ul ul ul a {
    padding-left: 65px;
    background-color: #ffffff;
    color: #9c2a2a;
}

#siteNav ul ul ul ul a {
    padding-left: 90px;
}

.daddy {
    background: #f4f4f4 url(img/arrow_down.svg) no-repeat right 16px center / 22px !important;
    padding-right: 45px !important;
}

.active .active.daddy {
    background: #9c2a2a url(img/arrow.svg) no-repeat right 16px center / 22px !important;
    padding-right: 45px;
}

.active .daddy {
    background: #f4f4f4 url(img/arrow_down.svg) no-repeat right 16px center / 22px !important;
    padding-right: 45px;
}

#siteNav .current-page-parent>.daddy {
    background: #f4f4f4 url(img/arrow_red.svg) no-repeat right 16px center / 22px !important;
    padding-right: 45px;
}

#siteNav .current-page-parent>.daddy:hover {
    background: #d1d1d1 url(img/arrow_red.svg) no-repeat right 16px center / 22px !important;
    padding-right: 45px;
}


.current-page-parent .daddy {
    background: #f4f4f4 url(img/arrow_down.svg) no-repeat right 16px center / 22px !important;
    padding-right: 45px;
}

.daddy:hover {
    background: #e0e0e0 url(img/arrow_down.svg) no-repeat right 16px center / 22px !important;
    padding-right: 45px;
}

.active.daddy:hover {
    /*background: #e0e0e0 url(img/arrow_red.svg) no-repeat right 16px center / 22px !important;*/
    padding-right: 45px;
}

/* Acordeón para el menú activo */
#siteNav li.active.nav-collapsed>ul,
#siteNav li.active.nav-collapsed>.other-section {
    display: none !important;
}

#siteNav li.active.nav-collapsed>a.daddy {
    background: #9c2a2a url(img/arrow_down_white.svg) no-repeat right 16px center / 22px !important;
    color: #ffffff !important;
}

#siteNav li.active.nav-collapsed>a {
    color: #ffffff !important;
}

/* pagination */
.school-logo {
    position: fixed;
    top: 5px;
    /*right: 220px;*/
    z-index: 998;
    width: 120px;
    height: 40px;
    background: url(img/logo_school.png) no-repeat center / contain;
    left: 50px;
}

.nav-buttons .nav-button,
button.toggler {
    position: fixed;
    top: 5px;
    right: 10px;
    display: inline-block;
    width: 40px;
    height: 40px;
    background-image: url(img/arrow_back.svg);
    background-size: 24px;
    background-color: #9c2a2a;
    background-repeat: no-repeat;
    border-radius: 50%;
    z-index: 999;
    border: 0;
    transition: background-color 0.5s ease;
    padding: 0;
    color: transparent;
    font-weight: 600;
    overflow: hidden;
}

.nav-buttons span.nav-button {
    opacity: 0.5;
    filter: grayscale(1);
    cursor: not-allowed;
}

.nav-buttons .nav-button-left {
    background-position: center;
    right: 80px;
}

.nav-buttons .nav-button-right {
    background-position: center;
    background-image: url(img/arrow_forward.svg);
    right: 20px;
}

button#siteNavToggler {
    left: 15px;
    top: 5px;
    background: transparent url(img/menu_open.svg) no-repeat left center / 24px;
    width: auto;
    height: 40px;
    border-radius: 4px;
    box-sizing: content-box;
    padding: 0 0 0 30px;
    border: none;
    color: #9c2a2a;
    font-weight: bold;
    text-decoration: underline;
    z-index: 1001;
    max-width: 20px;
}

/*#siteNavToggler:hover {
    background-color: #f4f4f4;
}*/

button#siteNavToggler span {
    display: inline-block;
}

.siteNav-off button#siteNavToggler span {
    display: inline;
}

body.siteNav-off button#siteNavToggler {
    /*left: 0;
    top: 60px;*/
    padding: 0px 0px 0px 25px;
    /* width: 100px !important; */
    border-radius: 10px 10px 10px 10px;
    background: #9c2a2a url(img/menu_closed.svg) no-repeat 7px / 32px;
    left: 6px;
}

body.siteNav-off button#siteNavToggler:hover {
    background: #ffffff url(img/menu_closed_hover.svg) no-repeat 7px / 32px;
}

#siteNavToggler .sr-av {
    visibility: visible;
    position: static;
    padding-left: 24px;
    color: #fff;
    font-size: 1rem;
    font-weight: 600;
}

body.siteNav-off button#siteNavToggler:hover .sr-av {
    color: #9c2a2a;
}

.nav-buttons a:hover,
.nav-buttons a:focus,
button.toggler:hover,
button.toggler:focus {
    background-color: #cc1717;
    border-color: #cc1717;
    color: transparent;
    text-decoration: none;
}

#exe-client-search-reset span,
#packageLicense .license-label {
    position: absolute;
    clip: rect(1px 1px 1px 1px);
    clip: rect(1px, 1px, 1px, 1px);
}

.box-toggle span {
    display: none;
}

/* Box toggler */
.box {
    background-color: #ffffff;
    border: 1px solid #eaecf0;
    border-radius: 12px;
    padding: 0;
    margin-bottom: 32px;
}

.exe-export .box {
    position: relative;
}

.exe-export .box-toggle {
    width: 40px;
    height: 40px;
    background: url(img/arrow_red.svg);
    background-size: auto 40px;
    border-radius: 50%;
    border: 0;
    position: absolute;
    top: 50%;
    margin-top: -20px;
    right: 20px;
    background-color: #f3f3f3;
    transition: transform 0.2s ease-in-out;
}

.exe-export .box-head:hover .box-toggle,
.exe-export .box-toggle:focus {
    opacity: 1;
}

.exe-export .minimized .box-toggle {
    transform: rotate(180deg);
}

#node-content-container.exe-content .box-head .exe-icon {
    width: 60px;
    height: 60px;
    font-size: 40px;
}

#node-content-container.exe-content .box-head .exe-icon img {
    height: 40px;
}

.exe-export .box-icon img {
    display: block;
    float: left;
    margin-right: 10px;
}

.exe-export .box-icon img {
    width: 40px;
    height: auto;
}

.exe-export .box-title {
    padding-top: 5px;
}

/*.exe-export .box.minimized .box-head {
    border-bottom: 1px solid #ddd;
}*/

.exe-export .box.no-header.minimized .box-head {
    border-color: #fff;
}

.exe-export .box .box-content {
    padding: 2.25rem;
}

.exe-export .box.no-header .box-content {
    background: none;
    border: none;
    padding: 20px 0;
}

/* Licenses */
#packageLicense {
    text-align: left;
    font-size: 0.9em;
    color: #555;
    line-height: 1em;
    margin: 2.5em auto 2em auto;
    border: 1px solid transparent;
    border-radius: 2px;
    width: fit-content;
    max-width: 100%;
}

#packageLicense p {
    margin: 0;
}

#packageLicense a {
    color: #666;
    text-transform: capitalize;
    display: inline-block;
    white-space: nowrap;
    text-overflow: ellipsis;
    max-width: 100%;
    overflow: hidden;
    line-height: 15px;
}

#packageLicense a:hover,
#packageLicense a:focus {
    text-decoration: none;
    color: #b04721;
}

#packageLicense.propietary {
    position: absolute;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    height: 0;
}

#packageLicense.cc {
    padding: 0 20px 0 90px;
    background: url(img/licenses.gif) no-repeat 0 0;
}

#packageLicense.cc-by-sa {
    background-position: 0 -100px;
}

#packageLicensea.cc-by-nd {
    background-position: 0 -200px;
}

#packageLicense.cc-by-nc {
    background-position: 0 -300px;
}

#packageLicense.cc-by-nc-sa {
    background-position: 0 -400px;
}

#packageLicense.cc-by-nc-nd {
    background-position: 0 -500px;
}

#packageLicense.cc-0 {
    background-position: 0 -600px;
}

/* Page footer */
#siteUserFooter {
    margin-bottom: 20px;
}

/* iDevice buttons */
.exe-content .iDevice_buttons input,
.exe-content .iDevice_buttons button {
    background: #fff;
    color: #555;
    border: 1px solid #ccc;
    padding: 4px 10px;
    border-radius: 4px;
    transition: 0.5s ease;
}

.exe-content .iDevice_buttons input:hover,
.exe-content .iDevice_buttons input:focus,
.exe-content .iDevice_buttons button:hover,
.exe-content .iDevice_buttons button:focus {
    box-shadow: 2px 2px 4px #dbdbdb;
    color: #000;
    border-color: #bbb;
}

/* Page counter */
.page-counter {
    text-align: right;
    margin: 0 0 0.5em 0;
    font-size: 0.9em;
    color: #9c2a2a;
    font-weight: bold;
    background: #fff;
}

.exe-web-site .page-counter {
    margin: 0 auto;
    font-size: 0.9em;
    color: #777;
    text-align: right;
    background-color: #f7f7f7;
}

/* Search bar */
body.siteNav-off.exe-search-on button#searchBarTogger,
body.exe-search-on button#searchBarTogger {
    display: inline-block;
}

#exe-client-search-form p {
    margin-top: 2em;
}

#exe-client-search-form p {
    display: flex;
    width: 100%;
    flex-direction: row;
    flex-wrap: nowrap;
    gap: 6px;
}

button#searchBarTogger {
    position: absolute;
    right: 50px;
    top: -1px;
    margin: 0;
    background: #9f2a2a url(img/icons.png) no-repeat -42px -3px;
    background-size: auto 40px;
    width: 35px;
    height: 35px;
    padding: 0;
    display: none;
    z-index: 1000;
    border-radius: 5px;
}

button#searchBarTogger:hover,
button#searchBarTogger:focus {
    background-color: #cc1717;
}

body.siteNav-off button#searchBarTogger {
    display: none;
    padding-left: 0;
}

#exe-client-search {
    display: none;
    margin-bottom: 30px;
}

#exe-client-search-text {
    flex: 1 1 auto;
    min-width: 0;
    display: inline;
}

#exe-client-search-submit {
    text-indent: -999em;
    background: #9f2a2a url(img/icons.png) no-repeat -41px -1px;
    background-size: auto 40px;
    width: 38px;
    height: 38px;
    border: none;
    border-radius: 4px;
}

#exe-client-search-reset.visible {
    background: url(img/icons.png) no-repeat -242px -1px;
    background-size: auto 40px;
    width: 38px;
    height: 38px;
    display: inline-block;
    vertical-align: middle;
    opacity: 0.6;
    border-radius: 4px;
}

#exe-client-search-reset:hover,
#exe-client-search-reset:focus {
    opacity: 1;
}

#exe-client-search-submit:hover,
#exe-client-search-submit:focus {
    background-color: #cc1717;
}

#exe-client-search-results-list ul,
#exe-client-search-results-list li {
    margin: 2em 0;
    padding: 0;
    list-style: none;
}

#exe-client-search-results-list li {
    margin: 0 0 1em 0;
}

#exe-client-search-results-list p {
    margin-top: 2em;
}


/* Accessibility Tools */
#eXeAtools {
    display: block;
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 90px;
    /* Aligned with page content */
    position: relative !important;
    z-index: 1000;
}

.exe-scorm #eXeAtools,
.exe-scorm12 #eXeAtools {
    top: -105px !important;
}

.exe-single-page #eXeAtools {
    top: -115px !important;
}

@media (max-width: 1024px) {
    #eXeAtools {
        right: 20px;
        /* Aligned with the compressed Next button on smaller screens */
    }
}

#eXeAtoolsBtn {
    background: transparent url(img/icons.png) no-repeat -10px -1350px;
    width: 40px;
    height: 40px;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    text-indent: -9999px;
    box-shadow: none;
    /* Cleaner look above title */
    display: block;
}

/* Adjustments when inside page-content */
.page-content #eXeAtools {
    padding-left: 0;
    /* Since it's inside .page-content which already has padding */
    padding-right: 0;
    margin-bottom: 10px;
}


/* Force wrapper to stay inside the relative container */
#eXeAtoolsBtnSet {
    display: block;
    position: absolute !important;
    right: 0;
    top: 0;
    /* Match the padding of parent if needed, or 0 if parent has padding */
    bottom: auto !important;
    margin: 0 !important;
    /* Reset any specific transforms */
    transform: none !important;
    left: auto !important;
}

/* Responsive left alignment handled by container padding, so absolute left is always 0 relative to container */



#eXeAtoolsBtn:hover,
#eXeAtoolsBtn:focus {
    background-color: transparent;
    /* No background color change on hover if using sprite change */
}

/* Specific override for the main toggle button */
#eXeAtoolsBtn {
    background: transparent url(img/exe_atools.png) no-repeat 0 0 !important;
    /* User: You need to edit img/exe_atools.png to have a red background */
    border: none;
}

/* Force ALL buttons in the panel to use the local sprite */
#eXeAtools button {
    background-image: url(img/exe_atools.png) !important;
    background-color: transparent !important;
    background-size: auto 35px !important;
    /* Ensure background color doesn't interfere if sprite has it */
}




/* Hide the settings panel initially or style it */
/* Hide the settings panel initially or style it */
#eXeAtoolsSet {
    display: none;
    /* Use flexbox for vertical centering */
    align-items: center;
    gap: 10px;
    /* Space between items */

    position: absolute;
    top: 0px;
    /* Adjust to align vertically with the button/text line if needed */
    left: auto;
    /* Align right with container */
    right: 0;

    background: #fff;
    border: 1px solid #ddd;
    padding: 5px 10px;
    /* Reduced vertical padding for tighter fit */
    border-radius: 4px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    width: auto;
    /* Let content dictate width */
    max-width: 100%;
    z-index: 1001;
    /* Above other content */
    white-space: nowrap;
}

#eXeAtools.active #eXeAtoolsSet {
    display: flex;
    /* Activate as flex container */
}

#eXeAtoolsFont {
    position: relative !important;
    top: 0 !important;
    margin: 0 !important;
    border: 9px solid #fff !important;
}


.exe-content .page-title {

    margin-right: 40px !important;
}


/* Modo docente */

#teacher-mode-toggler-wrapper {
    float: none;
    position: fixed;
    top: 5px;
    right: 130px;
    display: flex;
    align-items: center;
    padding: 0 36px 0 0;
    margin: 0;
    height: 40px;
    z-index: 1000;
    background-image: url(img/teacher_hat.svg);
    background-repeat: no-repeat;
    background-position: right center;
    background-size: 28px;
}

#teacher-mode-toggler-wrapper .form-check-label {
    position: absolute;
    clip: rect(1px 1px 1px 1px);
    /* IE6, IE7 */
    clip: rect(1px, 1px, 1px, 1px);
}

#teacher-mode-toggler-wrapper .form-check-input {
    width: 2.6em;
    height: 1.4em;
}

#teacher-mode-toggler-wrapper .form-check-input:checked {
    background-color: #9c2a2a;
    border-color: #9c2a2a;
}

#teacher-mode-toggler-wrapper .form-check-input:focus {
    border-color: #9c2a2a;
    box-shadow: 0 0 0 0.25rem rgba(156, 42, 42, 0.25);
}

#teacher-mode-toggler-wrapper .form-check-input:focus {
    background-image: url(img/switch.svg);
    background-size: 16px;
    background-repeat: no-repeat;
    background-position: left 1.6px center;
}

.mode-teacher #teacher-mode-toggler-wrapper .form-check-input:focus {
    background-image: url(img/switch_white.svg);
    background-position: right 1.6px center;
}

@media (max-width: 1440px) {
    .siteNav-off button#siteNavToggler span {
        display: none;
    }

    body.siteNav-off button#siteNavToggler {
        width: 56px;
    }
}

@media (max-width: 1200px) {
    body.cover-on #activity {
        width: 100% !important;
    }

    #activity {
        width: 100%;
        margin: 0 auto;
    }

    #activity #player {
        width: 100% !important;
        max-width: 100% !important;
    }
}

@media (max-width: 1024px) {
    .nav-buttons .nav-button span {
        display: none;
    }

    .nav-buttons .nav-button {
        /*height: 60px;*/
    }

    .nav-buttons .nav-button-right {
        right: 20px;
        background-position: center;
    }

    .nav-buttons .nav-button-left {
        /*right: 100px;*/
        background-position: center;
    }

    /*.page>header .package-title,
    .siteNav-off .page>header .package-title {
        width: calc(100% - 230px);
    }*/


    .page-counter-label {
        display: none;
    }

    /*#teacher-mode-toggler-wrapper {
        right: 182px;
    }*/

    #teacher-mode-toggler-wrapper:hover {
        background-color: transparent;
    }

    #teacher-mode-toggler-wrapper .form-check-input {
        margin: 0 !important;
    }

    .exe-teacher-mode-toggler .page>header .package-title,
    .exe-teacher-mode-toggler.siteNav-off .page>header .package-title {
        width: calc(100% - 320px);
    }
}

@media (max-width: 750px) {

    .exe-web-site .page-content,
    .exe-web-site .page-counter {
        padding: 0 20px;
    }

    .exe-web-site .page-content {
        margin: 0;
    }

    #sidebar-nav {
        position: static !important;
        width: 100%;
        padding: 190px 0 0 0;
    }

    #siteNav {
        float: none;
        border-right: 1px solid #f0f0f0;
        width: 100%;
        padding-top: 200px;
        padding-left: 8px;
        background-color: #ffffff;
        height: auto;
        padding: 16px 16px 8px 16px;
    }

    #siteNav a {
        width: 100%;
        max-width: none;
    }

    button#siteNavToggler {
        right: 16px;
        left: 16px;
        top: 120px;
        border-radius: 0.75rem;
        width: auto;
        padding: 16px;
        height: 20px;
        border: 1px solid #ebe9e9;
        background: #ffffff url(img/menu_open.svg) no-repeat 12px center / 32px;
        font-weight: 700;
        position: absolute;
        z-index: 0;
        display: none;
    }

    button#siteNavToggler span {
        display: block;
        color: #000000;
        overflow: visible;
        width: auto;
        height: auto;
        text-align: left;
        padding-left: 40px;
    }

    .exe-web-site main.page {
        padding-left: 0;
        padding-top: 0;
    }

    body.siteNav-off button#siteNavToggler {
        right: 16px;
        left: 16px;
        top: 120px;
        border-radius: 0.75rem;
        width: auto;
        padding: 16px;
        height: 20px;
        background: #9c2a2a url(img/menu_closed.svg) no-repeat 12px / 32px;
        font-weight: 700;
    }

    body.siteNav-off button#siteNavToggler span {
        color: #fff;
        text-align: left;
        padding-left: 40px;
        width: auto;
        height: auto;
        display: block;
    }

    body.siteNav-off button#siteNavToggler:hover {
        background-color: #191748;
    }

    body.siteNav-off main.page,
    body.siteNav-off #siteFooter {
        padding: 0;
    }

    .exe-web-site .exe-content .box {
        margin-top: 20px;
    }

    /* .page > header, .siteNav-off .page > header{
        background: #fff url(img/logo_responsive.png) no-repeat 32px 15px/ 32px;
    } 
    .page>header .package-title,
    .siteNav-off .page>header .package-title {
        width: calc(100% - 180px);
    }
*/
    #siteNavToggler .sr-av {
        color: #000;
        padding-left: 40px;
    }

    .exe-search-on.siteNav-off button#siteNavToggler,
    .exe-search-on button#siteNavToggler {
        right: 100px;
    }

    #exe-client-search-form p {
        height: 54px;
        margin-top: 1em;
    }

    #exe-client-search-submit {
        background: #ffcc00 no-repeat url(img/search.svg) center / 24px;
    }

    #exe-client-search-reset.visible {
        background: #ffffff url(img/menu_open.svg) no-repeat 12px center / 24px;
    }

    #exe-client-search-submit,
    #exe-client-search-reset.visible {
        height: 54px;
        flex: 0 0 54px;
    }

    .exe-web-site #siteFooter #siteFooterContent {
        padding: 0;
    }

    .exe-web-site #siteFooter {
        padding: 0 20px !important;
    }

    #packageLicense {
        margin: 0 auto 3em auto;
    }
}

@media (max-width: 650px) {
    html {
        font-size: 0.85rem !important;
    }

    .page>header .package-title,
    .siteNav-off .page>header .package-title {
        padding-left: 32px;
        /*width: calc(100% - 140px);*/
        overflow: hidden;
        text-overflow: ellipsis;
        height: auto;
        /* white-space: normal;*/
        word-wrap: break-word;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        font-size: large;
    }

    .nav-buttons .nav-button-left,
    .nav-buttons .nav-button-right {
        height: 40px;
        width: 40px;
        padding: 0;
        /* top: 30px;*/
    }

    .nav-buttons .nav-button-left {
        right: 70px;
    }

    #searchBarTogger {
        position: absolute;
        right: 16px;
        top: 120px;
        border-radius: 0.75rem;
        width: auto;
        padding: 16px;
        height: 20px;
        border: 1px solid #ebe9e9;
        background: #fff url(img/menu_open.svg) no-repeat 12px center / 24px;
        font-weight: 700;
        z-index: 0;
        display: none;
    }

    button#siteNavToggler span,
    button#siteNavToggler .sr-av,
    body.siteNav-off button#siteNavToggler span {
        padding-left: 24px;
    }

    body.siteNav-off button#siteNavToggler {
        background: #9c2a2a url(img/menu_closed.svg) no-repeat 12px / 24px;
    }

    .box-title {
        width: calc(100% - 32px);
    }

    .exe-export .box-toggle {
        background-position: center;
        background-size: auto 32px;
        width: 32px;
        height: 32px;
    }

    .exe-single-page .package-header h1 {
        padding-left: 60px;
        overflow: hidden;
        text-overflow: ellipsis;
        word-wrap: break-word;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        width: 95%;
        height: auto;
        white-space: normal;
    }

    .exe-web-site .page-content,
    .exe-web-site .page-counter,
    #exe-client-search,
    .exe-web-site main>header,
    .exe-web-site #siteFooterContent {
        padding: 0 30px;
    }

    #teacher-mode-toggler-wrapper {
        right: 120px;
    }

    #teacher-mode-toggler-wrapper .form-check-input {
        width: 2.5em;
        height: 1.5em;
    }

    #teacher-mode-toggler-wrapper .form-check-input:focus {
        background-size: 16px;
    }

    .exe-teacher-mode-toggler .page>header .package-title,
    .exe-teacher-mode-toggler.siteNav-off .page>header .package-title {
        width: calc(100% - 180px);
    }



    #teacher-mode-toggler-wrapper {
        right: 130px;
        z-index: 999;
    }

    .page-title {
        margin-top: 32px;
    }
}

/* Table */

table {
    display: table;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    max-width: 100% !important;
    margin: 2em 0 !important;
}

@media print {
    html body.exe-export {
        background: #fff;
    }

    .exe-content {
        color: #000;
        padding: 0;
    }

    @page {
        margin: 1.5cm;
    }

    #packageLicense.cc {
        background: none;
        padding-left: 0;
    }

    .exe-export .box-toggle {
        display: none;
    }

    /* Website */
    .exe-web-site #siteNav,
    .exe-web-site .nav-buttons,
    .exe-web-site button.toggler {
        display: none;
    }

    .exe-web-site #siteFooter,
    .exe-web-site main.page {
        padding-left: 0;
        padding-right: 0;
    }

    .exe-web-site main.page {
        padding-top: 1em;
    }


}

/* Accordion FX */
.fx-accordion-title {
    position: relative;
    padding-right: 30px;
    display: block;
    text-decoration: none !important;
}

.fx-accordion-title::after {
    content: '';
    position: absolute;
    right: 10px;
    top: 50%;
    margin-top: -10px;
    width: 20px;
    height: 20px;
    background: url(img/arrow_red.svg) no-repeat center center;
    background-size: contain;
    transform: rotate(180deg);
    transition: transform 0.3s ease;
}

.fx-accordion-title.active::after {
    transform: rotate(0deg);
}