/* VARIABLES CSS */
:root {
    --color-primario: #0058ab; 
    --color-secundario:#e3000f;
    --color-terciario: #ffee00;
    --color-primary-light: #dbeafe; 
    --color-base: #F7F8FA;
    --tertiary: #FFF500;
    --tertiary-dark: #E6DD00;

    --radius-md: 12px;
    --shadow-primary: 0 8px 30px rgba(0,89,171,0.3);

    --colortext-white: #FFFFFF;
    --colortext-black: #0F172A;
    
     --color-text: #1a2130;
           
    --gray-50: #F8FAFC;
    --gray-100: #F1F5F9;
    --gray-200: #E2E8F0;
    --gray-300: #CBD5E1;
    --gray-400: #94A3B8;
    --gray-500: #64748B;
    --gray-600: #475569;
    --gray-700: #334155;
    --gray-800: #1E293B;

    --shadow-sm: 0 1px 3px rgba(0,0,0,0.08);
    --shadow-md: 0 4px 20px rgba(0,0,0,0.1);
    --shadow-lg: 0 10px 40px rgba(0,0,0,0.12);
    --shadow-xl: 0 20px 60px rgba(0,0,0,0.15);
    --shadow-primary: 0 8px 30px rgba(0,89,171,0.3);
    --shadow-secondary: 0 8px 30px rgba(227,0,14,0.3);
    --radius-sm: 8px;
    --radius-md: 12px;
    --radius-lg: 16px;
    --radius-xl: 24px;
    --radius-full: 9999px;
    --transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    
     --personal_primary-light: #dbeafe;     
     --persnal_bg: #f8fafc;
     --persnal_p_bg-card: #ffffff;
     --persnal_p_accent: #f59e0b;
     --persnal_p_success: #10b981;
     --persnal_p_bg: #f8fafc;
     --persnal_bg-card: #ffffff;
     --persnal_text: #1e293b;
     --persnal_text-light: #64748b;
     --persnal_text-lighter: #94a3b8;
     --persnal_border: #e2e8f0;
     --persnal_shadow-sm: 0 1px 3px rgba(0,0,0,0.08);
     --persnal_shadow-md: 0 4px 12px rgba(0,0,0,0.1);
     --persnal_shadow-lg: 0 10px 30px rgba(0,0,0,0.12);
     --persnal_shadow-xl: 0 20px 50px rgba(0,0,0,0.15);
     --persnal_radius-sm: 8px;
     --persnal_radius-md: 12px;
     --persnal_radius-lg: 16px;
     --persnal_radius-xl: 24px;
     --persnal_transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
     --persnal_max-width: 1200px;
    
     /*ORGANIZACION*/
     /* Tipografía fluida */
      --Ofs-xs: clamp(0.8rem, 0.75vw + 0.6rem, 0.9rem);
      --Ofs-sm: clamp(0.9rem, 0.8vw + 0.7rem, 1rem);
      --Ofs-base: clamp(1rem, 0.9vw + 0.75rem, 1.125rem);
      --Ofs-md: clamp(1.25rem, 1vw + 0.8rem, 1.5rem);
      --Ofs-lg: clamp(1.5rem, 1.5vw + 1rem, 2rem);
      --Ofs-xl: clamp(2rem, 2vw + 1.2rem, 3rem);
      
      --Ospace-xs: clamp(0.5rem, 1vw, 0.75rem);
      --Ospace-sm: clamp(1rem, 1vw, 1rem);
       /*--Ospace-sm: clamp(1rem, 2vw, 1.5rem);*/
      --Ospace-md: clamp(1.5rem, 3vw, 2.5rem);
      --Ospace-lg: clamp(2rem, 5vw, 4rem);
      --Ospace-xl: clamp(3rem, 8vw, 6rem);

      

      --Obg: #F8FAFC;
      --Osurface: #FFFFFF;
      --Otext: #1A202C;
      --Otext-light: #4A5568;
      --Oborder: #E2E8F0;
      --Oradius: 0.75rem;
      --Oshadow: 0 4px 6px -1px rgba(0,0,0,0.05), 0 2px 4px -1px rgba(0,0,0,0.03);
      --Oshadow-hover: 0 10px 15px -3px rgba(0,0,0,0.1), 0 4px 6px -2px rgba(0,0,0,0.05);
      --Otransition: 250ms cubic-bezier(0.4, 0, 0.2, 1);

      /*transparencia*/
       --Taccent: #e53e3e;
            --Taccent-hover: #c53030;
            --Tsuccess: #38a169;
            --Tsuccess-hover: #2f855a;
            --Tgray-50: #f7fafc;
            --Tgray-100: #edf2f7;
            --Tgray-200: #e2e8f0;
            --Tgray-300: #cbd5e0;
            --Tgray-400: #a0aec0;
            --Tgray-500: #718096;
            --Tgray-600: #4a5568;
            --Tgray-700: #2d3748;
            --Tgray-800: #1a202c;
            --Twhite: #ffffff;
            --Tshadow-sm: 0 1px 2px rgba(0,0,0,0.05);
            --Tshadow-md: 0 4px 6px -1px rgba(0,0,0,0.1), 0 2px 4px -1px rgba(0,0,0,0.06);
            --Tshadow-lg: 0 10px 15px -3px rgba(0,0,0,0.1), 0 4px 6px -2px rgba(0,0,0,0.05);
            --Tshadow-xl: 0 20px 25px -5px rgba(0,0,0,0.1), 0 10px 10px -5px rgba(0,0,0,0.04);
            --Tradius: 12px;
            --Ttransition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);

        --whatsapp-bg: #25D366;
        --whatsapp-hover: #128C7E;
        --whatsapp-size: 56px;
        --whatsapp-z: 1050; /* Mayor que tu menú fijo */

      
            
}


html {
    color: #222;
    font-size: 1em;
    line-height: 1.4;
}

:-moz-selection {
    background: #b3d4fc;
    text-shadow: none;
}

::selection {
    background: #b3d4fc;
    text-shadow: none;
}

body {
    font-family: 'Open Sans', sans-serif;
    padding-right: 0 !important;
    color: #29303b;
    font-size: 15px;
}

body.white-bg {
    background: #fff;
}

body.gray-bg {
    background: #f7f8fa;
}

body.modal-open {
    overflow: auto;
}

p {
    margin: 0 0 10.5px;
}

a, button, input[type="button"] {
    transition: all 0.3s;
    -webkit-transition: all 0.3s;
    -ms-webkit-transition: all 0.3s;
}

a {
    color: #007791;
}

a:hover {
    text-decoration: none;
    color: #003845;
}

*[data-toggle="modal"], button {
    cursor: pointer;
}

a:focus, .btn:focus, .form-control:focus, button:focus, input:focus, textarea:focus, select:focus {
    outline: none;
    box-shadow: 0 0 0 0 !important;
}

fieldset, label {
    margin: 0;
    padding: 0;
    margin-bottom: 5px;
    color: #b2b4b9;
}

.tooltip {
    pointer-events: none;
}

.btn {
    color: #fff;
    background-color: var(--color-primario);
    border-color: var(--color-primario);
    padding: 11px 12px;
    font-size: 15px;
    border-radius: 2px;
    line-height: 1.35135;
    font-weight: 600;
}

.bg-academy {
    color: #fff;
    background-color: var(--color-primario);
    border-color: var(--color-primario);
}

.btn:hover, .btn:focus {
    background-color: var(--color-secundario);
    border-color: var(--color-secundario);
    color: #fff;
}

textarea:focus, .form-control:focus, input:focus {
    border-color: #76c5d6;
}

select+.select2-container {
    width: 100%!important;
}

.rating i {
    color: #dedfe0;
}

.rating i.filled {
    color: var(--color-terciario);
}

.rating i.half-filled {
    position: relative;
}

.rating i.half-filled:after {
    position: absolute;
    content: "\f089";
    top: 0;
    left: 0;
    font-size: inherit;
    color: var(--color-terciario);
    z-index: 1;
}

/*
bootstrap overwrite css
*/

.container-xl, .container-lg {
    width: 100%;
    padding-right: 20px;
    padding-left: 20px;
    margin-right: auto;
    margin-left: auto
}

/*
menu
*/

.corner-triangle.top-left:after {
    top: -12px;
    left: 14px;
}

.corner-triangle.top-left:before {
    top: -14px;
    left: 14px;
}

.corner-triangle.top-right:after {
    top: -12px;
    right: 14px;
}

.corner-triangle.top-right:before {
    top: -14px;
    right: 14px;
}

.corner-triangle:after {
    border-color: transparent transparent #fff;
}

.corner-triangle:before {
    border-color: transparent transparent #e8e9eb;
}

.corner-triangle:before, .corner-triangle:after {
    border-style: solid;
    border-width: 0 10px 13px;
    content: "";
    height: 0;
    width: 0;
    position: absolute;
}

.menu-area {
    box-shadow: 0 0 1px 1px rgba(20, 23, 28, .1), 0 3px 1px 0 rgba(20, 23, 28, .1);
    position: sticky;
   
     position: sticky;
  top: 0;
  z-index: 1000;
  background-color: #f7f9fa;
  
}

.menu-area .navbar {
    padding: 0;
}

.signin-box-move-mobile-helper, .signin-box-move-desktop-helper {
    display: none;
}

/*

menu code was here

*/

.search-box {
    margin-right: 50px;
    padding: 10px 0;
}

.search-box input {
    background-color: #f2f3f5;
    border: 1px solid #f2f3f5;
    height: 45px;
    padding: 0 15px;
    border-radius: 2px 0 0 2px;
    font-size: 13px;
}

.search-box input:focus {
    background-color: #fff;
    border-color: #dedfe0;
    border-right-color: transparent;
}

.search-box input:focus+.input-group-append button {
    background-color: #fff;
    border-color: #dedfe0;
    border-left-color: transparent;
}

.search-box button {
    border: 1px solid #f2f3f5;
    border-radius: 0 2px 2px 0;
    font-size: 15px;
    padding: 10px 15px;
    background: #f2f3f5;
    color: var(--color-primario);
}

.search-box button:hover, .search-box button:focus {
    background-color: var(--color-primario) !important;
    border-color: var(--color-primario);
    color: #fff;
}

.menu-icon-box .empty-box {
    padding: 20px;
}

.menu-icon-box .empty-box p {
    margin-bottom: 0px;
}

.menu-icon-box .empty-box a {
    display: inline-block;
    font-weight: 600;
    margin-top: 15px;
}

.menu-icon-box {
    position: relative;
    margin: 0 5px;
}

.menu-icon-box .icon {
    position: relative;
}

.menu-icon-box .icon .number {
    position: absolute;
    top: 14px;
    right: 2px;
    background-color: var(--color-primario);
    border-radius: 15px;
    color: #fff;
    font-size: 10px;
    line-height: 1.43;
    min-width: 19px;
    padding: 2px 6px;
    text-align: center;
    pointer-events: none;
}

.menu-icon-box .icon a {
    height: 45px;
    width: 45px;
    text-align: center;
    line-height: 45px;
    display: inline-block;
    border-radius: 50%;
    color: #686f7a;
    border: 1px solid transparent;
    margin: 10px 0;
    font-size: 18px;
}

.menu-icon-box .icon a:hover {
    background: rgba(20, 23, 28, .05);
    border-color: rgba(20, 23, 28, .05);
}

.menu-icon-box:hover>.dropdown {
    opacity: 1;
    visibility: visible;
}

.menu-icon-box .dropdown {
    position: absolute;
    z-index: 10;
    opacity: 0;
    visibility: hidden;
    background-color: #fff;
    border-top: 1px solid #e8e9eb;
    box-shadow: 0 4px 16px rgba(20, 23, 28, .25);
    color: #505763;
    font-size: 13px;
    left: inherit;
    list-style: none;
    margin: 0;
    right: -1px;
    text-align: left;
    top: 100%;
    width: 330px;
}

.course-list-dropdown .item-list {
    max-height: 230px;
    overflow-y: auto;
    margin-bottom: 10px;
}

.course-list-dropdown .item-list ul {
    margin: 0;
    padding: 0;
    list-style: none;
}

.course-list-dropdown .item-list ul li {
    padding: 23px 23px 10px;
    transition: all 0.3s;
    -webkit-transition: all 0.3s;
    -ms-webkit-transition: all 0.3s;
}

.course-list-dropdown .item-list ul li:hover {
    background: #f2f3f5;
}

.course-list-dropdown .item-list ul a {
    display: block;
}

.course-list-dropdown .item-list .item .item-image {
    width: 60px;
    float: left;
}

.course-list-dropdown .item-list .item .item-details {
    padding-left: 70px;
}

.course-list-dropdown .item-list .item .item-details .course-name {
    color: #505763;
    font-size: 13px;
    font-weight: 600;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    -webkit-line-clamp: 1;
    -moz-line-clamp: 1;
    -ms-line-clamp: 1;
    -o-line-clamp: 1;
    line-clamp: 1;
}

.course-list-dropdown .item-list .item .item-details .instructor-name {
    color: #686f7a;
    font-size: 13px;
}

.course-list-dropdown .item-list .item .item-details .current-price {
    color: var(--color-primario);
    font-size: 18px;
    font-weight: 600;
    margin-right: 5px;
}

.course-list-dropdown .item-list .item .item-details .original-price {
    text-decoration: line-through;
    color: #686f7a;
}

.course-list-dropdown .item-list .item .item-details .instructor-name {
    color: #686f7a;
    font-size: 13px;
}

.course-list-dropdown .item-list .item .item-details .current-price {
    color: var(--color-primario);
    font-size: 18px;
    font-weight: 600;
    margin-right: 5px;
}

.course-list-dropdown .item-list .item .item-details .original-price {
    text-decoration: line-through;
    color: #686f7a;
}

.course-list-dropdown .item-list .item .item-details button {
    padding: 2px 8px;
    font-size: 13px;
    line-height: 1.35135;
    border-radius: 2px;
    width: 100%;
    color: #007791;
    background-color: #fff;
    border: 1px solid #007791;
}

.course-list-dropdown .item-list .item .item-details button:hover, .course-list-dropdown .item-list .item .item-details button:focus {
    background: #e6f2f5;
}

.course-list-dropdown .dropdown-footer {
    background: #f2f3f5;
    padding: 5px 20px 25px;
}

.course-list-dropdown .dropdown-footer a {
    width: 100%;
    border: 0;
    color: #fff;
    background-color: #007791;
    padding: 11px 12px;
    font-size: 15px;
    line-height: 1.43;
    border-radius: 2px;
    font-weight: 600;
    margin-top: 20px;
    display: block;
    text-align: center;
}

.course-list-dropdown .dropdown-footer a:hover, .course-list-dropdown .dropdown-footer a:focus {
    background: #003440;
}

.course-list-dropdown .dropdown-footer .cart-total-price {
    color: #686f7a;
    font-size: 15px;
    margin-top: 8px;
}

.course-list-dropdown .dropdown-footer .cart-total-price .current-price {
    color: var(--color-primario);
    font-size: 18px;
    font-weight: 600;
    margin-right: 5px;
}

.course-list-dropdown .dropdown-footer .cart-total-price .original-price {
    text-decoration: line-through;
    color: #686f7a;
    font-size: 14px;
}

.notifications-list-dropdown .notifications-head {
    padding: 12px;
    font-size: 15px;
    border-bottom: 1px solid hsla(210, 3%, 87%, .45);
    color: #29303b;
}

.notifications-list-dropdown .notifications-footer {
    background: #f7f8fa;
    height: 58px;
    box-shadow: 0 -3px 5px rgba(0, 0, 0, .05);
}

.notifications-list-dropdown .notifications-footer a, .notifications-list-dropdown .notifications-footer button {
    color: #007791;
    font-size: 13px;
    font-weight: 600;
    padding: 20px 15px;
}

.notifications-list-dropdown .notifications-footer button {
    border: 0;
    background: transparent;
}

.notifications-list-dropdown .notifications-footer a:hover, .notifications-list-dropdown .notifications-footer button:hover, .notifications-list-dropdown .notifications-footer a:focus, .notifications-list-dropdown .notifications-footer button:focus {
    color: #004d5e;
    background: #f2f3f5;
}

.notifications-list-dropdown .notifications-footer a i {
    margin-left: 5px;
    margin-right: 5px;
    transition: inherit;
    -webkit-transition: inherit;
    -ms-webkit-transition: inherit;
}

.notifications-list-dropdown .notifications-footer a:hover i {
    transform: translateX(5px);
}

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

.notification-list ul li {
    padding: 10px 15px;
    border-bottom: 1px solid hsla(210, 3%, 87%, .45);
    transition: all 0.3s;
    -webkit-transition: all 0.3s;
    -ms-webkit-transition: all 0.3s;
}

.notification-list ul li:hover {
    background: #f7f8fa;
}

.notification-list ul li a {
    display: block;
}

.notification-list .notification .notification-image {
    float: left;
    height: 64px;
    width: 64px;
}

.notification-list .notification .notification-details {
    padding-left: 74px;
}

.notification-list .notification .notification-details .notification-text {
    display: block!important;
    display: -webkit-box!important;
    -webkit-line-clamp: 2;
    -moz-line-clamp: 2;
    -ms-line-clamp: 2;
    -o-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    -moz-box-orient: vertical;
    -ms-box-orient: vertical;
    -o-box-orient: vertical;
    box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: normal;
    width: 210px;
    height: 40px;
    color: #505763;
    margin-bottom: 0;
    line-height: 1.5;
}

.notification-list .notification .notification-details .notification-time {
    color: #686f7a;
    font-size: 13px;
    margin-top: 5px;
    margin-bottom: 0;
}

.notification-list .notification .notification-image img {
    border-radius: 50%;
}

.notification-list .notification {
    position: relative;
}

.notifications-list-dropdown .notification-list {
    max-height: 415px;
    overflow-y: auto;
}

.notification-list .notification .mark-as-read {
    position: absolute;
    height: 10px;
    width: 10px;
    border: 1px solid #007791;
    border-radius: 50%;
    top: 2px;
    right: -3px;
    background: #007791;
}

.notification-list .notification .mark-as-read.marked {
    border-color: rgba(41, 48, 59, .25);
    background-color: transparent;
}

.user-box.menu-icon-box .icon a img {
    border-radius: 50%;
    height: 45px;
    width: 45px;
    margin-top: -5px;
}

.user-dropdown-menu {
    margin: 0;
    padding: 0;
    padding-top: 10px;
    list-style: none;
}

.user-dropdown-menu li a {
    display: block;
    color: #29303b;
    font-size: 15px;
    font-weight: 400;
    padding: 10px 22px;
}

.user-dropdown-menu li a:hover {
    color: #007791;
    background: #f2f3f5;
}

.user-dropdown-menu li a i {
    font-size: 16px;
    width: 20px;
    text-align: center;
    margin: 0 19px 0 10px;
    color: #a1a7b3;
}

.dropdown-user-info .user-image img {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: 1px solid #f2f3f5;
}

.dropdown-user-info .user-details {
    padding-left: 50px;
}

.dropdown-user-info .user-details .user-name {
    color: #29303b;
}

.dropdown-user-info .user-details .user-email {
    color: #686f7a;
    font-size: 13px;
}

.dropdown-user-info .user-details .user-name .hi, .dropdown-user-info .user-details .user-email .welcome {
    display: none;
}

.user-dropdown-menu .dropdown-user-logout {
    padding: 10px 0;
    background: #f7f8fa;
}

.sign-in-box>.btn {
    padding: 11px 12px;
    font-size: 15px;
    border-radius: 2px;
    line-height: 1.35135;
    font-weight: 600;
    margin-left: 5px !important;
    border-radius: 8px !important;
}

.sign-in-box .btn-sign-in {
    color: #686f7a;
    background-color: #fff;
    border: 1px solid #505763;
}

.sign-in-box .btn-sign-in:hover, .sign-in-box .btn-sign-in:focus {
    background-color: #f2f3f5;
}

.sign-in-box .btn-sign-up {
    color: #fff;
    background-color: var(--color-primario);
    border: 1px solid var(--color-primario);
}

.sign-in-box .btn-sign-up:hover, .sign-in-box .btn-sign-up:focus {
    background-color: var(--color-secundario);
    ;
    border-color: var(--color-secundario);
    ;
}

.sign-in-box .modal-dialog {
    max-width: 400px;
}

.sign-in-modal .modal-title {
    color: #29303b;
    font-weight: 700;
    font-size: 15px;
}

.sign-in-modal .close {
    font-size: 2rem;
    padding: 0.5rem 1rem;
}

.sign-in-modal .modal-header {
    border-bottom: 1px solid rgba(41, 48, 59, .1);
    background-color: #f2f3f5;
}

.sign-in-modal .modal-header, .sign-in-modal .modal-body {
    padding: 20px 25px;
}

.sign-in-modal .social-btn {
    box-shadow: 0 2px 2px 0 rgba(41, 48, 59, .24), 0 0 2px 0 rgba(41, 48, 59, .12);
    border-radius: 2px;
    margin-bottom: 10px;
    padding: 0 20px 0 0;
    font-size: 16px;
    font-weight: 700;
    background-color: #fff;
}

.sign-in-modal .social-btn a {
    display: block;
}

.sign-in-modal .icon {
    display: inline-block;
    font-size: 20px;
    font-weight: 400;
    margin-right: 10px;
    padding: 15px 0 15px 5px;
    text-align: center;
    width: 50px;
}

.sign-in-modal .icon.google-icon {
    background: url(../img/icons/google_icon.svg) no-repeat 50%;
    background-size: 24px;
    color: #fff;
    color: rgba(0, 0, 0, 0);
}

.sign-in-modal .social-btn.fb-sign-up {
    background-color: #1a538a;
}

.sign-in-modal .social-btn.fb-sign-up a {
    color: #fff;
}

.sign-in-modal .social-btn.google-sign-up a {
    color: #686f7a;
}

.sign-in-modal .sign-in-separator {
    font-size: 11px;
    font-weight: 700;
    text-align: center;
    margin-bottom: 10px;
    padding-top: 3px;
    position: relative;
}

.sign-in-modal .sign-in-separator:after, .sign-in-modal .sign-in-separator:before {
    position: absolute;
    height: 1px;
    background-color: #dedfe0;
    content: "";
    top: 10px;
    width: calc( 50% - 20px);
}

.sign-in-modal .sign-in-separator:before {
    left: 0
}

.sign-in-modal .sign-in-separator:after {
    right: 0
}

.sign-in-modal .input-group {
    margin-bottom: 10px;
    position: relative;
}

.sign-in-modal .input-group .input-field-icon {
    position: absolute;
    top: 15px;
    height: 20px;
    width: 20px;
    text-align: center;
    line-height: 20px;
    z-index: 10;
    left: 10px;
    color: #dedfe0;
    font-size: 18px;
}

.sign-in-modal .input-group .form-control {
    border-radius: 5px;
    color: #29303b;
    font-size: 18px;
    height: auto;
    padding: 11px 10px 12px 40px;
    background-color: #fff;
    border: 1px solid #cacbcc;
}

.sign-in-modal .input-group .form-control:focus {
    border-color: #76c5d6;
}

.sign-in-modal .deal-checkbox {
    margin-bottom: 10px;
    font-size: 15px;
    cursor: pointer;
}

.sign-in-modal .custom-checkbox .custom-control-label::before {
    border-radius: 1px;
    border: 1px solid #cacbcc;
    background-color: transparent;
}

.sign-in-modal .custom-control-input:hover~.custom-control-label::before, .sign-in-modal .custom-control-input:focus~.custom-control-label::before {
    box-shadow: 0 0 0 0px #fff, 0 0 0 0 rgba(0, 123, 255, .25);
    border-color: #007791;
}

.sign-in-modal .custom-checkbox .custom-control-input:checked~.custom-control-label::before {
    background-color: #007791;
    border-color: #007791;
}

.sign-in-modal form button[type="submit"] {
    color: #fff;
    background-color: var(--color-primario);
    border-color: var(--color-primario);
    font-size: 16px;
    font-weight: 700;
    height: 50px;
    width: 100%;
    padding: 11px 12px;
    border-radius: 2px;
}

.sign-in-modal form button[type="submit"]:hover, .sign-in-modal form button[type="submit"]:focus {
    background-color: #521822 !important;
    border-color: #521822 !important;
}

.sign-in-modal .forgot-pass {
    text-align: center;
    font-size: 15px;
}

.sign-in-modal .agreement-text {
    text-align: center;
    font-size: 10px;
    margin: 10px 0;
}

.sign-in-modal .account-have {
    text-align: center;
    font-size: 15px;
    padding-top: 15px;
    border-top: 1px solid #dedfe0;
}

.sign-in-modal .account-have a {
    font-weight: 700;
}

.sign-in-modal .forgot-email.form-control {
    font-size: 16px;
    padding: 10px 12px;
    border-radius: 2px;
}

.sign-in-modal .forgot-pass-btn {
    text-align: center;
    margin-top: 15px;
    font-size: 15px;
}

.sign-in-modal .forgot-pass-btn .btn {
    width: auto;
    height: auto;
    padding: 11px 12px;
    font-size: 15px;
}

.sign-in-modal .forgot-pass-btn span {
    margin: 0 5px;
}

.sign-in-modal .forgot-recaptcha {
    margin: 25px 0 15px;
}

.course-preview-modal .modal-header {
    border-color: #000;
}

.course-preview-modal {
    background-color: #29303b;
    color: #fff;
}

.course-preview-modal .modal-title {
    font-size: 18px;
}

.course-preview-modal .modal-title span {
    color: #76c5d6;
    margin-right: 5px;
}

.course-preview-modal .close {
    color: #fff;
    text-shadow: 0 0 0 #fff;
    opacity: 1;
    font-size: 27px;
}

.course-preview-modal .modal-body {
    padding: 0;
}

.course-preview-modal .course-preview-video-list .title {
    font-size: 18px;
    color: #dedfe0;
    padding: 7px 15px;
}

.course-preview-modal .course-preview-video-list ul {
    margin: 0;
    padding: 0;
    list-style: none;
    margin-bottom: 10px;
}

.course-preview-modal .course-preview-video-list .course-preview-free-video {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.course-preview-modal .course-preview-video-list .course-preview-free-video .course-image {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 18%;
    flex: 0 0 18%;
    max-width: 18%;
}

.course-preview-modal .course-preview-video-list .course-preview-free-video .course-name {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 82%;
    flex: 0 0 82%;
    max-width: 82%;
    padding-left: 15px;
    font-size: 13px;
}

.course-preview-modal .course-preview-video-list .course-preview-free-video .course-name i {
    font-size: 12px;
    margin-right: 7px;
}

.course-preview-modal .course-preview-video-list li {
    padding: 7px 15px;
    cursor: pointer;
}

.course-preview-modal .course-preview-video-list li.active {
    background-color: #505763;
}

/*
homepage styles
*/

.home-banner-area {
    background-image: url('../img/portadaDSI.JPG');
    background-position: center center;
    background-size: cover;
    background-repeat: no-repeat;
    padding: 170px 0 130px;
    color: #fff;
}

.home-banner-wrap {
    max-width: 500px;
}

.home-banner-wrap h2 {
    font-size: 44px;
    font-weight: 600;
    line-height: 1;
    margin-bottom: 10px;
    text-shadow: 0 2px 4px rgba(41, 48, 59, .55);
}

.home-banner-wrap p {
    font-size: 18px;
    line-height: 34px;
    margin-bottom: 30px;
    text-shadow: 0 2px 4px rgba(41, 48, 59, .55);
}

.home-banner-wrap input[type="text"] {
    font-size: 20px;
    height: 50px;
    padding: 11px 17px;
    border: none;
    border-radius: 3px 0 0 3px;
    font-weight: 300
}

.home-banner-wrap .btn {
    padding: 10px 14px;
    font-size: 20px;
    background: #fff;
    border: 0;
    border-radius: 0 3px 3px 0;
    color: var(--color-primario);
}

.home-banner-wrap .btn:hover {
    background: var(--color-primario);
    color: #fff;
}

.home-fact-area {
    background-color: var(--color-terciario);
   /* background: -webkit-linear-gradient(-45deg, var(--color-primario), #292f36);
    background: -moz-linear-gradient(-45deg, var(--color-primario) 0, #292f36 100%);
    background: -ms-linear-gradient(-45deg, var(--color-primario) 0, #292f36 100%);
    background: -o-linear-gradient(-45deg, var(--color-primario) 0, #292f36 100%);
    background: linear-gradient(-45deg, var(--color-primario), #292f36);
    */
    background: linear-gradient(135deg, var(--color-terciario), var(--color-terciario));
    color: #fff;
    padding: 15px 0;
    margin-bottom: 50px
}

.home-fact-box .text-box {
    padding: 10px 0 10px 63px;
}

.home-fact-box i {
    font-size: 47px;
    margin-top: 8px;
     color: var(--color-text);
}

.home-fact-box .text-box h4 {
    font-size: 17px;
    font-weight: 700;
    margin-bottom: 0;
     color: var(--color-text);
}

.home-fact-box .text-box p {
    font-size: 15px;
    margin-bottom: 0;
    color: var(--color-text);
}

.course-carousel-area {
    margin-bottom: 20px;
    overflow-x: hidden;
}

.course-carousel-area .course-carousel-title {
    font-size: 20px;
    color: #505763;
    margin: 0 0 10px;
}

.course-carousel-area .slick-slider {
    width: calc( 100% + 16px);
    margin-left: -8px;
}

.course-carousel-area .slick-list:before, .course-carousel-area .slick-list:after {
    position: absolute;
    content: "";
    top: 0;
    right: 0;
    height: 100%;
    width: 8px;
    background: #f7f8fa;
    z-index: 1;
}

.course-carousel-area .slick-list:after {
    right: auto;
    left: 0
}

.course-carousel .slick-prev:hover, .course-carousel .slick-next:hover {
    box-shadow: 0 2px 8px 2px rgba(20, 23, 28, .15);
}

.course-carousel .slick-prev:focus, .course-carousel .slick-next:focus {
    box-shadow: 0 0 1px 1px rgba(20, 23, 28, .1), 0 3px 1px 0 rgba(20, 23, 28, .1) !important;
}

.course-carousel .slick-prev, .course-carousel .slick-next {
    width: 47px;
    height: 47px;
    border-radius: 50%;
    background-color: #fff;
    box-shadow: 0 0 1px 1px rgba(20, 23, 28, .1), 0 3px 1px 0 rgba(20, 23, 28, .1);
    z-index: 1;
    top: calc( 50% - 25px);
}

.course-carousel .slick-prev {
    left: -28px;
}

.course-carousel .slick-prev.slick-disabled, .course-carousel .slick-next.slick-disabled {
    opacity: 0;
}

.course-carousel .slick-prev:before {
    content: url(../img/icons/prev_arrow.png);
    line-height: 0;
    opacity: 1
}

.course-carousel .slick-next {
    right: -15px
}

.course-carousel .slick-next:before {
    content: url(../img/icons/next_arrow.png);
    line-height: 0;
    opacity: 1;
}

.course-box-wrap:focus {
    outline: none;
}

.course-box-wrap {
    padding: 0 8px;
    margin-bottom: 20px;
}

.course-box-wrap a {
    color: #fff;
}

.course-box-wrap a:hover {
    text-decoration: none;
}

.course-box {
    position: relative;
    background: #fff;
}

.course-box:before, .course-box:after {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    will-change: opacity;
    transition: .2s ease;
    -webkit-transition: .2s ease;
    -ms-webkit-transition: .2s ease;
    z-index: -1;
}

.course-box:before {
    opacity: 1;
    box-shadow: 0 0 1px 1px rgba(20, 23, 28, .1), 0 3px 1px 0 rgba(20, 23, 28, .1);
    -webkit-box-shadow: 0 0 1px 1px rgba(20, 23, 28, .1), 0 3px 1px 0 rgba(20, 23, 28, .1);
    -ms-webkit-box-shadow: 0 0 1px 1px rgba(20, 23, 28, .1), 0 3px 1px 0 rgba(20, 23, 28, .1);
}

.course-box:after {
    opacity: 0;
    box-shadow: 0 2px 8px 2px rgba(20, 23, 28, .15);
    -webkit-box-shadow: 0 2px 8px 2px rgba(20, 23, 28, .15);
    -ms-webkit-box-shadow: 0 2px 8px 2px rgba(20, 23, 28, .15);
}

.course-box:hover:before {
    opacity: 0;
}

.course-box:hover:after {
    opacity: 1;
}

.course-box .play-btn {
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    position: absolute;
    background: url(../img/icons/icon-play.svg) no-repeat;
    background-size: auto 40%;
    background-position: 50%;
    visibility: hidden;
    opacity: 0;
    -webkit-transition: .2s;
    -moz-transition: .2s;
    -o-transition: .2s;
    transition: .2s;
    z-index: 1
}

.course-box .course-image:hover>.play-btn {
    -webkit-transform: scale(1.2);
    -ms-transform: scale(1.2);
    -o-transform: scale(1.2);
    transform: scale(1.2);
    visibility: visible;
    opacity: 1;
}

.course-box .course-details {
    padding: 15px 10px 0px 15px;
    position: relative;
}

.course-box .course-details .title {
    display: block!important;
    display: -webkit-box!important;
    -webkit-line-clamp: 2;
    -moz-line-clamp: 2;
    -ms-line-clamp: 2;
    -o-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    -moz-box-orient: vertical;
    -ms-box-orient: vertical;
    -o-box-orient: vertical;
    box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: normal;
    font-weight: 600;
    height: 36px;
    min-height: 42px;
    font-size: 15px;
    color: #29303b;
    margin-bottom: 10px;
    line-height: 20px;
}

.course-box .course-details .instructors {
    display: block!important;
    display: -webkit-box!important;
    -webkit-line-clamp: 1;
    -moz-line-clamp: 1;
    -ms-line-clamp: 1;
    -o-line-clamp: 1;
    line-clamp: 1;
    -webkit-box-orient: vertical;
    -moz-box-orient: vertical;
    -ms-box-orient: vertical;
    -o-box-orient: vertical;
    box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: normal;
    min-height: 21px;
    height: 21px;
    font-size: 12px;
    color: #686f7a;
    margin-bottom: 5px;
}

.course-box .course-details .rating {
    margin-bottom: 10px;
}

.course-box .course-details .rating i {
    font-size: 11px;
}

.course-box .course-details .rating .rating-number {
    color: #29303b;
    margin-bottom: 0;
    font-size: 12px;
}

.course-box .course-details .rating .rating-number span {
    font-weight: 600;
    color: #a1a7b3;
    margin-left: 5px;
}

.course-box .course-details .price {
    padding-bottom: 15px;
    color: #29303b;
    font-size: 18px;
    font-weight: 600;
    margin-right: 10px;
}

.course-box .course-details .price small {
    color: #686f7a;
    font-weight: 400;
    font-size: 13px;
    margin-right: 5px;
    text-decoration: line-through;
}

.course-box .course-details .completed-percent .progress-bar {
    background: #007791;
}

.course-box .course-details .completed-percent .progress {
    border-radius: 0;
    height: 2px;
    background-color: rgba(41, 48, 59, .25);
}

.course-box .course-details .completed-percent {
    margin-top: 10px;
    padding-bottom: 30px;
}

.course-box .course-details .completed-percent .text {
    width: 50%;
    color: #686f7a;
    font-size: 13px;
}

.course-box .course-details .your-rating-box {
    position: absolute;
    right: 10px;
    bottom: 3px;
    margin-bottom: 0;
    z-index: 1;
    text-align: right;
}

.course-box .course-details .your-rating-box .your-rating-text {
    margin-bottom: 0;
    font-size: 13px;
    color: #29303b;
    margin-top: 2px;
}

.course-box .course-details .your-rating-box:hover .your-rating-text {
    color: var(--color-primario);
}

.course-box .course-details .your-rating-box .your-rating-text .edit {
    display: none;
}

.course-box .course-details .your-rating-box:hover .your-rating-text .edit {
    display: unset;
}

.course-box .course-details .your-rating-box:hover .your-rating-text .your {
    display: none;
}

.course-box .course-details .your-rating-box i {
    color: transparent;
    text-stroke: 1px #eaeaea;
    -webkit-text-stroke: 1px #eaeaea;
    font-size: 17px;
    letter-spacing: -0.1em;
}

.course-box .course-details .your-rating-box i.filled {
    color: var(--color-terciario);;
}

.course-badge {
    color: #29303b;
    box-shadow: 0 0 1px 1px rgba(20, 23, 28, .1), 0 3px 1px 0 rgba(20, 23, 28, .1);
    pointer-events: none;
    border-radius: 3px;
    font-size: 9px;
    padding: 1px 8px;
    font-weight: 700;
    position: relative;
    line-height: 1.5;
    text-align: center;
    text-transform: uppercase;
    display: inline-block;
}

.course-badge:after {
    border-radius: 3px;
    right: -4px;
    background: inherit;
    content: "";
    height: 11px;
    position: absolute;
    top: 2px;
    transform: rotate(45deg);
    width: 11px;
    z-index: 0;
    display: block;
}

.course-badge.best-seller {
    background: var(--color-terciario);
}

.course-badge.hot-new {
    background: var(--color-primario);
    color: #fff;
}

.course-badge.position {
    position: absolute;
    top: 12px;
    left: 0;
    border-bottom-left-radius: 0;
    border-top-left-radius: 0;
}

.course-box .course-image {
    position: relative;
}

.course-box .course-image:before {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    content: "";
    background-color: rgba(0, 0, 0, 0.3);
    z-index: 1;
    opacity: 0;
    visibility: hidden;
    transition: 0.2s;
    -webkit-transition: 0.2s;
    -ms-webkit-transition: 0.2s;
}

.course-box .wishlist-add, .course-box .favorite-add {
    position: absolute;
    top: 10px;
    right: 10px;
    z-index: 1;
}

.course-box .wishlist-add button, .course-box .favorite-add button {
    margin: 0;
    padding: 0;
    border: 0;
    background: none;
    cursor: pointer;
}

.course-box .wishlist-add button:hover i, .course-box .wishlist-add.wishlisted button i, .course-box .favorite-add button:hover i, .course-box .favorite-add.added button i {
    color: var(--color-primario);
}

.course-box .wishlist-add button i, .course-box .favorite-add button i {
    text-stroke: 1px #fff;
    -webkit-text-stroke: 1px #fff;
    font-size: 16px;
    color: #686f7a;
}

.course-box .instructor-img-hover {
    position: absolute;
    display: flex;
    flex-direction: column;
    text-align: left;
    top: 10px;
    left: 10px;
    z-index: 1;
    opacity: 0;
    visibility: hidden;
    transition: 0.2s;
    -webkit-transition: 0.2s;
    -ms-webkit-transition: 0.2s;
}

.course-box .instructor-img-hover img {
    border: 3px solid #fff;
    width: 48px;
    height: 48px;
    margin-bottom: 8px;
}

.course-box .instructor-img-hover span {
    color: #fff;
    font-weight: 600;
    font-size: 13px;
    text-stroke: .4px #fff;
    -webkit-text-stroke: .4px #fff
}

.course-box:hover .instructor-img-hover, .course-box:hover .course-image:before {
    opacity: 1;
    visibility: visible;
}

.webui-popover {
    box-shadow: 0 4px 16px rgba(20, 23, 28, .25);
    border-color: transparent;
    border-radius: 2px;
}

.course-popover-content .last-updated {
    margin: 10px 0;
    font-size: 13px;
}

.course-popover-content .course-title a {
    visibility: visible;
    display: block!important;
    display: -webkit-box!important;
    -webkit-line-clamp: 3;
    -moz-line-clamp: 3;
    -ms-line-clamp: 3;
    -o-line-clamp: 3;
    line-clamp: 3;
    -webkit-box-orient: vertical;
    -moz-box-orient: vertical;
    -ms-box-orient: vertical;
    -o-box-orient: vertical;
    box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: normal;
    font-size: 18px;
    font-weight: 600;
    line-height: 1.33;
    letter-spacing: -.3px;
    color: #505763;
}

.course-popover-content .course-title a:hover {
    text-decoration: underline;
}

.course-popover-content .course-category {
    color: #686f7a;
    font-size: 11px;
    margin-top: 7px;
}

.course-popover-content .course-category .course-badge {
    margin-right: 10px;
    box-shadow: 0 0 0;
}

.course-popover-content .course-meta span {
    margin-right: 10px;
    font-size: 13px;
    color: #7a7d82;
}

.course-popover-content .course-meta span i {
    font-size: 12px;
    margin-right: 5px;
}

.course-popover-content .course-meta {
    padding: 5px 0;
}

.course-popover-content .course-subtitle {
    display: block!important;
    display: -webkit-box!important;
    -webkit-line-clamp: 3;
    -moz-line-clamp: 3;
    -ms-line-clamp: 3;
    -o-line-clamp: 3;
    line-clamp: 3;
    -webkit-box-orient: vertical;
    -moz-box-orient: vertical;
    -ms-box-orient: vertical;
    -o-box-orient: vertical;
    box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: normal;
    visibility: visible;
    font-size: 15px;
    line-height: 1.53;
    letter-spacing: -.2px;
    color: #686f7a;
    padding-top: 10px;
}

.course-popover-content .what-will-learn {
    margin-top: 15px;
}

.course-popover-content .what-will-learn ul {
    margin: 0;
    padding: 0;
    list-style: none;
}

.course-popover-content .what-will-learn ul li {
    position: relative;
    padding-left: 20px;
    margin-bottom: 10px;
    max-height: 54px;
    visibility: visible;
    display: block!important;
    display: -webkit-box!important;
    -webkit-line-clamp: 3;
    -moz-line-clamp: 3;
    -ms-line-clamp: 3;
    -o-line-clamp: 3;
    line-clamp: 3;
    -webkit-box-orient: vertical;
    -moz-box-orient: vertical;
    -ms-box-orient: vertical;
    -o-box-orient: vertical;
    box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: normal;
    font-size: 13px;
    letter-spacing: -.2px;
    color: #686f7a;
}

.course-popover-content .what-will-learn ul li:before {
    content: ".";
    font-weight: 900;
    position: absolute;
    left: 0;
    top: 2px;
    font-size: 30px;
    line-height: 0;
    color: #dedfe0;
}

.course-popover-content .popover-btns {
    margin-top: 50px;
    padding-right: 65px;
    position: relative;
    margin-bottom: 15px;
}

.course-popover-content .popover-btns .add-to-cart-btn {
    width: 100%;
    padding: 16px 12px;
}

.addedToCart {
    color: var(--color-primario);
    background-color: #ffffff;
    border-color: var(--color-primario);
}

.addedToCart:hover {
    color: var(--color-primario);
    background-color: #ffffff;
    border-color: var(--color-primario);
}

.course-popover-content .popover-btns .wishlist-btn {
    position: absolute;
    right: 8px;
    top: 8px;
    border: none;
    background: none;
    font-size: 24px;
}

.course-popover-content .popover-btns .wishlist-btn i {
    color: transparent;
    text-stroke: 1px var(--color-primario);
    -webkit-text-stroke: 1px var(--color-primario);
}

.course-popover-content .popover-btns .wishlist-btn.active i, .course-popover-content .popover-btns .wishlist-btn:hover i {
    color: var(--color-primario);
}

.webui-popover.left>.webui-arrow, .webui-popover.left-top>.webui-arrow, .webui-popover.left-bottom>.webui-arrow {
    border-left-color: rgba(20, 23, 28, .1);
}

.webui-popover.right>.webui-arrow, .webui-popover.right-top>.webui-arrow, .webui-popover.right-bottom>.webui-arrow {
    border-right-color: #999;
    border-right-color: rgba(20, 23, 28, .1);
}

/*
course page style
*/

/*
course header
*/

section.course-header-area {
    background-color: #29303b;
    color: #fff;
    padding: 60px 0;
}

.course-header-area.duplicated {
    position: fixed;
    width: 100%;
    top: 0;
    left: 0;
    z-index: 9;
    background-color: rgba(41, 48, 59, .8);
    padding: 10px 0;
}

.course-header-area.duplicated .title {
    font-size: 20px;
    font-weight: 600;
    line-height: 28px;
    margin-bottom: 0;
}

.course-header-area.duplicated .subtitle, .course-header-area.duplicated .course-badge, .course-header-area.duplicated .created-row {
    display: none;
}

.course-header-wrap .title {
    font-size: 36px;
    line-height: 41px;
    font-weight: 600;
    margin-bottom: 10.5px;
}

.course-header-wrap .subtitle {
    font-size: 21px;
    line-height: 27px;
    margin-bottom: 7px;
}

.course-header-wrap>div>span {
    margin-right: 12px;
    margin-bottom: 7px;
    font-size: 15px;
}

.course-header-wrap .rating p {
    margin-bottom: 0;
}

.course-header-wrap .rating i {
    font-size: 14px;
    color: var(--color-terciario);;
}

.course-header-wrap a {
    color: #fff;
}

.course-header-wrap .course-badge {
    font-size: 9px !important;
}

.course-header-wrap .comment i {
    margin-right: 7px;
    font-size: 13px;
}

/*
course sidebar
*/

.course-sidebar {
    background-color: #fff;
    box-shadow: 0 0 1px 1px rgba(20, 23, 28, .1), 0 3px 1px 0 rgba(20, 23, 28, .1);
    border-radius: 4px;
    color: #505763;
    padding: 3px;
    position: relative;
    margin-top: -250px;
    z-index: 10;
}

.course-sidebar.fixed {
    position: fixed;
    margin-top: 0;
    width: 350px;
}

.course-sidebar.fixed .preview-video-box, .course-sidebar.bottom .preview-video-box {
    display: none;
}

.course-sidebar.bottom {
    margin-top: 0;
}

.preview-video-box a {
    display: block;
    color: #fff;
    overflow: hidden;
    position: relative;
}

.preview-video-box .preview-text {
    position: absolute;
    width: 100%;
    bottom: 10px;
    left: 0;
    text-align: center;
    height: auto;
    font-size: 15px;
    font-weight: 700;
}

.preview-video-box .play-btn {
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    position: absolute;
    background: url('../img/icons/icon-play.svg') no-repeat;
    background-size: auto 50%;
    background-position: 50%;
    visibility: visible;
    -webkit-transition: -webkit-transform .15s ease-in-out;
    -moz-transition: -moz-transform .15s ease-in-out;
    -o-transition: -o-transform .15s ease-in-out;
    transition: transform .15s ease-in-out;
}

.preview-video-box a:hover>.play-btn {
    -webkit-transform: scale(1.2);
    -ms-transform: scale(1.2);
    -o-transform: scale(1.2);
    transform: scale(1.2);
}

.course-sidebar-text-box {
    padding: 15px 30px;
}

.course-sidebar-text-box .price .current-price {
    color: #505763;
    font-size: 36px;
    font-weight: 700;
    line-height: 40px;
    margin-right: 10px;
}

.course-sidebar-text-box .price span {
    vertical-align: middle;
    color: #a1a7b3;
    margin-right: 10px;
}

.course-sidebar-text-box .price .original-price {
    text-decoration: line-through;
}

.course-sidebar-text-box .offer-time {
    color: #208058;
    font-size: 14px;
    margin-bottom: 10px;
}

.course-sidebar-text-box .offer-time i {
    margin-right: 7px;
}

.course-sidebar-text-box .buy-btns .btn {
    display: block;
    width: 100%;
    margin: 0;
    border-radius: 2px;
    margin-top: 13px;
    padding: 15px 12px;
    font-size: 15px;
    font-weight: 600;
    margin-bottom: 10px;
}

.course-sidebar-text-box .buy-btns .btn-add-wishlist {
    color: #fff;
    background-color: #7E57C2;
    border-color: #673AB7;
}

.course-sidebar-text-box .buy-btns .btn-add-wishlist:hover, .course-sidebar-text-box .buy-btns .btn-add-wishlist:focus {
    background-color: #673AB7;
    border-color: var(--color-secundario);
}

.course-sidebar-text-box .buy-btns .btn-buy-now {
    color: #fff;
    background-color: var(--color-primario);
    border-color: var(--color-primario);
}

.course-sidebar-text-box .buy-btns .btn-buy-now:hover, .course-sidebar-text-box .buy-btns .btn-buy-now:focus {
    background-color: var(--color-secundario);
    border-color: var(--color-secundario);
}

.course-sidebar-text-box .buy-btns .btn-add-cart {
    background: transparent;
    border-color: #505763;
    color: #686f7a;
}

.course-sidebar-text-box .buy-btns .btn-add-cart:hover, .course-sidebar-text-box .buy-btns .btn-add-cart:focus {
    background-color: #f2f3f5;
}

.course-sidebar-text-box .money-back {
    display: block;
    font-size: 12px;
    font-weight: 400;
    margin-bottom: 12px;
    margin-top: 10px;
}

.course-sidebar-text-box .includes {
    margin-bottom: 15px;
}

.course-sidebar-text-box .includes ul {
    margin: 0;
    padding: 0;
    list-style: none;
}

.course-sidebar-text-box .includes ul li {
    font-size: 13px;
    padding: 3px;
}

.course-sidebar-text-box .includes ul li i {
    width: 19px;
    font-size: 12px;
}

/*
course content
*/

.view-more-parent {
    position: relative;
    overflow: hidden;
}

.view-more {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    background: linear-gradient(hsla(0, 0%, 100%, 0), hsla(0, 0%, 100%, .95), #fff);
    display: block;
    padding: 30px 3px 3px 3px;
    color: #007791;
    cursor: pointer;
    z-index: 5;
}

.view-less {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    display: block;
    padding: 3px 3px 3px 3px;
    color: #007791;
    cursor: pointer;
}

.view-more-parent.expanded {
    max-height: none;
    overflow: visible;
}

.view-more-parent.has-hide {
    padding-bottom: 30px;
}

.description-box {
    max-height: 260px;
    margin-top: 40px;
    margin-bottom: 40px;
}

.description-box ul {
    list-style: disc;
}

.description-box .description-title {
    font-size: 22px;
    font-weight: 600;
    margin: 0 0 10px;
}

.description-box .audience {
    margin-top: 20px;
}

.description-box .audience .audience-title {
    font-size: 18px;
    font-weight: 600;
    margin: 0 0 10px;
}

.description-box .audience ul {
    margin-bottom: 0;
}

.what-you-get-box {
    background-color: #f9f9f9;
    border: 1px solid #dedfe0;
    padding: 10px 15px;
    margin-top: 40px;
}

.what-you-get-box .what-you-get-title {
    font-size: 22px;
    font-weight: 600;
    margin: 0 0 10px;
}

.what-you-get-box ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    flex-wrap: wrap;
}

.what-you-get-box ul li {
    display: flex;
    margin-bottom: 10px;
    width: 45%;
    padding-left: 26px;
    font-size: 15px;
    position: relative;
}

.what-you-get-box ul li:before {
    font-family: Font Awesome\ 5 Free;
    font-weight: 900;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    display: inline-block;
    font-style: normal;
    font-variant: normal;
    text-rendering: auto;
    line-height: 1;
    content: "\f00c";
    color: #a1a7b3;
    font-size: 14px;
    position: absolute;
    left: 0;
    top: 4px;
}

.requirements-box {
    margin-top: 40px;
}

.requirements-box .requirements-title {
    font-size: 22px;
    font-weight: 600;
    margin: 0 0 10px;
}

.requirements-box .requirements__list {
    list-style: disc;
    margin-left: 10px;
    padding-left: 10px;
    margin-bottom: 0;
}



.requirements-box .requirements__list li:not(:last-child) {
    margin-bottom: 10px;
}

.compare-box {
    max-height: 580px;
    margin-bottom: 40px;
}

.compare-box .compare-title {
    font-size: 22px;
    font-weight: 600;
    margin: 0 0 15px;
}

.course-comparism-item .item-image {
    height: auto;
    width: 18%;
    position: relative;
}

.course-comparism-item {
    color: #29303b;
    padding: 15px;
}

.course-comparism-item-container {
    border-top: 1px solid #dedfe0;
}

.course-comparism-item-container a {
    display: block;
    transition: .1s;
    -webkit-transition: .1s;
    -ms-webkit-transition: .1s;
}

.course-comparism-item-container a:hover {
    background-color: #dedfe0;
}

.course-comparism-item-container.this-course {
    border-bottom: 2px solid #dedfe0;
}

.course-comparism-item-container.this-course .course-comparism-item-this-text {
    font-size: 11px;
    margin-left: 15px;
    text-transform: uppercase;
    margin-bottom: -5px;
    margin-top: 5px;
}

.course-comparism-item .item-image .item-duration {
    position: absolute;
    width: 100%;
    bottom: 0;
    text-align: center;
    left: 0;
    background-color: hsla(0, 0%, 100%, .95);
}

.course-comparism-item .item-title {
    padding-left: 15px;
    width: 39%;
}

.course-comparism-item .item-title .title {
    font-size: 15px;
    font-weight: 700;
    word-break: break-word;
}

.course-comparism-item .item-title .updated-time {
    color: #686f7a;
    font-size: 13px;
    margin-top: 3px;
}

.course-comparism-item .item-details {
    position: relative;
    width: 43%;
    padding-left: 15px;
}

.course-comparism-item .item-details .wishlist-btn {
    position: absolute;
    right: 0;
    top: 0;
}

.course-comparism-item .item-details .item-rating i {
    color: var(--color-terciario);;
    margin-right: 4px;
    font-size: 14px;
}

.course-comparism-item .item-details .wishlist-btn button {
    padding: 0;
    margin: 0;
    border: 0;
    background: 0;
    font-size: 17px;
    color: var(--color-primario);
    cursor: pointer;
}

.course-comparism-item .item-details .wishlist-btn button:hover>i:before {
    font-weight: 900;
}

.course-comparism-item .item-details .item-price {
    position: absolute;
    top: 0;
    right: 38px;
    display: flex;
    flex-direction: column-reverse;
    text-align: right;
}

.course-comparism-item .item-details .item-price .current-price {
    color: #29303b;
    font-size: 18px;
    font-weight: 600;
}

.course-comparism-item .item-details .item-price .original-price {
    color: #686f7a;
    font-weight: 400;
    font-size: 13px;
    text-decoration: line-through;
}

.course-comparism-item .item-details .enrolled-student {
    margin-left: 25px;
}

.course-comparism-item .item-details .enrolled-student i {
    margin-right: 2px;
    color: #cacbcc;
    font-size: 14px;
}

.more-by-instructor-box {
    background-color: #f9f9f9;
    border: 1px solid #dedfe0;
    margin-bottom: 50px;
    padding: 10px 8px;
}

.more-by-instructor-box .more-by-instructor-title {
    font-size: 22px;
    font-weight: 600;
    margin: 0 0 10px 7px;
}

.about-instructor-box .about-instructor-title {
    display: block;
    font-size: 22px;
    font-weight: 600;
    margin: 0 0 20px;
}

.about-instructor-box .about-instructor-image img {
    width: 96px;
    height: 96px;
    border-radius: 50%;
}

.about-instructor-box .about-instructor-image ul {
    padding: 0;
    margin: 0;
    list-style: none;
    margin-top: 15px;
}

.about-instructor-box .about-instructor-image ul b {
    font-weight: 600;
}

.about-instructor-box .about-instructor-image ul i {
    width: 26px;
    font-size: 13px;
}

.about-instructor-box .about-instructor-image ul li {
    margin-bottom: 5px;
}

.about-instructor-details {
    max-height: 380px;
}

.about-instructor-box {
    margin-bottom: 40px;
}

.about-instructor-details .instructor-name {
    font-size: 18px;
    font-weight: 600;
    line-height: 1.33;
    margin-bottom: 10px;
}

.about-instructor-details .instructor-title {
    font-size: 16px;
    font-weight: 600;
    line-height: 1.33;
    margin-bottom: 10px;
}

.student-feedback-box {
    margin: 50px 0;
}

.student-feedback-box .student-feedback-title {
    font-size: 22px;
    font-weight: 600;
    margin: 0 0 15px;
}

.student-feedback-box .average-rating {
    text-align: center;
    margin-top: 10px;
}

.student-feedback-box .average-rating .num {
    font-size: 72px;
    font-weight: 500;
    line-height: 1;
    margin-bottom: 10px;
}

.student-feedback-box .average-rating .rating i {
    font-size: 20px;
    color: var(--color-terciario);;
    margin-bottom: 5px;
}

.student-feedback-box .individual-rating ul {
    margin: 0;
    padding: 0;
    list-style: none;
}

.student-feedback-box .individual-rating ul li {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    margin-bottom: 10px;
}

.student-feedback-box .individual-rating ul li .progress {
    width: 70%;
    height: 20px;
    border-radius: 3px;
    background-color: #f2f3f5
}

.student-feedback-box .individual-rating ul li .progress-bar {
    border-radius: 3px;
    background-color: #a1a7b3;
}

.student-feedback-box .individual-rating .rating i {
    font-size: 14px;
    color: #dedfe0;
}

.student-feedback-box .individual-rating .rating i.filled {
    color: var(--color-terciario);;
}

.student-feedback-box .individual-rating li>div:not(.progress) {
    padding-left: 15px;
}

.student-feedback-box .individual-rating li>div:not(.progress) span:not(.rating) {
    text-align: center;
    padding-left: 10px;
    color: #007791;
}

.student-feedback-box .reviews .reviews-title {
    font-size: 18px;
    font-weight: 600;
    padding: 0 0 20px;
}

.student-feedback-box .reviews ul {
    list-style: none;
    padding: 0;
    margin: 0;
    padding-bottom: 30px;
}

.student-feedback-box .reviews .reviewer-details img {
    height: 46px;
    width: 46px;
    border-radius: 50%;
    margin-right: 20px;
}

.student-feedback-box .reviews .reviewer-details .review-time .time {
    color: #686f7a;
}

.student-feedback-box .reviews ul li {
    padding: 30px 0;
    border-top: 1px solid #dedfe0;
}

.student-feedback-box .reviews ul li:last-child {
    border-bottom: 1px solid #dedfe0;
}

.student-feedback-box .reviews .review-details .rating i {
    color: #dedfe0;
    margin-bottom: 15px;
}

.student-feedback-box .reviews .review-details .rating i.filled {
    color: var(--color-terciario);;
}

.student-feedback-box .reviews .review-details .review-text {
    color: #505763;
    margin-bottom: 10px;
    font-size: 16px;
}

.student-feedback-box .reviews {
    margin-top: 30px;
}

.reviews .more-reviews-btn {
    text-align: center;
}

.reviews .more-reviews-btn button {
    border-radius: 2px;
    border: 2px solid #007791;
    color: #007791;
    background: #fff;
    padding: 11px 12px;
    font-size: 15px;
    font-weight: 600;
}

.reviews .more-reviews-btn button:hover, .reviews .more-reviews-btn button:focus {
    background-color: #e6f2f5;
}

.course-curriculum-box {
    margin-bottom: 40px;
}

.course-curriculum-box .course-curriculum-title .title {
    font-size: 22px;
    font-weight: 600;
    margin: 0 0 10px;
}

.course-curriculum-box .course-curriculum-title .total-time {
    width: 130px;
    display: inline-block;
    text-align: right;
}

.course-curriculum-accordion .lecture-group-title .total-time {
    width: 130px;
    display: inline-block;
    text-align: right;
}

.course-curriculum-accordion .lecture-group-title .title {
    max-width: 60%;
    font-weight: 600;
}

.course-curriculum-accordion .lecture-group-title {
    position: relative;
    padding: 10px 30px 10px 45px;
    background: #f9f9f9;
    border: 1px solid #e8e9eb;
    cursor: pointer;
    height: auto;
    margin-top: 3px;
    color: #505763;
}

.course-curriculum-box .course-curriculum-title {
    padding-right: 31px;
}

.course-curriculum-accordion .lecture-group-title:before {
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    display: inline-block;
    font-style: normal;
    font-variant: normal;
    text-rendering: auto;
    line-height: 1;
    font-family: Font Awesome\ 5 Free;
    font-weight: 900;
    position: absolute;
    left: 22px;
    font-size: 10px;
    top: 16px;
    color: #007791;
}

.course-curriculum-accordion .lecture-group-title[aria-expanded="false"]:before {
    content: "\f067";
}

.course-curriculum-accordion .lecture-group-title[aria-expanded="true"]:before {
    content: "\f068";
}

.course-curriculum-accordion .lecture-group-title[aria-expanded="true"] .total-lectures {
    display: none;
}

.course-curriculum-accordion .lecture-list ul {
    margin: 0;
    padding: 0;
    list-style: none;
}

.course-curriculum-accordion .lecture-list .lecture {
    padding: 12px 30px 12px 73px;
    position: relative;
    border-bottom: 1px solid #e8e9eb;
    border-left: 1px solid #e8e9eb;
    border-right: 1px solid #e8e9eb;
    color: #686f7a;
}

.course-curriculum-accordion .lecture-list .lecture .lecture-title {
    width: 50%;
    display: inline-block;
    transition: 0.3s;
    -webkit-transition: 0.3s;
    -ms-webkit-transition: 0.3s;
}

.course-curriculum-accordion .lecture-list .lecture .lecture-time {
    width: 100px;
    text-align: right;
}

.course-curriculum-accordion .lecture-list .lecture:before {
    font-family: Font Awesome\ 5 Free;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    display: inline-block;
    font-style: normal;
    font-variant: normal;
    text-rendering: auto;
    line-height: 1;
    content: "\f144";
    position: absolute;
    left: 45px;
    opacity: 0.3;
    font-weight: 900;
    font-size: 13px;
    top: 17px;
}

.course-curriculum-accordion .lecture-list .lecture.has-preview {
    color: var(--color-primario);
}

.course-curriculum-accordion .lecture-list .lecture.has-preview .lecture-title, .course-curriculum-accordion .lecture-list .lecture.has-preview .lecture-preview {
    cursor: pointer;
}

.course-curriculum-accordion .lecture-list .lecture.has-preview .lecture-title:hover {
    color: #003845;
}

/*
category page
*/

section.category-header-area {
    padding: 40px 0 30px;
    background: #29303b;
    color: #fff;
}

section.category-header-area .category-name {
    font-size: 30px;
    font-weight: 400;
    line-height: 1.287;
    margin: 0;
}

.breadcrumb {
    padding: 0;
    margin: 0;
    background: none;
    margin-bottom: 5px;
}

.breadcrumb .breadcrumb-item a, .breadcrumb .breadcrumb-item {
    color: #fff;
}

.breadcrumb .breadcrumb-item a:hover {
    color: #dedfe0;
}

.breadcrumb .breadcrumb-item a i {
    color: #a1a7b3;
    font-size: 13px;
}

.breadcrumb-item+.breadcrumb-item::before {
    color: #fff;
}

section.category-course-list-area {
    padding-bottom: 50px;
}

.category-filter-box {
    padding: 35px 0;
    border-bottom: 1px solid #e8e9eb;
    margin-bottom: 30px;
}

.filter-box .btn {
    border-radius: 2px;
    border-color: #007791;
    color: #007791;
    font-weight: 600;
    font-size: 15px;
    padding: 10px 12px;
    min-width: 60px;
    background: transparent;
}

.filter-box .btn:not(.all-btn) {
    margin-left: 10px;
}

.filter-box .btn:hover, .filter-box .btn:focus {
    background: #fff !important;
    color: #007791 !important;
    border-color: #007791 !important;
}

.filter-box .btn[aria-expanded="true"] {
    background-color: #76c5d6 !important;
}

.filter-box .dropdown-menu {
    box-shadow: 0 4px 16px rgba(20, 23, 28, .25);
    border-color: #fff;
    border-radius: 2px;
    max-height: 365px;
    overflow-y: auto;
}

.filter-box .dropdown-menu .dropdown-item {
    color: #505763;
    padding: 5px 12px;
    font-weight: 400;
    line-height: 1.43;
    font-size: 15px;
}

.filter-box .dropdown-menu .dropdown-item:hover, .filter-box .dropdown-menu .dropdown-item:focus {
    background-color: #f2f3f5;
    color: inherit;
}

.filter-box .reset-btn {
    background-color: transparent;
    border-color: transparent;
}

.filter-box .reset-btn:hover {
    background-color: transparent!important;
    border-color: transparent!important;
}

.filter-box .reset-btn:disabled {
    color: #a1a7b3!important;
    cursor: not-allowed;
}

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

.course-box-2 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    border: 1px solid #dedfe0;
    border-radius: 2px 2px 0 0;
    min-height: 148px;
    background-color: #fff;
}

.course-box-2 .course-image {
    width: 26%;
}

.course-box-2 .course-details {
    width: 50%;
    padding: 10px 30px;
}

.course-box-2 .course-price-rating {
    width: 24%;
    text-align: right;
    -ms-flex-item-align: end;
    align-self: flex-end;
    padding: 10px 25px 15px;
}

.category-course-list ul li {
    margin-bottom: 30px;
}

.course-box-2 .course-price-rating .current-price {
    font-size: 18px;
    font-weight: 700;
    color: #29303b;
}

.course-box-2 .course-price-rating .original-price {
    color: #686f7a;
    font-size: 15px;
    font-weight: 400;
    margin-left: 5px;
    text-decoration: line-through;
}

.course-box-2 .course-price-rating .rating i {
    /* color: var(--color-terciario);; */
    font-size: 13px;
}

.course-box-2 .course-price-rating .rating .average-rating {
    font-size: 13px;
    color: #686f7a;
}

.course-box-2 .course-price-rating .rating-number {
    font-size: 13px;
    color: #686f7a;
}

.course-box-2 .course-details .course-title {
    color: #29303b;
    display: block;
    font-weight: 700;
    margin-bottom: 4px;
}

.course-box-2 .course-details a:hover {
    text-decoration: underline;
}

.course-box-2 .course-details .course-instructor {
    display: block;
    color: #686f7a;
    font-size: 11px;
    margin-bottom: 6px;
}

.course-box-2 .course-details .course-subtitle {
    color: #505763;
    font-size: 13px;
    margin-bottom: 20px;
}

.course-box-2 .course-details .course-meta span {
    font-size: 13px;
    margin-right: 10px;
    color: #686f7a;
}

.course-box-2 .course-details .course-meta {
    padding-top: 5px;
}

.course-box-2 .course-details .course-meta span i {
    opacity: 0.5;
    font-size: 14px;
    margin-right: 4px;
}

/*
Instructor page
*/

section.instructor-header-area {
    background-color: #007791;
    color: #fff;
    padding: 34px 0;
}

section.instructor-header-area .instructor-name {
    font-size: 30px;
    font-weight: 400;
    line-height: 1.287;
    margin: 0;
}

section.instructor-header-area .instructor-title {
    font-size: 18px;
    font-weight: 400;
    line-height: 1.287;
    margin: 7px 0 0;
}

section.instructor-details-area {
    padding: 30px 0;
}

.instructor-left-box .instructor-image img {
    border-radius: 50%;
    height: 120px;
    width: 120px;
}

.instructor-left-box .instructor-social ul {
    margin: 0;
    padding: 0;
    margin-top: 25px;
    list-style: none;
}

.instructor-left-box .instructor-social ul li {
    display: inline-block;
    padding: 0 6px;
    font-size: 19px;
}

.biography-content-box {
    max-height: 400px;
    margin-bottom: 40px;
}

.instructor-right-box .instructor-stat-box ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.instructor-right-box .instructor-stat-box ul li {
    display: inline-block;
    border-left: 1px solid rgba(41, 48, 59, .25);
    padding: 0 15px;
    text-align: left;
}

.instructor-right-box .instructor-stat-box ul li .small {
    font-size: 86%;
}

.instructor-right-box .instructor-stat-box ul li .num {
    font-size: 24px;
    font-weight: 300;
}

section.instructor-course-list-area {
    background-color: #f7f8fa;
    padding: 40px 0;
}

section.instructor-course-list-area .section-title {
    font-size: 18px;
    margin-bottom: 20px;
}

section.instructor-course-list-area .container {
    max-width: 940px;
}

ul.pagination {
    margin-top: 25px;
}

ul.pagination .page-item.disabled .page-link {
    color: #a1a7b3;
}

ul.pagination .page-item.active a, ul.pagination .page-item.active .page-link {
    background-color: #007791;
    border-color: #007791;
    color: #fff;
}

ul.pagination .page-item a, ul.pagination .page-item .page-link {
    color: #007791;
    padding: 10px 15px;
    font-size: 17px;
    position: relative;
    display: block;
    margin-left: -1px;
    line-height: 1.25;
    background-color: #fff;
    border: 1px solid #dee2e6;
}

ul.pagination .page-item a:hover, ul.pagination .page-item .page-link:hover {
    background-color: #e6f2f5;
    border-color: #007791;
    position: relative;
    z-index: 1;
}

/*
Notifications page
*/

section.page-header-area {
    padding: 40px 0 30px;
    background: #505763;
    color: #fff;
}

section.page-header-area .page-title {
    font-size: 30px;
    font-weight: 400;
    line-height: 1.287;
    margin: 0;
}

section.page-header-area .page-subtitle {
    font-size: 18px;
    font-weight: 400;
    line-height: 1.287;
    margin: 7px 0 5px;
}

.notifications-list-area .notifications-footer .mark-all-read {
    border: 0;
    background: none;
    color: #007791;
}

.notifications-list-area .notifications-footer .mark-all-read:hover {
    color: #003845;
}

.notifications-list-area .notifications-footer {
    padding: 15px 0;
}

.notifications-list-area .notification-list {
    max-height: 415px;
    overflow-y: auto;
    margin-top: 40px;
}

.notifications-list-area .notification-list li {
    padding: 15px;
}

.notifications-list-area .notification-list .notification-details .notification-text {
    width: 100%;
}

.notifications-list-area .notification-list .notification-details {
    padding-right: 15px;
}

.notifications-list-area .notification-list .notification-details .notification-time {
    margin-top: 10px;
}

/*
my courses - wishlist page
*/

section.page-header-area.my-course-area {
    padding-bottom: 0;
}

section.page-header-area.my-course-area ul {
    margin: 0;
    padding: 0;
    list-style: none;
    margin-top: 20px;
}

section.page-header-area.my-course-area ul li {
    display: inline-block;
    margin-right: 30px;
}

section.page-header-area.my-course-area ul li a {
    padding: 0 0 5px;
    border-bottom: 6px solid hsla(0, 0%, 100%, 0);
    color: #fff;
    display: block;
}

section.page-header-area.my-course-area ul li.active a, section.page-header-area.my-course-area ul li a:hover {
    border-bottom-color: hsla(0, 0%, 100%, .7);
}

section.my-courses-area .my-course-search-bar .input-group {
    width: 220px;
    margin-left: auto;
}

section.my-courses-area {
    padding: 40px 0;
}

.my-courses-area .my-course-search-bar input {
    font-size: 16px;
    padding: 10px 12px;
    border-radius: 0;
    background-color: #fff;
    border: 1px solid #cacbcc;
}

.my-courses-area .my-course-search-bar .input-group-append button {
    background: #f2f3f5;
    border-color: #dedfe0;
    color: #a1a7b3;
    border-top-right-radius: 2px;
    border-bottom-right-radius: 2px;
}

.my-courses-area .my-course-search-bar .input-group-append button:hover, .my-courses-area .my-course-search-bar .input-group-append button:focus, .my-courses-area .my-course-search-bar input:focus+.input-group-append button {
    background: #007791;
    color: #fff;
    border-color: #007791;
}

.my-courses-area .row.no-gutters {
    margin-top: 50px;
    margin-left: -10px;
    margin-right: -10px;
}

.my-courses-area .course-box-wrap {
    padding: 0 10px;
}

.my-course-filter-bar.filter-box {
    position: relative;
    padding-top: 30px;
}

.my-course-filter-bar.filter-box>span {
    position: absolute;
    top: 0;
    left: 0;
    color: #686f7a;
    font-size: 13px;
}

.edit-rating-modal .m-progress-bar-wrapper {
    background: #e8e9eb;
}

.edit-rating-modal .m-progress-bar {
    height: 6px;
    background: #a1a7b3;
    border-radius: 0 3px 3px 0;
}

.edit-rating-modal .rating-title {
    font-weight: 300;
    font-size: 24px;
    color: #29303b;
}

.edit-rating-modal .modal-body {
    padding-top: 50px;
    padding-bottom: 50px;
}

.modal-course-preview-box {
    padding-left: 50px;
}

.modal-course-preview-box .card-title {
    line-height: 24px;
    height: 48px;
    color: #505763;
    display: block!important;
    display: -webkit-box!important;
    -webkit-line-clamp: 2;
    -moz-line-clamp: 2;
    -ms-line-clamp: 2;
    -o-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    -moz-box-orient: vertical;
    -ms-box-orient: vertical;
    -o-box-orient: vertical;
    box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: normal;
    font-size: 18px;
}

.modal-course-preview-box .card-text {
    line-height: 24px;
    height: 48px;
    color: #505763;
    display: block!important;
    display: -webkit-box!important;
    -webkit-line-clamp: 2;
    -moz-line-clamp: 2;
    -ms-line-clamp: 2;
    -o-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    -moz-box-orient: vertical;
    -ms-box-orient: vertical;
    -o-box-orient: vertical;
    box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: normal;
}

.edit-rating-modal .modal-footer button {
    padding: 16px 12px;
    font-size: 15px;
    line-height: 1.35135;
    border-radius: 2px;
    background-color: var(--color-primario);
    border-color: var(--color-primario);
    font-weight: 600;
}

.edit-rating-modal .modal-footer button:hover, .edit-rating-modal .modal-footer button:focus {
    background-color: var(--color-secundario) !important;
    border-color: var(--color-secundario) !important;
}

.edit-rating-modal .modal-footer button.previous {
    color: #007791;
    background-color: #fff;
    border-color: #007791;
}

.edit-rating-modal .modal-footer button.previous:hover, .edit-rating-modal .modal-footer button.previous:focus {
    background-color: #e6f2f5 !important;
    border-color: #007791 !important;
}

.your-rating {
    border: none;
    float: left;
}

.your-rating>input {
    display: none;
}

.your-rating>label:before {
    margin: 8px;
    font-size: 40px;
    font-family: "Font Awesome 5 Free";
    display: inline-block;
    content: "\f005";
    font-weight: 900
}

.your-rating>.half:before {
    content: "\f089";
    position: absolute;
}

.your-rating>label {
    color: #dedfe0;
    float: right;
}

.your-rating>input:checked~label, .your-rating:not(:checked)>label:hover, .your-rating:not(:checked)>label:hover~label {
    color: var(--color-terciario);;
}

.your-rating>input:checked+label:hover, .your-rating>input:checked~label:hover, .your-rating>label:hover~input:checked~label, .your-rating>input:checked~label:hover~label {
    color: var(--color-terciario);;
}

.edit-rating-modal .rating {
    margin-bottom: 30px;
    margin-top: 20px;
}

.edit-rating-modal .rating i {
    font-size: 30px;
}

.edit-rating-modal .modal-rating-comment-box textarea {
    width: 100%;
    height: 210px;
    resize: none;
    border-radius: 2px;
}

.edit-rating-modal .modal-rating-comment-box textarea:focus {
    border-color: #76c5d6;
}

/*
cart page
*/

section.cart-list-area {
    margin-top: 50px;
    margin-bottom: 70px;
}

.in-cart-box>.title, .wishlisted-box>.title {
    font-size: 18px;
    margin-bottom: 10px;
    color: #29303b;
}

.in-cart-box .cart-course-list, .wishlisted-box .cart-course-list {
    padding: 0;
    margin: 0;
    list-style: none;
    -webkit-box-shadow: 0 0 2px #dedfe0;
    box-shadow: 0 0 2px #dedfe0;
    margin-bottom: 60px;
}

.in-cart-box .cart-course-list li:not( :first-child), .wishlisted-box .cart-course-list li:not( :first-child) {
    border-top: 1px solid #f1f1f1;
}

.cart-course-wrapper {
    padding: 10px;
    display: flex;
    justify-content: space-between;
    background-color: #fff;
}

.cart-course-wrapper .image {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 17%;
    flex: 0 0 17%;
    max-width: 17%;
}

.cart-course-wrapper .details {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 53%;
    flex: 0 0 53%;
    max-width: 53%;
    padding-left: 10px;
}

.cart-course-wrapper .details .name {
    display: block!important;
    display: -webkit-box!important;
    -webkit-line-clamp: 2;
    -moz-line-clamp: 2;
    -ms-line-clamp: 2;
    -o-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    -moz-box-orient: vertical;
    -ms-box-orient: vertical;
    -o-box-orient: vertical;
    box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: normal;
    margin-bottom: 0;
    max-height: 37px;
    color: #29303b;
    line-height: 1.2;
    font-weight: 700;
}

.cart-course-wrapper .details .instructor {
    display: block!important;
    display: -webkit-box!important;
    -webkit-line-clamp: 2;
    -moz-line-clamp: 2;
    -ms-line-clamp: 2;
    -o-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    -moz-box-orient: vertical;
    -ms-box-orient: vertical;
    -o-box-orient: vertical;
    box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: normal;
    max-height: 36px;
    font-size: 13px;
    color: #686f7a;
}

.cart-course-wrapper .move-remove {
    text-align: right;
    padding-left: 10px;
    -webkit-box-flex: 0;
    -ms-flex: 0 0 15%;
    flex: 0 0 15%;
    max-width: 15%;
}

.cart-course-wrapper .price {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 15%;
    flex: 0 0 15%;
    max-width: 15%;
    text-align: right;
    padding-right: 25px;
    position: relative;
}

.cart-course-wrapper .move-remove div {
    color: #007791;
    cursor: pointer;
    font-size: 13px;
    margin-bottom: 3px;
}

.cart-course-wrapper .move-remove div:hover {
    color: #003845;
}

.cart-course-wrapper .price .current-price {
    color: var(--color-primario);
    font-weight: 900;
}

.cart-course-wrapper .price .original-price {
    text-decoration: line-through;
    color: #686f7a;
}

.cart-course-wrapper .price .coupon-tag {
    position: absolute;
    top: 2px;
    right: 0;
    color: var(--color-primario);
    font-size: 14px;
}

.cart-sidebar .total {
    color: #686f7a;
    font-size: 18px;
}

.cart-sidebar .total-price {
    font-size: 36px;
    line-height: 49px;
    color: var(--color-primario);
    font-weight: 600;
}

.cart-sidebar .total-original-price {
    color: #686f7a;
    margin-bottom: 12px;
}

.cart-sidebar .total-original-price .original-price {
    text-decoration: line-through;
    margin-right: 10px;
}

.cart-sidebar .checkout-btn {
    font-size: 15px;
    line-height: 1.35135;
    border-radius: 2px;
    color: #fff;
    background-color: var(--color-primario);
    border-color: var(--color-primario);
    font-weight: 600;
    padding: 16px 12px;
}

.cart-sidebar .checkout-btn:hover, .cart-sidebar .checkout-btn:focus {
    background-color: var(--color-secundario) !important;
    border-color: var(--color-secundario) !important;
}

.cart-sidebar .coupon-field input {
    padding: 14px 12px;
    font-size: 12px;
    border-radius: 2px;
}

.cart-sidebar .coupon-field input:focus {
    border-color: #76c5d6;
}

.cart-sidebar .coupon-field button {
    border-radius: 2px;
    background-color: #007791;
    border-color: #007791;
    color: #fff;
    font-weight: 600;
    font-size: 15px;
}

.cart-sidebar .coupon-field button:hover, .cart-sidebar .coupon-field button:focus {
    background-color: #00576b !important;
    border-color: #00576b !important;
}

.cart-sidebar .coupon-list ul {
    list-style: none;
    margin: 0;
    padding: 0;
    margin-top: 15px;
}

.cart-sidebar .coupon-list ul li {
    font-size: 13px;
    cursor: pointer;
    color: #686f7a;
}

.cart-sidebar .coupon-list ul li:hover {
    color: var(--color-primario);
}

.cart-sidebar .coupon-list ul li i {
    font-size: 11px;
}

/*
user dashboard page
*/

section.user-dashboard-area {
    padding: 40px 0;
}

.user-dashboard-box {
    border: 1px solid #dedfe0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    background-color: #fff;
}

.user-dashboard-sidebar {
    width: 18%;
    border-right: 1px solid #dedfe0;
}

.user-dashboard-content {
    width: 82%;
}

section.user-dashboard-area {
    padding: 40px 0;
}

.user-dashboard-box {
    border: 1px solid #dedfe0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}

.user-dashboard-sidebar .user-box {
    text-align: center;
    padding: 10px;
}

.user-dashboard-sidebar .user-box img {
    height: 118px;
    width: 118px;
    border-radius: 50%;
    margin-bottom: 15px;
}

.user-dashboard-sidebar .user-box .name {
    font-size: 17px;
    font-weight: 700;
    margin-bottom: 10px;
}

.user-dashboard-sidebar .user-dashboard-menu ul {
    padding: 0;
    margin: 0;
    list-style: none;
}

.user-dashboard-sidebar .user-dashboard-menu ul a {
    display: block;
    padding: 4px 15px;
}

.user-dashboard-sidebar .user-dashboard-menu ul .active a {
    background: #a1a7b3;
    color: #fff;
}

.user-dashboard-content .content-title-box {
    text-align: center;
    border-bottom: 1px solid #dedfe0;
    padding: 20px;
}

.user-dashboard-content .content-title-box .title {
    color: #29303b;
    font-size: 22px;
    font-weight: 700;
}

.user-dashboard-content .content-title-box .subtitle {
    font-size: 15px;
    line-height: 25px;
    font-weight: 300;
    color: #29303b;
}

.user-dashboard-content .content-update-box {
    border-top: 1px solid #dedfe0;
    padding: 20px;
    text-align: center;
}

.user-dashboard-content .content-update-box button {
    color: #fff;
    background-color: var(--color-primario);
    border-color: var(--color-primario);
    padding: 11px 12px;
    font-size: 15px;
    border-radius: 2px;
    line-height: 1.35135;
    font-weight: 600;
}

.user-dashboard-content .content-box .form-group {
    padding: 10px 142px;
    margin-bottom: 0;
}

.user-dashboard-content .content-box .form-group .input-group-text {
    border: 1px solid #cacbcc;
    border-radius: 2px;
}

.user-dashboard-content .content-box .form-group .custom-select {
    padding: 11px 12px;
    border-radius: 2px;
    height: auto;
}

.user-dashboard-content .content-box .form-group .form-control {
    font-size: 16px;
    padding: 10px 12px;
    border: 1px solid #cacbcc;
    border-radius: 2px;
}

.user-dashboard-content .content-box .input-group>.input-group-prepend:not(:first-child)>.input-group-text {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
}

.user-dashboard-content .content-box .form-group .custom-select:focus, .user-dashboard-content .content-box .form-group input:focus {
    border: 1px solid #76c5d6;
}

.user-dashboard-content .content-box .form-group small.form-text {
    margin-top: 5px;
    margin-bottom: 10px;
    color: #5d6d86;
    font-size: 11px;
}

.user-dashboard-content .content-box .mce-tinymce, .user-dashboard-content .content-box .mce-panel, .user-dashboard-content .content-box .mce-top-part::before {
    box-shadow: none;
    border-color: #cacbcc;
}

.user-dashboard-content .content-box .mce-edit-area.mce-container {
    border-right: 1px solid #cacbcc !important;
    cursor: text;
}

.user-dashboard-content .content-box .basic-group, .user-dashboard-content .content-box .link-group, .user-dashboard-content .content-box .email-group, .user-dashboard-content .content-box .password-group {
    padding: 10px 0;
}

.user-dashboard-content .content-box .password-group {
    padding-bottom: 30px;
    border-top: 1px solid #dedfe0
}

/*
my message page
*/

.message-sender-list-box {
    padding-top: 10px;
}

.message-sender-list-box .compose-btn {
    color: #007791;
    background-color: #fff;
    border-color: #007791;
    padding: 11px 12px;
    font-size: 15px;
    border-radius: 2px;
    line-height: 1.35135;
}

.message-sender-list-box .compose-btn:hover, .message-sender-list-box .compose-btn:focus {
    background-color: #e6f2f5;
}

.message-sender-list-box .message-sender-list {
    margin: 0;
    padding: 0;
    list-style: none;
    padding: 0 10px 10px 0;
    position: relative;
    min-height: 280px;
    height: calc(100vh - 380px);
    overflow: auto;
}

.message-sender-list-box .message-sender-list .sender-image img {
    height: 24px;
    width: 24px;
    border-radius: 50%;
}

.message-sender-list-box .message-sender-list li {
    cursor: pointer;
    transition: 0.3s;
    -webkit-transition: 0.3s;
    -ms-webkit-transition: 0.3s;
    border: 1px solid transparent;
    padding: 15px;
    border-radius: 3px;
}

.message-sender-list-box .message-sender-list li.active, .message-sender-list-box .message-sender-list li:hover {
    border-color: #dedfe0;
    background-color: #fff;
}

.message-sender-list-box .message-sender-list .sender-name {
    font-size: 15px;
    font-weight: 700;
    color: #505763;
    margin-left: 15px;
}

.message-sender-list-box .message-sender-list .message-time {
    font-size: 13px;
    color: #686f7a;
}

.message-sender-list-box .message-sender-list .message-sender-head {
    margin-bottom: 10px;
}

.message-sender-list-box .message-sender-list .message-sender-body {
    padding: 0 43px;
    font-size: 13px;
    color: #686f7a;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.message-details-box {
    height: 100%;
    background: #fff;
    border-right: 1px solid #dedfe0;
    border-left: 1px solid #dedfe0;
}

.message-details-box .empty-box {
    padding-top: 55px;
}

.message-details-box .message-details .message-header a {
    display: block;
}

.message-details-box .message-details .message-header img {
    height: 40px;
    width: 40px;
    border-radius: 50%;
    margin-right: 15px;
}

.message-details-box .message-details .message-header {
    min-height: 65px;
    padding: 10px;
    border-bottom: 1px solid #dedfe0;
}

.message-details-box .message-details .message-footer {
    padding: 10px;
    border-top: 1px solid #dedfe0;
    background: #fff;
}

.message-details-box .message-details .message-content {
    background: #fff;
    padding: 10px;
    overflow: auto;
    min-height: 200px;
    height: calc(100vh - 460px);
}

.message-details-box .message-details .message-content .message-box {
    max-width: 400px;
    min-width: 190px;
    padding: 15px;
    border-radius: 2px;
    margin-bottom: 10px;
    background: #f2f3f5;
    display: inline-block;
}

.message-details-box .message-details .message-content .message-box .message {
    white-space: pre-wrap;
    color: #505763;
    font-size: 15px;
    overflow-x: auto;
}

.message-details-box .message-details .message-content .message-box .time {
    color: #686f7a;
    font-size: 13px;
    margin-bottom: 10px;
}

.message-details-box .message-details .message-content .me .message-box {
    background: rgba(230, 242, 245, .5);
}

.message-details-box .message-details .message-content .me {
    display: flex;
    justify-content: flex-end;
}

.message-details-box .message-details .message-footer textarea {
    border-radius: 2px;
    min-height: 100px;
}

.message-details-box .message-details .message-footer textarea:focus {
    border-color: #76c5d6;
}

.message-details-box .message-details .message-footer .send-btn {
    color: #fff;
    background-color: var(--color-primario);
    border-color: var(--color-primario);
    padding: 11px 12px;
    font-size: 15px;
    border-radius: 2px;
    line-height: 1.35135;
    margin-top: 15px;
    margin-bottom: 25px;
    font-weight: 600;
}

.message-details-box .message-details .message-footer .send-btn:hover, .message-details-box .message-details .message-footer .send-btn:focus {
    background-color: var(--color-secundario);
    border-color: var(--color-secundario);
}

.message-sender-list-box .message-sender-list .sender-image i {
    height: 24px;
    width: 24px;
    border-radius: 50%;
    font-size: 11px;
    line-height: 21px;
    text-align: center;
    border: 1px solid #adadad;
    color: #adadad;
}

.new-message-details .message-header {
    min-height: 65px;
    padding: 10px;
    border-bottom: 1px solid #dedfe0;
}

.new-message-details .message-header span {
    font-weight: 700;
    color: #29303b;
    vertical-align: middle;
}

.new-message-details .message-header i {
    font-size: 17px;
    height: 40px;
    width: 40px;
    line-height: 37px;
    text-align: center;
    border: 1px solid #adadad;
    border-radius: 50%;
    color: #adadad;
    margin-right: 15px;
    margin-left: 10px;
}

.new-message-details .message-body {
    padding: 10px;
}

.new-message-details .message-body .cancel-btn {
    border: none;
    background: no-repeat;
    color: #007791;
}

.new-message-details .message-body textarea {
    min-height: 100px;
    border-radius: 2px;
    border-color: #cacbcc;
}

.new-message-details .message-body textarea:focus {
    border-color: #76c5d6;
}

span.select2-selection.select2-selection--single {
    background-color: transparent;
    color: #32373c;
    border-color: #cacbcc;
    height: auto;
    border-radius: 2px;
}

.select2-container .select2-selection--single .select2-selection__rendered {
    padding: 10px;
    ;
}

.select2-container .select2-selection--single .select2-selection__rendered:focus {
    outline: none;
}

span.select2-selection.select2-selection--single:focus {
    outline: none;
}

span.select2-selection.select2-selection--single[aria-expanded="true"] {
    background-color: #ffffff;
    border-color: #76c5d6;
}

.select2-container--default .select2-selection--single .select2-selection__arrow {
    top: 12px;
    right: 7px;
}

span.select2-dropdown, .daterangepicker.dropdown-menu {
    border-color: #cacbcc;
}

span.select2-search.select2-search--dropdown {
    padding: 13px 15px;
}

span.select2-results ul li {
    padding: 6px 15px;
    color: #56666d;
}

span.select2-results ul li.select2-results__option--highlighted, .select2-container--default .select2-results__option[aria-selected=true] {
    background: #e8e8e8;
    color: #32373c;
}

.select2-container--default .select2-results__option {
    padding: 12px 15px;
}

.select2-container--default .select2-search--dropdown .select2-search__field {
    border-color: #cacbcc;
    padding: 10px;
}

.select2-container--default .select2-search--dropdown .select2-search__field:focus {
    border-color: #76c5d6;
    outline: none;
    box-shadow: 0 0 0;
}

.select2-container--default .select2-results__option--highlighted[aria-selected] {
    background-color: #007791;
    color: white;
}

/*
purchase History page
*/

section.purchase-history-list-area {
    padding: 30px 0 50px;
}

.purchase-history-list {
    margin: 0;
    padding: 0;
    list-style: none;
}

.purchase-history-list li {
    border-bottom: 1px solid #f2f3f5;
    padding: 10px 0;
    font-size: 12px;
}

.purchase-history-list .purchase-history-list-title {
    font-size: 18px;
    font-weight: 600;
    margin-bottom: 0;
}

.purchase-history-list .purchase-history-course-img {
    float: left;
}

.purchase-history-list .purchase-history-course-img img {
    width: 135px;
    margin-right: 15px;
    height: auto;
}

.purchase-history-list .purchase-history-course-title {
    font-weight: 600;
    font-size: 16px;
}

.purchase-history-list .purchase-history-course-title:hover {
    color: #003845;
}

.purchase-history-list .purchase-history-detail .btn-receipt {
    color: #007791;
    background-color: #fff;
    border: 1px solid #007791;
    padding: 2px 8px;
    font-size: 13px;
    line-height: 1.35135;
    border-radius: 2px;
}

.purchase-history-list .purchase-history-detail .btn-receipt:hover, .purchase-history-list .purchase-history-detail .btn-receipt:focus {
    background-color: #e6f2f5;
}

.purchase-history-list .purchase-history-items {
    background-color: #fff;
    padding: 15px;
    border-bottom: 1px solid #efefef;
}

/*
footer style
*/

.footer-top-widget-area {
    border-top: 1px solid #e8e9eb;
    padding: 40px 0;
    background-color: #fff;
}

.footer-widget.link-widget ul {
    margin: 0;
    padding: 0;
    list-style: none;
}

.footer-widget.link-widget ul li:not(:last-child) {
    margin-bottom: 8px;
}

.footer-widget.link-widget ul a {
    font-size: 13px
}

.language-widget button {
    padding: 9px 18px;
    font-size: 13px;
    font-weight: 600;
    line-height: 18px;
    min-width: 160px;
    text-align: left;
    color: #686f7a;
    background-color: #fff;
    border: 1px solid #505763;
    border-radius: 2px;
}

.language-widget button:hover, .language-widget button:focus {
    color: #686f7a !important;
    background-color: #e8e9eb !important;
    border-color: #505763;
}

.language-widget button i {
    font-size: 11px;
    margin-right: 10px;
}

.language-widget .dropdown-menu {
    box-shadow: 0 4px 16px rgba(20, 23, 28, .25);
    border-radius: 2px;
    border: 0;
    margin-bottom: 2px;
    width: 160px;
}

.language-widget .dropdown-menu a {
    padding: 6px 14px;
    color: #505763;
    font-weight: 400;
    line-height: 1.43;
    font-size: 13px;
}

.language-widget .dropdown-menu a:hover, .language-widget .dropdown-menu a:focus {
    background-color: #f2f3f5;
}

.language-widget .dropdown-toggle {
    position: relative;
}

.language-widget .dropdown-toggle::after {
    position: absolute;
    top: 17px;
    right: 14px;
    transform: rotate(180deg);
    -webkit-transform: rotate(180deg);
    -ms-webkit-transform: rotate(180deg);
}

.footer-area {
    background-color: #fff;
    padding: 30px 0;
    border-bottom: 6px solid var(--color-primario);
    border-top: 1px solid #e8e9eb;
}

.copyright-text {
    color: #686f7a;
    font-size: 13px;
    margin-bottom: 0;
}

.copyright-text img {
    margin-right: 20px
}

.footer-menu .nav-item:not(:last-child) {
    margin-right: 20px;
}

.footer-menu .nav-link {
    padding: 6px 0;
    font-size: 13px;
}

.payment-in-modal form .stripe {
    color: #fff;
    background-color: #008cde;
    border-color: #0698dc;
    font-size: 16px;
    font-weight: 700;
    height: 50px;
    width: 100%;
    padding: 11px 12px;
    border-radius: 2px;
}

.payment-in-modal form .paypal {
    color: #fff;
    background-color: #008cde;
    border-color: #0698dc;
    font-size: 16px;
    font-weight: 700;
    height: 50px;
    width: 100%;
    padding: 11px 12px;
    border-radius: 2px;
}

.purchased a {
    width: 100%;
    border: 0;
    color: #fff;
    background-color: #007791;
    padding: 11px 12px;
    font-size: 15px;
    line-height: 1.43;
    border-radius: 2px;
    font-weight: 600;
    margin-top: 20px;
    display: block;
    text-align: center;
}

.purchased a:hover, .purchased a:focus {
    background: #003440;
}

.already_purchased a {
    width: 100%;
    border: 0;
    color: #fff;
    background-color: #007791;
    padding: 11px 12px;
    font-size: 15px;
    line-height: 1.43;
    border-radius: 2px;
    font-weight: 600;
    margin-top: 20px;
    display: block;
    text-align: center;
}

.already_purchased a:hover, .already_purchased a:focus {
    background: #003440;
}

div.tagsinput span.tag {
    background-color: #2196F3;
    border-color: #2196F3;
    color: white;
}

div.tagsinput span.tag a {
    color: #ddd;
}

/* Version 1.4 */

.hidden {
    display: none;
}

@media (max-width:760px) {
    .user-dashboard-content .content-box .form-group {
        padding: 10px 10px;
    }
}

/* Customizing Radio Button */

.custom-radio:checked, .custom-radio:not(:checked) {
    position: absolute;
    left: -9999px;
}

.custom-radio:checked+label, .custom-radio:not(:checked)+label {
    position: relative;
    padding-left: 28px;
    cursor: pointer;
    line-height: 20px;
    display: inline-block;
    color: #666;
}

.custom-radio:checked+label:before, .custom-radio:not(:checked)+label:before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    width: 18px;
    height: 18px;
    border: 1px solid #ddd;
    border-radius: 100%;
    background: #fff;
}

.custom-radio:checked+label:after, .custom-radio:not(:checked)+label:after {
    content: '';
    width: 12px;
    height: 12px;
    background: var(--color-primario);
    position: absolute;
    top: 3px;
    left: 3px;
    border-radius: 100%;
    -webkit-transition: all 0.2s ease;
    transition: all 0.2s ease;
}

.custom-radio:not(:checked)+label:after {
    opacity: 0;
    -webkit-transform: scale(0);
    transform: scale(0);
}

.custom-radio:checked+label:after {
    opacity: 1;
    -webkit-transform: scale(1);
    transform: scale(1);
}

.filter_type h6 {
    /* border-top: 1px solid #ededed; */
    margin: 15px 0;
    padding: 15px 0 0 0;
    font-size: 13px;
    font-size: 0.8125rem;
}

.filter_type ul {
    list-style: none;
    padding: 0;
    margin: 0 0 15px 0;
}

.filter_type ul li {
    margin-bottom: 5px;
    font-size: 13px;
}

.filter_type ul .parent-category {
    margin-bottom: 5px;
    font-size: 13px;
    font-weight: 600;
}

.filter_type .filter-title {
    margin-bottom: 5px;
    font-size: 13px;
    font-weight: 600;
}

/* .card-with-no-color-no-border {
background-color: unset;
border: none;
} */

.login-form, .register-form, .forgot-password-form {
    background-color: #fff;
    padding-bottom: 30px;
}

.mobile-main-nav .all-category-devided {
    border-top: 1px solid #f5f5f5;
    padding-top: 10px;
}

.quiz-options label {
    color: #3a3a3a;
}

.page-not-found-banner {
    padding: 150px 0px;
}

.page_not_found_heading {
    font-size: 8.75rem;
    display: block;
}

.page_not_found_message {
    font-size: 1.56rem;
    display: block;
    margin-bottom: 30px;
}

.back_to_home_btn {
    color: #2a303b;
    background-color: #fff;
    border-color: #fff;
    padding: 11px 12px;
    font-size: 15px;
    border-radius: 2px;
    line-height: 1.35135;
    font-weight: 600;
}

.back_to_home_btn:hover, .back_to_home_btn:focus {
    background-color: #ffffff;
    border-color: var(--color-secundario);
    color: #2a303b;
}

/* Course progress on lesson sidebar */

.circular-progress {
    display: block;
    margin: 0 auto;
    overflow: hidden;
    transform: rotate(-90deg) rotateX(180deg);
    background-color: #fff;
}

.circular-progress circle {
    stroke-dashoffset: 0;
    transition: stroke-dashoffset 1s ease;
    stroke: #4CAF50;
    stroke-width: 5px;
}

.circular-progress .bar {
    stroke: #E0E0E0;
}

.circular-progressdiv {
    position: relative;
}

.circular-progressdiv:after {
    position: absolute;
    top: 50%;
    left: 50%;
    font-size: 35px;
    transform: translate(-50%, -50%);
    content: attr(data-percent) " %";
}

.ofline-payment-pending {
    background-color: #fff;
    border: 1px solid #ffc107;
    padding-left: 8px;
    padding-right: 8px;
    padding-top: 3px;
    padding-bottom: 3px;
    color: #ffc107;
    border-radius: 1px;
}



/*PERSONZALIZADO*/

.navbar-brand {
    display: flex;
    align-items: center;
    gap: 12px;
    font-family: 'Space Grotesk', sans-serif;
    font-weight: 700;
    font-size: 1.15rem;
    color: var(--color-primario);
}

.navbar-brand .logo-icon {
    width: 74px;
    height: 44px;
    background: linear-gradient(135deg, var(--color-secundario), var(--color-terciario));
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 1.2rem;
    font-weight: 800;
    box-shadow: var(--shadow-primary);
}

.navbar-brand .contacto {
    width: 100px;
    height: 35px;
    background: linear-gradient(135deg, var(--color-secundario), var(--color-secundario));
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 1rem;
    font-weight: 800;
    box-shadow: var(--shadow-primary);
}


.navbar-brand span {
    color: var(--color-primario);
}

.color-gradiente{
    background: linear-gradient(135deg, var(--color-terciario), var(--color-terciario));
    color:  var(--color-text)
}

.color-top{
    background: linear-gradient(135deg, var(--color-primario), var(--color-primario));
}


.color-submenu  {
    background: linear-gradient(135deg, var(--color-base), var(--color-base));
}

.color-aviso  {
    background: var(--color-secundario);
}

.color-submenu a {
    color: #8F9498;
}

.color-submenu a:hover {
    color: #AEB3B3;
}

.color-personal{
    background: linear-gradient(145deg, var(--color-primario), var(--color-primario));
}


 h1 .highlight {
    background: linear-gradient(135deg, var(--color-terciario), var(--color-terciario));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
 }

 h2 .highlight {
    background: linear-gradient(135deg, var(--color-secundario), var(--color-secundario));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
 }

 h3 .highlight {
    background: linear-gradient(135deg, var(--color-primario), var(--color-secundario));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
 }


 /*cabecera de la seccion*/
 .section {
            padding: 100px 0;
        }

.section-header {
    text-align: center;
    max-width: 680px;
    margin: 0 auto 60px;
}

.section-label {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 0.85rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-secundario);
    margin-bottom: 12px;
}

.section-label::before,
.section-label::after {
    content: '';
    width: 24px;
    height: 2px;
    background: var(--color-secundario);
    border-radius: 2px;
}


.section-header h2 {
    font-size: clamp(2rem, 4vw, 2.8rem);
    font-weight: 800;
    color: var(--color-primario);
    margin-bottom: 16px;
    letter-spacing: -0.02em;
}


.section-header h2 .text-primary { color: var(--color-terciario); }
.section-header h2 .text-secondary { color: var(--color-secundario); }

.section-header p {
    font-size: 1.1rem;
    color: var(--gray-500);
    line-height: 1.7;
}

.section-header p .color-textprimary{ color: var(--colortext-white); }


 /* ============================================
    ANIMATIONS
    ============================================ */
.fade-in {
    opacity: 50;
    transform: translateY(30px);
    transition: opacity 0.6s ease, transform 0.6s ease;
}

.fade-in.visible {
    opacity: 1;
    transform: translateY(0);
}

.fade-in-left {
    opacity: 0;
    transform: translateX(-30px);
    transition: opacity 0.6s ease, transform 0.6s ease;
}

.fade-in-left.visible {
    opacity: 1;
    transform: translateX(0);
}

.fade-in-right {
    opacity: 0;
    transform: translateX(30px);
    transition: opacity 0.6s ease, transform 0.6s ease;
}

.fade-in-right.visible {
    opacity: 1;
    transform: translateX(0);
}

/*admision*/
.hero {
    min-height: 100vh;
    display: flex;
    align-items: center;
    position: relative;
    overflow: hidden;
    background: linear-gradient(160deg, var(--color-terciario) 0%, var(--color-primario) 40%, var(--color-primario) 70%, var(--color-terciario) 100%);
    padding-top: 76px;
}

.hero::before {
    content: '';
    position: absolute;
    top: -50%;
    right: -20%;
    width: 800px;
    height: 800px;
    background: radial-gradient(circle, rgba(255,245,0,0.15) 0%, transparent 70%);
    border-radius: 50%;
    animation: float 8s ease-in-out infinite;
}

.hero::after {
    content: '';
    position: absolute;
    bottom: -30%;
    left: -10%;
    width: 600px;
    height: 600px;
    background: radial-gradient(circle, rgba(227,0,14,0.12) 0%, transparent 70%);
    border-radius: 50%;
    animation: float 10s ease-in-out infinite reverse;
}

@keyframes float {
    0%, 100% { transform: translate(0, 0) scale(1); }
    50% { transform: translate(30px, -30px) scale(1.05); }
}

.hero-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 60px;
    align-items: center;
    position: relative;
    z-index: 2;
}

.hero-content {
    color: var(--white);
}

.hero-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: rgba(255,245,0,0.15);
    border: 1px solid rgba(255,245,0,0.3);
    padding: 8px 20px;
    border-radius: var(--radius-full);
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--tertiary);
    margin-bottom: 24px;
    backdrop-filter: blur(10px);
}

.hero-badge .pulse {
    width: 8px;
    height: 8px;
    background: var(--tertiary);
    border-radius: 50%;
    animation: pulse 2s ease-in-out infinite;
}

@keyframes pulse {
    0%, 100% { opacity: 1; transform: scale(1); }
    50% { opacity: 0.5; transform: scale(1.5); }
}

.hero h1 {
    font-size: clamp(2.5rem, 5vw, 4rem);
    font-weight: 800;
    margin-bottom: 20px;
    letter-spacing: -0.02em;
}

.hero h1 .highlight {
    background: linear-gradient(135deg, var(--tertiary), #FFD700);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.hero p {
    font-size: 1.15rem;
    color: rgba(255,255,255,0.8);
    margin-bottom: 36px;
    max-width: 520px;
    line-height: 1.7;
}

.hero-buttons {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
}

.btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 14px 32px;
    border-radius: var(--radius-full);
    font-size: 0.95rem;
    font-weight: 600;
    font-family: 'Inter', sans-serif;
    cursor: pointer;
    transition: var(--transition);
    border: none;
    position: relative;
    overflow: hidden;
}

.btn-primary {
    background: linear-gradient(135deg, var(--color-primario), var(--color-primario));
    color: var(--white);
    box-shadow: var(--shadow-secondary);
}

.btn-primary:hover {
    transform: translateY(-3px);
    box-shadow: 0 14px 40px rgba(227,0,14,0.4);
}

.btn-outline {
    background: rgba(255,255,255,0.1);
    color: var(--white);
    border: 2px solid rgba(255,255,255,0.3);
    backdrop-filter: blur(10px);
}

.btn-outline:hover {
    background: rgba(255,255,255,0.2);
    border-color: rgba(255,255,255,0.5);
    transform: translateY(-3px);
}

.hero-stats {
    display: flex;
    gap: 40px;
    margin-top: 48px;
    padding-top: 32px;
    border-top: 1px solid rgba(255,255,255,0.15);
}

.stat-item h3 {
    font-size: 2rem;
    font-weight: 800;
    color: var(--tertiary);
}

.stat-item p {
    font-size: 0.85rem;
    color: rgba(255,255,255,0.6);
    margin-bottom: 0;
}

.hero-visual {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
}

.hero-card {
    background: rgba(255,255,255,0.1);
    backdrop-filter: blur(20px);
    border: 1px solid rgba(255,255,255,0.15);
    border-radius: var(--radius-xl);
    padding: 40px;
    width: 100%;
    max-width: 440px;
}

.hero-card-header {
    text-align: center;
    margin-bottom: 28px;
}

.hero-card-header .icon-circle {
    width: 72px;
    height: 72px;
    background: linear-gradient(135deg, var(--tertiary), #FFD700);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 16px;
    font-size: 2rem;
}

.hero-card-header h3 {
    color: var(--white);
    font-size: 1.3rem;
}

.hero-card-header p {
    color: rgba(255,255,255,0.6);
    font-size: 0.9rem;
    margin-bottom: 0;
}

.hero-card-form {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.hero-card-form input {
    width: 100%;
    padding: 14px 18px;
    border: 1px solid rgba(255,255,255,0.15);
    border-radius: var(--radius-md);
    background: rgba(255,255,255,0.08);
    color: var(--white);
    font-size: 0.9rem;
    font-family: 'Inter', sans-serif;
    transition: var(--transition);
    outline: none;
}

.hero-card-form input::placeholder {
    color: rgba(255,255,255,0.4);
}

.hero-card-form input:focus {
    border-color: var(--tertiary);
    background: rgba(255,255,255,0.12);
    box-shadow: 0 0 0 3px rgba(255,245,0,0.15);
}

.hero-card-form .btn-submit {
    width: 100%;
    padding: 14px;
    background: linear-gradient(135deg, var(--tertiary), #FFD700);
    color: var(--gray-900);
    border: none;
    border-radius: var(--radius-md);
    font-size: 1rem;
    font-weight: 700;
    font-family: 'Inter', sans-serif;
    cursor: pointer;
    transition: var(--transition);
    margin-top: 4px;
}

.hero-card-form .btn-submit:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(255,245,0,0.3);
}


 /*ADMISSION PROCESS / PASOS*/

.process {
    background: var(--gray-50);
}

.process-timeline {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
    position: relative;
}

.process-timeline::before {
    content: '';
    position: absolute;
    top: 50px;
    left: 12.5%;
    right: 12.5%;
    height: 3px;
    background: linear-gradient(90deg, var(--primary), var(--secondary), var(--tertiary), var(--primary));
    border-radius: 2px;
}

.process-step {
    text-align: center;
    position: relative;
    z-index: 2;
}

.step-number {
    width: 64px;
    height: 64px;
    background: var(--white);
    border: 3px solid var(--primary);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 24px;
    font-family: 'Space Grotesk', sans-serif;
    font-size: 1.4rem;
    font-weight: 800;
    color: var(--primary);
    box-shadow: var(--shadow-md);
    transition: var(--transition);
}

.process-step:nth-child(2) .step-number {
    border-color: var(--secondary);
    color: var(--secondary);
}

.process-step:nth-child(3) .step-number {
    border-color: var(--tertiary-dark);
    color: var(--tertiary-dark);
}

.process-step:nth-child(4) .step-number {
    border-color: var(--primary);
    color: var(--primary);
}

.process-step:hover .step-number {
    transform: scale(1.1);
    box-shadow: var(--shadow-lg);
}

.process-step:nth-child(2):hover .step-number {
    box-shadow: var(--shadow-secondary);
}

.step-content {
    background: var(--white);
    border-radius: var(--radius-lg);
    padding: 28px 20px;
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--gray-100);
    transition: var(--transition);
}

.process-step:hover .step-content {
    transform: translateY(-4px);
    box-shadow: var(--shadow-md);
}

.step-content h3 {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--gray-800);
    margin-bottom: 8px;
}

.step-content p {
    font-size: 0.88rem;
    color: var(--gray-500);
    line-height: 1.6;
}

.step-content .step-icon {
    font-size: 2rem;
    margin-bottom: 12px;
    display: block;
}


/*  DATES / FECHAS IMPORTANTES */
.dates {
    background: var(--gray-50);
}

.dates-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}

.date-card {
    background: var(--white);
    border-radius: var(--radius-xl);
    overflow: hidden;
    border: 1px solid var(--gray-200);
    transition: var(--transition);
}

.date-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--shadow-lg);
}

.date-card-header {
    padding: 24px 28px;
    display: flex;
    align-items: center;
    gap: 16px;
}

.date-card:nth-child(1) .date-card-header {
    background: linear-gradient(135deg, var(--color-primario), var(--color-primario));
    color: white;
}

.date-card:nth-child(2) .date-card-header {
    background: linear-gradient(135deg, var(--color-secundario), var(--color-secundario));
    color: white;
}

.date-card:nth-child(3) .date-card-header {
    background: linear-gradient(135deg, var(--color-terciario), var(--color-terciario));
    color: var(--gray-900);
}

.date-icon {
    width: 52px;
    height: 52px;
    background: rgba(255,255,255,0.2);
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.4rem;
}

.date-card:nth-child(3) .date-icon {
    background: rgba(0,0,0,0.1);
}

.date-card-header h3 {
    font-size: 1.1rem;
    font-weight: 700;
}

.date-card-header p {
    font-size: 0.8rem;
    opacity: 0.85;
}

.date-card-body {
    padding: 24px 28px;
}

.date-detail {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 0;
    border-bottom: 1px solid var(--gray-100);
}

.date-detail:last-child {
    border-bottom: none;
}

.date-detail span:first-child {
    font-size: 0.9rem;
    color: var(--gray-600);
}

.date-detail span:last-child {
    font-size: 0.9rem;
    font-weight: 700;
    color: var(--gray-800);
}

.date-badge {
    display: inline-block;
    padding: 4px 12px;
    background: rgba(227,0,14,0.1);
    color: var(--secondary);
    border-radius: var(--radius-full);
    font-size: 0.75rem;
    font-weight: 700;
}


/* ============================================
           FAQ SECTION
           ============================================ */
        .faq-container {
            max-width: 800px;
            margin: 0 auto;
        }

        .faq-item {
            background: var(--white);
            border: 1px solid var(--gray-200);
            border-radius: var(--radius-lg);
            margin-bottom: 12px;
            overflow: hidden;
            transition: var(--transition);
        }

        .faq-item:hover {
            border-color: var(--primary);
        }

        .faq-item.active {
            border-color: var(--color-primario);
            box-shadow: var(--shadow-md);
        }

        .faq-question {
            display: flex;
            align-items: center;
            justify-content: space-between;
            padding: 20px 24px;
            cursor: pointer;
            gap: 16px;
            background: none;
            border: none;
            width: 100%;
            text-align: left;
            font-family: 'Inter', sans-serif;
        }

        .faq-question h3 {
            font-size: 1rem;
            font-weight: 600;
            color: var(--gray-800);
            font-family: 'Inter', sans-serif;
        }

        .faq-item.active .faq-question h3 {
            color: var(--color-primario);
        }

        .faq-toggle {
            width: 32px;
            height: 32px;
            min-width: 32px;
            background: var(--gray-100);
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 1.2rem;
            color: var(--gray-500);
            transition: var(--transition);
        }

        .faq-item.active .faq-toggle {
            background: var(--color-primario);
            color: var(--white);
            transform: rotate(45deg);
        }

        .faq-answer {
            max-height: 0;
            overflow: hidden;
            transition: max-height 0.4s ease;
        }

        .faq-answer-content {
            padding: 0 24px 20px;
            font-size: 0.92rem;
            color: var(--gray-500);
            line-height: 1.7;
        }


/*heropersonal SECTION */
.heropersonal {
    background: linear-gradient(135deg, var(--color-primario) 0%, #1e3a5f 50%, var(--color-terciario) 100%);
    padding: 60px 24px;
    text-align: center;
    position: relative;
    overflow: hidden;
}

.heropersonal::before {
    content: '';
    position: absolute;
    top: -50%;
    left: -50%;
    width: 200%;
    height: 200%;
    background: radial-gradient(circle at 30% 50%, rgba(37, 99, 235, 0.15) 0%, transparent 50%),
                radial-gradient(circle at 70% 80%, rgba(245, 158, 11, 0.1) 0%, transparent 50%);
    animation: heropersonalFloat 20s ease-in-out infinite;
}

@keyframes heropersonalFloat {
    0%, 100% { transform: translate(0, 0); }
    50% { transform: translate(-2%, -2%); }
}

.heropersonal-content {
    position: relative;
    z-index: 1;
    max-width: 700px;
    margin: 0 auto;
}

.heropersonal h1 {
    font-size: clamp(1.8rem, 4vw, 2.8rem);
    color: white;
    font-weight: 800;
    margin-bottom: 12px;
    letter-spacing: -0.5px;
}

.heropersonal h1 span {
    background: linear-gradient(135deg, var(--color-terciario), var(--color-terciario));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.heropersonal p {
    color: rgba(255,255,255,0.7);
    font-size: 1.1rem;
    max-width: 550px;
    margin: 0 auto;
}

.heropersonal-stats {
    display: flex;
    justify-content: center;
    gap: 40px;
    margin-top: 32px;
    flex-wrap: wrap;
}

.heropersonal-stat {
    text-align: center;
}

.heropersonal-stat .number {
    font-size: 2rem;
    font-weight: 800;
    color: white;
}

.heropersonal-stat .label {
    font-size: 0.85rem;
    color: rgba(255,255,255,0.6);
    text-transform: uppercase;
    letter-spacing: 1px;
}


/* MAIN containerpersonal*/
.containerpersonal {
    max-width: var(--persnal_max-width);
    margin: 0 auto;
    padding: 40px 24px;
}

/* ============================================
    filterpersonal / searchpersonal BAR
    ============================================ */
.searchpersonal-bar {
    background: var(--persnal_bg-card);
    border-radius: var(--persnal_radius-lg);
    padding: 20px 24px;
    margin-bottom: 40px;
    box-shadow: var(--persnal_shadow-sm);
    border: 1px solid var(--persnal_border);
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    align-items: center;
}

.searchpersonal-input-wrapper {
    flex: 1;
    min-width: 200px;
    position: relative;
}

.searchpersonal-input-wrapper .icon {
    position: absolute;
    left: 14px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--persnal_text-lighter);
    font-size: 1rem;
}

.searchpersonal-input {
    width: 100%;
    padding: 12px 16px 12px 42px;
    border: 2px solid var(--persnal_border);
    border-radius: var(--persnal_radius-sm);
    font-size: 0.95rem;
    transition: var(--persnal_transition);
    background: var(--persnal_bg);
    color: var(--text);
}

.searchpersonal-input:focus {
    outline: none;
    border-color: var(--color-primario);
    box-shadow: 0 0 0 3px var(--color-primario);
}

.filterpersonal-pills {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.filterpersonal-pill {
    padding: 10px 18px;
    border-radius: 50px;
    border: 2px solid var(--persnal_border);
    background: var(--persnal_bg-card);
    font-size: 0.85rem;
    font-weight: 500;
    cursor: pointer;
    transition: var(--persnal_transition);
    color: var(--persnal_text-light);
    white-space: nowrap;
}

.filterpersonal-pill:hover {
    border-color: var(--color-primario);
    color: var(--color-primario);
}

.filterpersonal-pill.active {
    background: var(--color-primario);
    border-color: var(--color-primario);
    color: white;
}

 /* ============================================
           PROGRAM SECTION
           ============================================ */
        .program-section {
            margin-bottom: 50px;
            animation: fadeInUp 0.6s ease-out;
        }

        @keyframes fadeInUp {
            from { opacity: 0; transform: translateY(20px); }
            to { opacity: 1; transform: translateY(0); }
        }

        .program-header {
            display: flex;
            align-items: center;
            gap: 14px;
            margin-bottom: 24px;
            padding-bottom: 16px;
            border-bottom: 2px solid var(--border);
        }

        .program-icon {
            width: 48px;
            height: 48px;
            border-radius: var(--radius-md);
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 1.4rem;
            flex-shrink: 0;
        }

        .program-header h2 {
            font-size: 1.35rem;
            font-weight: 700;
            color: var(--secondary);
        }

        .program-header .count {
            background: var(--primary-light);
            color: var(--primary);
            padding: 4px 12px;
            border-radius: 50px;
            font-size: 0.8rem;
            font-weight: 600;
            margin-left: auto;
        }

/*TEACHER CARDS GRID*/
.teachers-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 20px;
}

.teacher-card {
    background: var(--persnal_bg-card);
    border-radius: var(--persnal_radius-lg);
    overflow: hidden;
    border: 1px solid var(--persnal_border);
    transition: var(--persnal_transition);
    position: relative;
}

.teacher-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--persnal_shadow-lg);
    border-color: transparent;
}

.card-accent {
    height: 4px;
    width: 100%;
}

.card-body {
    padding: 24px;
    text-align: center;
}

.teacher-photo {
    width: 90px;
    height: 90px;
    border-radius: 50%;
    margin: 0 auto 16px;
    overflow: hidden;
    border: 3px solid var(--persnal_border);
    background: linear-gradient(135deg, var(--color-primario), #e0e7ff);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2rem;
    color: var(--color-primario);
    position: relative;
}

.teacher-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.teacher-name {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--colortext-black);
    margin-bottom: 4px;
}

.teacher-cargo {
    font-size: 0.85rem;
    color: var(--color-text);
    font-weight: 600;
    margin-bottom: 16px;
    display: inline-block;
    background: var(--color-terciario);
    padding: 4px 14px;
    border-radius: 50px;
}

.teacher-specialty {
    font-size: 0.82rem;
    color: var(--persnal_text-light);
    margin-bottom: 18px;
    line-height: 1.5;
}

.btn-hv {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 24px;
    background: linear-gradient(135deg, var(--color-primario), var(--color-primario));
    color: #ffffff;
    border-radius: var(--persnal_radius-sm);
    font-size: 0.88rem;
    font-weight: 600;
    transition: var(--persnal_p_success);
    border: none;
    cursor: pointer;
    text-decoration: none;
}

.btn-hv:hover {
    color: #ffffff;
    transform: scale(1.03);
    box-shadow: 0 4px 15px rgba(37, 99, 235, 0.4);
}



/* CV PAGE (Hoja de Vida) */
.cv-page {
    display: none;
}

.cv-page.active {
    display: block;
}

.teachers-page.active {
    display: block;
}

.cv-back-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 20px;
    background: var(--persnal_bg-card);
    border: 2px solid var(--persnal_border);
    border-radius: var(--persnal_radius-sm);
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--text);
    cursor: pointer;
    transition: var(--persnal_transition);
    margin-bottom: 30px;
}

.cv-back-btn:hover {
    border-color: var(--color-primario);
    color: var(--color-primario);
    background: var(--personal_primary-light);
}

.cv-containerpersonal {
    max-width: 960px;
    margin: 0 auto;
    padding: 40px 24px;
}

.cv-card {
    background: var(--persnal_bg-card);
    border-radius: var(--persnal_radius-xl);
    overflow: hidden;
    box-shadow: var(--persnal_shadow-lg);
    border: 1px solid var(--persnal_border);
}

/* CV Header */
.cv-header {
    background: linear-gradient(135deg, var(--color-primario), #1e3a5f, var(--color-primario));
    padding: 40px;
    display: flex;
    gap: 30px;
    align-items: center;
    flex-wrap: wrap;
    position: relative;
    overflow: hidden;
}

.cv-header::before {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    width: 300px;
    height: 100%;
    background: radial-gradient(circle at center, rgba(255,255,255,0.05) 0%, transparent 70%);
}

.cv-photo {
    width: 130px;
    height: 130px;
    border-radius: var(--persnal_radius-lg);
    overflow: hidden;
    border: 4px solid rgba(255,255,255,0.2);
    background: rgba(255,255,255,0.1);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 3.5rem;
    color: rgba(255,255,255,0.6);
    flex-shrink: 0;
}

.cv-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.cv-header-info {
    flex: 1;
    min-width: 200px;
    position: relative;
    z-index: 1;
}

.cv-header-info h1 {
    font-size: 1.8rem;
    color: white;
    font-weight: 800;
    margin-bottom: 4px;
}

.cv-header-info .cargo {
    color: var(--persnal_p_accent);
    font-weight: 600;
    font-size: 1rem;
    margin-bottom: 12px;
}

.cv-contact-row {
    display: flex;
    gap: 20px;
    flex-wrap: wrap;
}

.cv-contact-item {
    display: flex;
    align-items: center;
    gap: 6px;
    color: rgba(255,255,255,0.7);
    font-size: 0.85rem;
}

.cv-contact-item .ci-icon {
    width: 28px;
    height: 28px;
    background: rgba(255,255,255,0.1);
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.75rem;
}

/* CV Content */
.cv-content {
    padding: 40px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 36px;
}

.cv-section {
    animation: fadeInUp 0.5s ease-out;
}

.cv-section.full-width {
    grid-column: 1 / -1;
}

.cv-section-title {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--color-primario);
    margin-bottom: 20px;
    padding-bottom: 10px;
    border-bottom: 2px solid var(--persnal_border);
}

.cv-section-title .sec-icon {
    width: 32px;
    height: 32px;
    background: var(--personal_primary-light);
    color: var(--primary);
    border-radius: var(--persnal_radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.9rem;
}

.cv-profile-text {
    font-size: 0.95rem;
    color: var(--persnal_text-light);
    line-height: 1.8;
    text-align: justify;
}

/* Personal Data */
.personal-data-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
}

.data-item {
    padding: 12px 16px;
    background: var(--persnal_bg);
    border-radius: var(--persnal_radius-sm);
    border: 1px solid var(--persnal_border);
}

.data-item .data-label {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--persnal_text-light);
    font-weight: 600;
    margin-bottom: 2px;
}

.data-item .data-value {
    font-size: 0.92rem;
    font-weight: 600;
    color: var(--persnal_text-light);
}

/* Timeline Items (Experience & Education) */
.timeline {
    position: relative;
    padding-left: 24px;
}

.timeline::before {
    content: '';
    position: absolute;
    left: 6px;
    top: 8px;
    bottom: 8px;
    width: 2px;
    background: var(--persnal_border);
}

.timeline-item {
    position: relative;
    margin-bottom: 24px;
    padding: 16px 20px;
    background: var(--persnal_bg);
    border-radius: var(--persnal_radius-md);
    border: 1px solid var(--persnal_border);
    transition: var(--persnal_transition);
}

.timeline-item:hover {
    border-color: var(--color-primario);
    box-shadow: var(--persnal_shadow-sm);
}

.timeline-item::before {
    content: '';
    position: absolute;
    left: -22px;
    top: 22px;
    width: 10px;
    height: 10px;
    background: var(--color-primario);
    border-radius: 50%;
    border: 2px solid var(--bg-card);
}

.timeline-item .period {
    font-size: 0.78rem;
    color: var(--primary);
    font-weight: 600;
    background: var(--personal_primary-light);
    padding: 2px 10px;
    border-radius: 50px;
    display: inline-block;
    margin-bottom: 6px;
}

.timeline-item h4 {
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--persnal_text);
    margin-bottom: 2px;
}

.timeline-item .org {
    font-size: 0.85rem;
    color: var(--persnal_text-light);
    font-weight: 500;
}

.timeline-item .desc {
    font-size: 0.83rem;
    color: var(--persnal_text-lighter);
    margin-top: 6px;
    line-height: 1.5;
}

/* Units Table */
.units-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.88rem;
}

.units-table th {
    background: var(--persnal_bg);
    padding: 12px 16px;
    text-align: left;
    font-weight: 700;
    color: var(--secondary);
    border-bottom: 2px solid var(--persnal_border);
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.units-table td {
    padding: 12px 16px;
    border-bottom: 1px solid var(--persnal_border);
    color: var(--text);
}

.units-table tr:last-child td {
    border-bottom: none;
}

.units-table tr:hover td {
    background: var(--personal_primary-light);
}

.unit-code {
    background: var(--personal_primary-light);
    color: var(--color-primario);
    padding: 3px 10px;
    border-radius: 4px;
    font-weight: 600;
    font-size: 0.8rem;
}


/*vision y mision*/
 .containerOrg { width: 100%; max-width: 1200px; margin: 0 auto; padding: 0 var(--Ospace-sm); }


.sectionOrg-title { font-size: var(--Ofs-lg); color: var(--color-primario); margin-bottom: var(--Ospace-md); text-align: center; }
.sectionOrg-subtitle { font-size: var(--Ofs-sm); color: var(--persnal_text-light); text-align: center; margin-top: -var(--space-xs); margin-bottom: var(--Ospace-md); }

/* 🧩 MISION & VISION */
.grid-2 { 
    display: grid; 
    gap: var(--Ospace-md); 
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); 
}
.card {
    background: var(--Osurface);
    padding: var(--Ospace-md);
    border-radius: var(--Oradius);
    border: 1px solid var(--Oborder);
    box-shadow: var(--Oshadow);
    transition: var(--Otransition);
}
.card:hover { transform: translateY(-4px); box-shadow: var(--Oshadow-hover); border-color: var(--color-primario); }
.card h2 { font-size: var(--Ofs-lg); color: var(--color-primario); margin-bottom: var(--Ospace-xs); }
.card p { color: var(--persnal_text-light); margin: 0; }

#️⃣ VALORES
.grid-3 { display: grid; gap: var(--Ospace-sm); grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); }
.value-card {
    background: var(--Osurface);
    padding: var(--Ospace-sm);
    border-radius: var(--Oradius);
    border: 1px solid var(--Oborder);
    box-shadow: var(--Oshadow);
    transition: var(--Otransition);
    position: relative;
    overflow: hidden;
}
.value-card::before {
    content: ''; position: absolute; top: 0; left: 0; width: 4px; height: 100%; background: var(--color-primario);
    transform: scaleY(0); transition: transform 300ms ease; transform-origin: bottom;
}
.value-card:hover::before { transform: scaleY(1); }
.value-card:hover { transform: translateY(-3px); box-shadow: var(--Oshadow-hover); }
.value-icon { font-size: 1.8rem; margin-bottom: var(--Ospace-xs); display: block; }
.value-card h3 { font-size: var(--Ofs-md); margin: 0 0 0.5rem; color: var(--color-primario); }
.value-card p { font-size: var(--Ofs-sm); color: var(--persnal_text-light); margin: 0; }


/*palabras director*/
/*HERO / DIRECTOR */
.herodirector { background: linear-gradient(135deg, var(--color-primario) 0%, var(--color-primario) 100%); color: white; padding: var(--Ospace-xl) 0; }
.herodirector-inner { display: grid; grid-template-columns: 1fr; gap: var(--Ospace-md); align-items: center; }
@media (min-width: 768px) { .hero-inner { grid-template-columns: 1.2fr 0.8fr; } }
.herodirector-text h1 { font-size: var(--Ofs-xl); margin-bottom: var(--Ospace-xs); line-height: 1.15; }
.herodirector-quote {
    border-left: 4px solid var(--color-terciario);
    padding-left: var(--Ospace-sm);
    margin: var(--Ospace-sm) 0;
    font-size:16px;
    font-style: italic;
    opacity: 0.95;
}
.herodirector-author { margin-top: var(--Ospace-xs); font-weight: 600; opacity: 0.9; }
.imagen {
    background: var(--color-primario);
    border-radius: var(--Oradius);
    padding: var(--Ospace-sm);
    box-shadow: 0 20px 25px -5px rgba(0,0,5,5.2);

    margin: 2rem;
    height: 80vh;

    display: flex;
    align-items: center;
    justify-content: center;

    overflow: hidden; /* puede quedarse */
}
.imagen img {
    max-width: 100%;
    max-height: 100%;
     border-radius: var(--Oradius);
    object-fit: contain; /* 👈 NO corta la imagen */
}

.herodirector-img img { border-radius: 0.5rem; }


/* ========== STATS BAR ========== */
        .stats-bar {
            max-width: 1200px;
            margin: -2rem auto 0;
            padding: 0 2rem;
            position: relative;
            z-index: 2;
        }

        .stats-container {
            background: var(--white);
            border-radius: var(--radius);
            box-shadow: var(--shadow-xl);
            display: grid;
            grid-template-columns: repeat(4, 1fr);
            padding: 1.5rem 2rem;
            gap: 1rem;
        }

        .stat-item {
            text-align: center;
            padding: 0.5rem;
            border-right: 1px solid var(--gray-200);
        }

        .stat-item:last-child {
            border-right: none;
        }

        .stat-number {
            font-size: 1.8rem;
            font-weight: 800;
            color: var(--primary);
            line-height: 1;
        }

        .stat-label {
            font-size: 0.75rem;
            color: var(--gray-500);
            text-transform: uppercase;
            letter-spacing: 0.08em;
            font-weight: 600;
            margin-top: 0.3rem;
        }


        /* ========== FILTERS ========== */
        .Tfilters-section {
            max-width: 1200px;
            margin: 2rem auto 0;
            padding: 0 2rem;
        }

        .Tfilters-wrapper {
            display: flex;
            align-items: center;
            justify-content: space-between;
            flex-wrap: wrap;
            gap: 1rem;
        }

        .Tfilter-tabs {
            display: flex;
            gap: 0.5rem;
            flex-wrap: wrap;
        }

        .Tfilter-tab {
            padding: 0.55rem 1.2rem;
            border: 1.5px solid var(--gray-200);
            border-radius: 50px;
            background: var(--colortext-white);
            color: var(--gray-600);
            font-size: 0.82rem;
            font-weight: 500;
            cursor: pointer;
            transition: var(--transition);
            font-family: 'Inter', sans-serif;
        }

        .Tfilter-tab:hover {
            border-color: var(--color-primario);
            color: var(--colortext-black);
            background: var(--color-primary-light);
        }

        .Tfilter-tab.active {
            background: var(--color-primario);
            color: var(--white);
            border-color: var(--color-primario);
        }

        .Tresults-count {
            font-size: 0.85rem;
            color: var(--gray-500);
            font-weight: 500;
        }

        .Tresults-count span {
            color: var(--color-primario);
            font-weight: 700;
        }


         /* ── MAIN CONTENT TRANSPARENCIA── */
        .Tmain-content {
            max-width: 1200px;
            margin: 1.5rem auto 3rem;
            padding: 0 2rem;
        }

        /* ── CATEGORY ── */
        .Tcategory-section { margin-bottom: 2.5rem; }

        .Tcategory-header {
            display: flex;
            align-items: center;
            gap: 0.75rem;
            margin-bottom: 1rem;
            padding-bottom: 0.75rem;
            border-bottom: 2px solid var(--Tgray-200);
        }

        .Tcategory-icon {
            width: 40px;
            height: 40px;
            border-radius: 10px;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 1rem;
        }

        .Tcategory-icon.blue   { background: var(--color-primary-light); color: var(--color-primario); }
        .Tcategory-icon.purple { background: #faf5ff; color: #805ad5; }
        .Tcategory-icon.teal   { background: #e6fffa; color: #319795; }
        .Tcategory-icon.orange { background: #fffaf0; color: #dd6b20; }

        .Tcategory-title { font-size: 1.05rem; font-weight: 700; color: var(--Tgray-800); }

        .Tcategory-count {
            font-size: 0.7rem;
            background: var(--Tgray-100);
            color: var(--Tgray-500);
            padding: 0.2rem 0.6rem;
            border-radius: 50px;
            font-weight: 600;
        }

        /* ── NORMATIVE CARD ── */
        .Tnormative-list { display: flex; flex-direction: column; gap: 0.75rem; }

        .Tnormative-card {
            background: var(--Twhite);
            border-radius: var(--Tradius);
            padding: 1.25rem 1.5rem;
            display: flex;
            align-items: center;
            gap: 1.25rem;
            box-shadow: var(--Tshadow-sm);
            border: 1px solid var(--Tgray-100);
            transition: var(--Ttransition);
            position: relative;
            overflow: hidden;
        }

        .Tnormative-card::before {
            content: '';
            position: absolute;
            left: 0; top: 0; bottom: 0;
            width: 4px;
            background: var(--color-primario);
            opacity: 0;
            transition: var(--Ttransition);
        }

        .Tnormative-card:hover {
            box-shadow: var(--Tshadow-lg);
            border-color: var(--Tgray-200);
            transform: translateY(-2px);
        }

        .Tnormative-card:hover::before { opacity: 1; }

        .Tnormative-icon {
            width: 48px;
            height: 48px;
            border-radius: 10px;
            background: linear-gradient(135deg, var(--color-primary-light), var(--color-terciario));
            display: flex;
            align-items: center;
            justify-content: center;
            flex-shrink: 0;
        }

        .Tnormative-icon i { font-size: 1.2rem; color: var(--Taccent); }

        .Tnormative-info { flex: 1; min-width: 0; }

        .Tnormative-code {
            font-size: 0.7rem;
            font-weight: 700;
            color: var(--color-primario);
            text-transform: uppercase;
            letter-spacing: 0.08em;
            margin-bottom: 0.15rem;
        }

        .Tnormative-title {
            font-size: 0.93rem;
            font-weight: 600;
            color: var(--Tgray-800);
            margin-bottom: 0.25rem;
            line-height: 1.3;
        }

        .Tnormative-meta {
            display: flex;
            align-items: center;
            gap: 1rem;
            flex-wrap: wrap;
        }

        .Tmeta-item {
            font-size: 0.73rem;
            color: var(--Tgray-500);
            display: flex;
            align-items: center;
            gap: 0.3rem;
        }

        .Tmeta-item i { font-size: 0.6rem; }

        .Tbadge {
            font-size: 0.63rem;
            padding: 0.15rem 0.55rem;
            border-radius: 50px;
            font-weight: 600;
            text-transform: uppercase;
            letter-spacing: 0.05em;
        }

        .Tbadge-vigente    { background: #f0fff4; color: #38a169; }
        .Tbadge-actualizado{ background: #ebf8ff; color: #2b6cb0; }
        .Tbadge-nuevo      { background: #faf5ff; color: #805ad5; }


/* 1. Contenedor principal: Flexbox para alineación horizontal y centrado vertical */
.home-banner-wrap_pe {
    display: flex;
    align-items: center;       /* Centrado vertical exacto */
    justify-content: flex-start;
    flex-wrap: nowrap;         /* Evita saltos de línea no deseados en desktop */
    gap: 1.5rem;               /* Espaciado consistente entre texto e imagen */
    padding: 1.5rem 0;
    position: relative;
}

/* 1. Contenedor flex para alineación vertical y distribución horizontal */
.home-banner-wrap_pe {
    display: flex;
    align-items: center;      /* Centrado vertical exacto */
    padding: 1.5rem 0;
    position: relative;
}

/* 2. Empuja el bloque de la imagen al extremo derecho */
.hero-card-header_pe {
    margin-left: auto;        /* Técnica flexbox para alinear a la derecha sin romper el DOM */
    display: flex;
    align-items: center;
}

/* 3. Imagen con dimensiones fijas y comportamiento controlado */
.icon-circle_pe img {
    width: 400px;              /* Ancho fijo (ajusta según tu diseño) */
    height: 400px;             /* Alto fijo */
    object-fit: contain;      /* Mantiene proporción sin deformar, centrado dentro del cuadro */
    display: block;
}

/* 4. Reset de márgenes para alineación tipográfica precisa */
.home-banner-wrap_pe h2,
.home-banner-wrap_pe p {
    margin: 0;
    line-height: 1.4;
}


/* ===== BACK TO TOP ===== */
.back-to-top {
    position: fixed;
    bottom:100px;
    right: 30px;
    width: 50px;
    height: 50px;
    background: var(--color-terciario);
    color: var(--color-primario);
    border: none;
    border-radius: 50%;
    cursor: pointer;
    font-size: 1.1rem;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    visibility: hidden;
    transition: var(--transition);
    z-index: 100;
    box-shadow: 0 5px 20px rgba(201, 168, 76, 0.3);
}

.back-to-top.visible {
    opacity: 1;
    visibility: visible;
}

.back-to-top:hover {
    transform: translateY(-5px);
}


/*======whatsapp====*/

.whatsapp-float {
  position: fixed;
  bottom: max(24px, env(safe-area-inset-bottom)); /* Respeta la barra de iOS/Android */
  right: 24px;
  width: var(--whatsapp-size);
  height: var(--whatsapp-size);
  background-color: var(--whatsapp-bg);
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25);
  text-decoration: none;
  z-index: var(--whatsapp-z);
  transition: transform 0.25s ease, box-shadow 0.25s ease, background-color 0.25s ease;
  -webkit-tap-highlight-color: transparent;
}

/* Tooltip */
.whatsapp-tooltip {
  position: absolute;
  right: calc(100% + 12px);
  top: 50%;
  transform: translateY(-50%) translateX(10px);
  background: #111;
  color: #fff;
  padding: 6px 10px;
  border-radius: 6px;
  font-size: 13px;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s, transform 0.2s;
}

.whatsapp-float:hover .whatsapp-tooltip,
.whatsapp-float:focus .whatsapp-tooltip {
  opacity: 1;
  transform: translateY(-50%) translateX(0);
}

/* Estados interactivos */
.whatsapp-float:hover {
  transform: scale(1.1);
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.35);
  background-color: var(--whatsapp-hover);
}

.whatsapp-float:focus {
  outline: 2px solid var(--whatsapp-hover);
  outline-offset: 3px;
}

/* Ajuste móvil */
@media (max-width: 480px) {
  :root { --whatsapp-size: 50px; }
  .whatsapp-float { right: 16px; }
  .whatsapp-tooltip { display: none; } /* En móvil el tooltip molesta al tacto */
}