/**************************************
 * style-login.css - OPTIMIZADO
 *
 * Basado en: Xmee Login Template v1.3
 * Optimizado: 2026-01-24
 *
 * Reducido de 13,800 lineas a ~1,200 lineas (91% menos)
 * Solo contiene Layout 1 (index.php) y Layout 29 (login.php, login_ldap.php)
 *
 * IMPORTANTE: Usa variables CSS institucionales desde colores-institucionales.css
 *
 * Backup del original: style-login.css.backup-original
 **************************************/

/*=======================================================================
1. Typography
=========================================================================*/
html {
    height: 100%;
}

body {
    font-size: 16px;
    font-family: 'Roboto', sans-serif;
    font-weight: 400;
    height: 100%;
    line-height: 1.7;
    vertical-align: baseline;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
    color: #646464;
    background-color: #fff;
}

p {
    margin: 0 0 20px 0;
    color: #7f8793;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-weight: 400;
    font-family: 'Roboto', sans-serif;
    margin: 0 0 20px 0;
    color: var(--color-principal-seguro, #384152);
}

h1,
h2 {
    line-height: 1.2;
}

h3,
h4,
h5,
h6 {
    line-height: 1.4;
}

h1 {
    font-size: 36px;
}

@media only screen and (max-width: 1199px) {
    h1 {
        font-size: 34px;
    }
}

@media only screen and (max-width: 991px) {
    h1 {
        font-size: 32px;
    }
}

@media only screen and (max-width: 767px) {
    h1 {
        font-size: 30px;
    }
}

h2 {
    font-size: 28px;
}

@media only screen and (max-width: 1199px) {
    h2 {
        font-size: 26px;
    }
}

@media only screen and (max-width: 991px) {
    h2 {
        font-size: 24px;
    }
}

@media only screen and (max-width: 767px) {
    h2 {
        font-size: 22px;
    }
}

h3 {
    font-size: 22px;
}

@media only screen and (max-width: 991px) {
    h3 {
        font-size: 20px;
    }
}

@media only screen and (max-width: 767px) {
    h3 {
        font-size: 18px;
    }
}

h4 {
    font-size: 20px;
}

@media only screen and (max-width: 991px) {
    h4 {
        font-size: 18px;
    }
}

@media only screen and (max-width: 767px) {
    h4 {
        font-size: 16px;
    }
}

h5 {
    font-size: 18px;
}

@media only screen and (max-width: 991px) {
    h5 {
        font-size: 16px;
    }
}

/*=======================================================================
2. Template Default Style
=========================================================================*/
li.right {
    float: right;
}

a.right {
    float: right;
}

a {
    text-decoration: none;
}

a:active,
a:hover,
a:focus {
    text-decoration: none;
    outline: 0 none;
}

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

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

.fxt-content-between {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

@media only screen and (max-width: 767px) {
    .fxt-none-767 {
        display: none !important;
    }
}

@media only screen and (max-width: 991px) {
    .fxt-none-991 {
        display: none !important;
    }
}

/*========================================================================
3. Template Animation
=========================================================================*/
.fxt-template-animation {
    position: relative;
    z-index: 1;
    width: 100%;
    opacity: 0;
    overflow: hidden;
    -webkit-transition: all 0.3s ease-in-out;
    -o-transition: all 0.3s ease-in-out;
    transition: all 0.3s ease-in-out;
}

.fxt-template-animation .fxt-transformY-50 {
    opacity: 0;
    -webkit-transform: translateY(50px);
    -ms-transform: translateY(50px);
    transform: translateY(50px);
}

.loaded.fxt-template-animation {
    opacity: 1;
}

.loaded.fxt-template-animation .fxt-transformY-50 {
    -webkit-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
    opacity: 1;
    -webkit-transition: all 1s ease-in-out;
    -o-transition: all 1s ease-in-out;
    transition: all 1s ease-in-out;
}

.loaded.fxt-template-animation .fxt-transition-delay-1 {
    -webkit-transition-delay: 0.1s;
    -o-transition-delay: 0.1s;
    transition-delay: 0.1s;
}

.loaded.fxt-template-animation .fxt-transition-delay-2 {
    -webkit-transition-delay: 0.2s;
    -o-transition-delay: 0.2s;
    transition-delay: 0.2s;
}

.loaded.fxt-template-animation .fxt-transition-delay-3 {
    -webkit-transition-delay: 0.3s;
    -o-transition-delay: 0.3s;
    transition-delay: 0.3s;
}

.loaded.fxt-template-animation .fxt-transition-delay-4 {
    -webkit-transition-delay: 0.4s;
    -o-transition-delay: 0.4s;
    transition-delay: 0.4s;
}

.loaded.fxt-template-animation .fxt-transition-delay-5 {
    -webkit-transition-delay: 0.5s;
    -o-transition-delay: 0.5s;
    transition-delay: 0.5s;
}

.loaded.fxt-template-animation .fxt-transition-delay-6 {
    -webkit-transition-delay: 0.6s;
    -o-transition-delay: 0.6s;
    transition-delay: 0.6s;
}

.loaded.fxt-template-animation .fxt-transition-delay-7 {
    -webkit-transition-delay: 0.7s;
    -o-transition-delay: 0.7s;
    transition-delay: 0.7s;
}

.loaded.fxt-template-animation .fxt-transition-delay-8 {
    -webkit-transition-delay: 0.8s;
    -o-transition-delay: 0.8s;
    transition-delay: 0.8s;
}

.loaded.fxt-template-animation .fxt-transition-delay-9 {
    -webkit-transition-delay: 0.9s;
    -o-transition-delay: 0.9s;
    transition-delay: 0.9s;
}

.loaded.fxt-template-animation .fxt-transition-delay-10 {
    -webkit-transition-delay: 1s;
    -o-transition-delay: 1s;
    transition-delay: 1s;
}

.loaded.fxt-template-animation .fxt-transition-delay-11 {
    -webkit-transition-delay: 1.1s;
    -o-transition-delay: 1.1s;
    transition-delay: 1.1s;
}

.loaded.fxt-template-animation .fxt-transition-delay-12 {
    -webkit-transition-delay: 1.2s;
    -o-transition-delay: 1.2s;
    transition-delay: 1.2s;
}

.loaded.fxt-template-animation .fxt-transition-delay-13 {
    -webkit-transition-delay: 1.3s;
    -o-transition-delay: 1.3s;
    transition-delay: 1.3s;
}

/*========================================================================
4. Layout One (usado en index.php)
=========================================================================*/
.fxt-template-layout1 .fxt-bg-color {
    background-color: #ffffff;
    min-height: 100vh;
    width: 100%;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    padding: 50px 30px 42px;
}

.fxt-template-layout1 .fxt-bg-img {
    min-height: 100vh;
    width: 100%;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.fxt-template-layout1 .fxt-content {
    max-width: 450px;
    width: 100%;
}

.fxt-template-layout1 .fxt-header {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    margin-bottom: 130px;
}

@media only screen and (max-width: 767px) {
    .fxt-template-layout1 .fxt-header {
        margin-bottom: 100px;
    }
}

@media only screen and (max-width: 575px) {
    .fxt-template-layout1 .fxt-header {
        margin-bottom: 70px;
    }
}

@media only screen and (max-width: 479px) {
    .fxt-template-layout1 .fxt-header {
        margin-bottom: 50px;
    }
}

@media only screen and (max-width: 320px) {
    .fxt-template-layout1 .fxt-header {
        display: block;
    }
}

.fxt-template-layout1 .fxt-header .fxt-logo {
    display: block;
    margin-bottom: 30px;
    max-width: 40vw;
}

.fxt-template-layout1 .fxt-header .fxt-page-switcher {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    margin-bottom: 25px;
}

.fxt-template-layout1 .fxt-header .fxt-page-switcher .switcher-text1 {
    color: #111111;
    font-size: 18px;
    margin-right: 15px;
    padding-right: 15px;
    border-right: 1px solid #9f9f9f;
    line-height: 1;
    -webkit-transition: all 0.3s ease-in-out;
    -o-transition: all 0.3s ease-in-out;
    transition: all 0.3s ease-in-out;
}

@media only screen and (max-width: 575px) {
    .fxt-template-layout1 .fxt-header .fxt-page-switcher .switcher-text1 {
        margin-right: 30px;
    }
}

@media only screen and (max-width: 479px) {
    .fxt-template-layout1 .fxt-header .fxt-page-switcher .switcher-text1 {
        margin-right: 15px;
        padding-right: 10px;
        font-size: 16px;
    }
}

@media only screen and (max-width: 320px) {
    .fxt-template-layout1 .fxt-header .fxt-page-switcher .switcher-text1 {
        margin-right: 10px;
        padding-right: 5px;
    }
}

.fxt-template-layout1 .fxt-header .fxt-page-switcher .switcher-text1:last-child {
    margin-right: 0;
    padding-right: 0;
    border-right: 0;
}

.fxt-template-layout1 .fxt-header .fxt-page-switcher .switcher-text1:hover {
    color: #000000;
}

.fxt-template-layout1 .fxt-header .fxt-page-switcher .switcher-text1.active {
    color: var(--color-secundario-1-seguro, #00AAA7);
}

.fxt-template-layout1 .fxt-form {
    margin-bottom: 40px;
}

.fxt-template-layout1 .fxt-form h2 {
    font-weight: 700;
    margin-bottom: 5px;
}

.fxt-template-layout1 .fxt-form p {
    margin-bottom: 30px;
    font-size: 17px;
}

.fxt-template-layout1 .fxt-form .form-group {
    position: relative;
    z-index: 1;
}

.fxt-template-layout1 .fxt-form .form-group i {
    position: absolute;
    z-index: 1;
    right: 5px;
    top: 50%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
}

.fxt-template-layout1 .fxt-form .form-group [class^="flaticon-"]:before,
.fxt-template-layout1 .fxt-form .form-group [class*=" flaticon-"]:before,
.fxt-template-layout1 .fxt-form .form-group [class^="flaticon-"]:after,
.fxt-template-layout1 .fxt-form .form-group [class*=" flaticon-"]:after {
    margin-left: 0;
    font-size: 17px;
    color: #a1a1a1;
}

.fxt-template-layout1 .fxt-form .form-control {
    min-height: 40px;
    -webkit-box-shadow: none;
    box-shadow: none;
    border: 0;
    border-bottom: 1px solid #e7e7e7;
    padding: 10px 30px 10px 0;
    color: #111111;
}

.fxt-template-layout1 .fxt-form input::-webkit-input-placeholder {
    color: #a1a1a1;
    font-size: 15px;
    font-weight: 300;
}

.fxt-template-layout1 .fxt-form input::-moz-placeholder {
    color: #a1a1a1;
    font-size: 15px;
    font-weight: 300;
}

.fxt-template-layout1 .fxt-form input:-moz-placeholder {
    color: #a1a1a1;
    font-size: 15px;
    font-weight: 300;
}

.fxt-template-layout1 .fxt-form input:-ms-input-placeholder {
    color: #a1a1a1;
    font-size: 15px;
    font-weight: 300;
}

.fxt-template-layout1 .fxt-btn-fill {
    margin-top: 15px;
    font-family: 'Roboto', sans-serif;
    cursor: pointer;
    display: inline-block;
    font-size: 17px;
    font-weight: 500;
    -webkit-box-shadow: none;
    box-shadow: none;
    outline: none;
    border: 0;
    color: var(--color-texto-claro, #FFFFFF);
    border-radius: 3px;
    background-color: var(--color-secundario-1, #00AAA7);
    padding: 10px 36px;
    margin-bottom: 10px;
    -webkit-transition: all 0.3s ease-in-out;
    -o-transition: all 0.3s ease-in-out;
    transition: all 0.3s ease-in-out;
}

.fxt-template-layout1 .fxt-btn-fill:hover {
    background-color: var(--color-secundario-1-hover, #008F8C);
}

.fxt-template-layout1 .fxt-btn-fill:focus {
    outline: none;
}

.fxt-template-layout1 .switcher-text2 {
    color: #9f9f9f;
    font-size: 15px;
    margin-top: 5px;
    display: block;
    -webkit-transition: all 0.3s ease-in-out;
    -o-transition: all 0.3s ease-in-out;
    transition: all 0.3s ease-in-out;
}

.fxt-template-layout1 .switcher-text2:last-child {
    margin-right: 0;
}

.fxt-template-layout1 .switcher-text2:hover {
    color: #666;
}

.fxt-template-layout1 .switcher-text2.active {
    color: #666;
}

.fxt-template-layout1 ul.fxt-socials li {
    display: inline-block;
    margin-right: 4px;
    margin-bottom: 8px;
}

@media only screen and (max-width: 575px) {
    .fxt-template-layout1 ul.fxt-socials li {
        margin-right: 2px;
    }
}

.fxt-template-layout1 ul.fxt-socials li:last-child {
    margin-right: 0;
}

.fxt-template-layout1 ul.fxt-socials li a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    font-size: 14px;
    height: 40px;
    width: 40px;
    color: #ffffff;
    border-radius: 50%;
    border: 1px solid;
    -webkit-transition: all 0.3s ease-in-out;
    -o-transition: all 0.3s ease-in-out;
    transition: all 0.3s ease-in-out;
}

.fxt-template-layout1 ul.fxt-socials li.fxt-facebook a {
    background-color: #3b5998;
    border-color: #3b5998;
}

.fxt-template-layout1 ul.fxt-socials li.fxt-facebook a:hover {
    background-color: transparent;
    color: #3b5998;
}

.fxt-template-layout1 ul.fxt-socials li.fxt-twitter a {
    background-color: #00acee;
    border-color: #00acee;
}

.fxt-template-layout1 ul.fxt-socials li.fxt-twitter a:hover {
    background-color: transparent;
    color: #00acee;
}

.fxt-template-layout1 ul.fxt-socials li.fxt-google a {
    background-color: #CC3333;
    border-color: #CC3333;
}

.fxt-template-layout1 ul.fxt-socials li.fxt-google a:hover {
    background-color: transparent;
    color: #CC3333;
}

.fxt-template-layout1 ul.fxt-socials li.fxt-instagram a {
    background-color: #3f729b;
    border-color: #3f729b;
}

.fxt-template-layout1 ul.fxt-socials li.fxt-instagram a:hover {
    background-color: transparent;
    color: #3f729b;
}

.fxt-template-layout1 ul.fxt-socials li.fxt-linkedin a {
    background-color: #0077B5;
    border-color: #0077B5;
}

.fxt-template-layout1 ul.fxt-socials li.fxt-linkedin a:hover {
    background-color: transparent;
    color: #0077B5;
}

.fxt-template-layout1 ul.fxt-socials li.fxt-youtube a {
    background-color: #c4302b;
    border-color: #c4302b;
}

.fxt-template-layout1 ul.fxt-socials li.fxt-youtube a:hover {
    background-color: transparent;
    color: #c4302b;
}

.fxt-template-layout1 ul.fxt-socials li.fxt-pinterest a {
    background-color: #bd081c;
    border-color: #bd081c;
}

.fxt-template-layout1 ul.fxt-socials li.fxt-pinterest a:hover {
    background-color: transparent;
    color: #bd081c;
}

.fxt-template-layout1 .fxt-footer {
    text-align: center;
}

/*========================================================================
5. Layout Twenty Nine (usado en login.php, login_ldap.php)
   COLORES: Usa variables CSS institucionales
=========================================================================*/
.fxt-template-layout29 .fxt-checkbox-area {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    margin-bottom: 30px;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

.fxt-template-layout29 .fxt-bg-color {
    background-color: #ffffff;
    min-height: 100vh;
    width: 100%;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    padding: 60px 30px 52px;
}

@media only screen and (max-width: 767px) {
    .fxt-template-layout29 .fxt-bg-color {
        min-height: 100%;
    }
}

@media only screen and (max-width: 575px) {
    .fxt-template-layout29 .fxt-bg-color {
        padding: 50px 15px 42px;
    }
}

.fxt-template-layout29 .fxt-bg-img {
    min-height: 100vh;
    width: 100%;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    padding: 50px 15px 30px;
}

.fxt-template-layout29 .fxt-page-switcher {
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    right: 0;
}

@media only screen and (max-width: 767px) {
    .fxt-template-layout29 .fxt-page-switcher {
        top: calc(100% - 48px);
        -webkit-transform: translateY(0);
        -ms-transform: translateY(0);
        transform: translateY(0);
        left: 0;
        text-align: center;
    }
}

.fxt-template-layout29 .fxt-page-switcher .switcher-text1 {
    text-align: right;
    display: block;
    color: var(--color-principal-seguro, #384152);
    font-size: 18px;
    font-weight: 500;
    padding: 20px 30px;
    background-color: var(--color-secundario-2, #BAD00C);
    margin: 2px 0;
    border-radius: 45px 0 0 45px;
    line-height: 1;
    -webkit-transition: all 0.3s ease-in-out;
    -o-transition: all 0.3s ease-in-out;
    transition: all 0.3s ease-in-out;
}

@media only screen and (max-width: 767px) {
    .fxt-template-layout29 .fxt-page-switcher .switcher-text1 {
        display: inline-block;
        margin: 0 2px;
        border-radius: 10px 10px 0 0;
        padding: 15px 30px;
    }
}

.fxt-template-layout29 .fxt-page-switcher .switcher-text1:hover {
    color: var(--color-texto-claro, #FFFFFF);
}

.fxt-template-layout29 .fxt-page-switcher .switcher-text1.active {
    color: var(--color-texto-claro, #FFFFFF);
    background-color: var(--color-secundario-1, #00AAA7);
}

.fxt-template-layout29 .fxt-page-switcher .switcher-text1.active:hover {
    color: var(--color-principal-seguro, #384152);
}

.fxt-template-layout29 .fxt-page-switcher .switcher-text1.secundary {
    color: var(--color-principal-seguro, #384152);
    background-color: #BCBCBC;
}

.fxt-template-layout29 .fxt-page-switcher .switcher-text1.secundary:hover {
    color: var(--color-texto-claro, #FFFFFF);
}

.fxt-template-layout29 .fxt-content {
    max-width: 450px;
    width: 100%;
}

@media only screen and (max-width: 767px) {
    .fxt-template-layout29 .fxt-content {
        text-align: center;
    }
}

.fxt-template-layout29 .fxt-header .fxt-logo {
    display: block;
    margin-bottom: 100px;
    max-width: 40vw;
}

@media only screen and (max-width: 767px) {
    .fxt-template-layout29 .fxt-header .fxt-logo {
        margin-left: auto;
        margin-right: auto;
        margin-bottom: 60px;
    }
}

.fxt-template-layout29 .fxt-form {
    margin-bottom: 40px;
}

.fxt-template-layout29 .fxt-form h2 {
    font-weight: 700;
    margin-bottom: 5px;
}

.fxt-template-layout29 .fxt-form p {
    margin-bottom: 30px;
    font-size: 17px;
}

.fxt-template-layout29 .fxt-form .form-group {
    position: relative;
    z-index: 1;
}

.fxt-template-layout29 .fxt-form .form-group i {
    position: absolute;
    z-index: 1;
    right: 5px;
    top: 50%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
}

.fxt-template-layout29 .fxt-form .form-group [class^="flaticon-"]:before,
.fxt-template-layout29 .fxt-form .form-group [class*=" flaticon-"]:before,
.fxt-template-layout29 .fxt-form .form-group [class^="flaticon-"]:after,
.fxt-template-layout29 .fxt-form .form-group [class*=" flaticon-"]:after {
    margin-left: 0;
    font-size: 17px;
    color: #a1a1a1;
}

.fxt-template-layout29 .fxt-form .form-control {
    min-height: 40px;
    color: var(--color-texto-claro, #FFFFFF);
    background-color: #495057;
    -webkit-box-shadow: none;
    box-shadow: none;
    border: 0;
    border-bottom: 1px solid var(--color-principal, #384152);
    padding: 10px 30px 10px 0;
}

.fxt-template-layout29 .fxt-form input::-webkit-input-placeholder {
    color: #a1a1a1;
    font-size: 15px;
    font-weight: 300;
}

.fxt-template-layout29 .fxt-form input::-moz-placeholder {
    color: #a1a1a1;
    font-size: 15px;
    font-weight: 300;
}

.fxt-template-layout29 .fxt-form input:-moz-placeholder {
    color: #a1a1a1;
    font-size: 15px;
    font-weight: 300;
}

.fxt-template-layout29 .fxt-form input:-ms-input-placeholder {
    color: #a1a1a1;
    font-size: 15px;
    font-weight: 300;
}

.fxt-template-layout29 .fxt-btn-fill {
    margin-top: 15px;
    font-family: 'Roboto', sans-serif;
    cursor: pointer;
    display: inline-block;
    font-size: 17px;
    font-weight: 700;
    -webkit-box-shadow: none;
    box-shadow: none;
    outline: none;
    border: 0;
    color: var(--color-texto-claro, #FFFFFF);
    border-radius: 3px;
    background-color: var(--color-secundario-1, #00AAA7);
    padding: 10px 36px;
    margin-bottom: 10px;
    -webkit-transition: all 0.3s ease-in-out;
    -o-transition: all 0.3s ease-in-out;
    transition: all 0.3s ease-in-out;
}

.fxt-template-layout29 .fxt-btn-fill:hover {
    background-color: var(--color-secundario-2, #BAD00C);
    border-color: var(--color-secundario-2-hover, #a8b52b);
    color: var(--color-principal-seguro, #384152);
}

.fxt-template-layout29 .fxt-btn-fill:focus {
    outline: none;
}

.fxt-template-layout29 .switcher-text2 {
    color: #9f9f9f;
    font-size: 15px;
    margin-top: 5px;
    display: block;
    -webkit-transition: all 0.3s ease-in-out;
    -o-transition: all 0.3s ease-in-out;
    transition: all 0.3s ease-in-out;
}

.fxt-template-layout29 .switcher-text2:last-child {
    margin-right: 0;
}

.fxt-template-layout29 .switcher-text2:hover {
    color: #666;
}

.fxt-template-layout29 .switcher-text2.active {
    color: #666;
}

.fxt-template-layout29 ul.fxt-socials li {
    display: inline-block;
    margin-right: 4px;
    margin-bottom: 8px;
}

@media only screen and (max-width: 575px) {
    .fxt-template-layout29 ul.fxt-socials li {
        margin-right: 2px;
    }
}

.fxt-template-layout29 ul.fxt-socials li:last-child {
    margin-right: 0;
}

.fxt-template-layout29 ul.fxt-socials li a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    font-size: 14px;
    height: 40px;
    width: 40px;
    color: #ffffff;
    border-radius: 50%;
    border: 1px solid;
    -webkit-transition: all 0.3s ease-in-out;
    -o-transition: all 0.3s ease-in-out;
    transition: all 0.3s ease-in-out;
}

.fxt-template-layout29 ul.fxt-socials li.fxt-facebook a {
    background-color: #3b5998;
    border-color: #3b5998;
}

.fxt-template-layout29 ul.fxt-socials li.fxt-facebook a:hover {
    background-color: transparent;
    color: #3b5998;
}

.fxt-template-layout29 ul.fxt-socials li.fxt-twitter a {
    background-color: #00acee;
    border-color: #00acee;
}

.fxt-template-layout29 ul.fxt-socials li.fxt-twitter a:hover {
    background-color: transparent;
    color: #00acee;
}

.fxt-template-layout29 ul.fxt-socials li.fxt-google a {
    background-color: #CC3333;
    border-color: #CC3333;
}

.fxt-template-layout29 ul.fxt-socials li.fxt-google a:hover {
    background-color: transparent;
    color: #CC3333;
}

.fxt-template-layout29 ul.fxt-socials li.fxt-instagram a {
    background-color: #3f729b;
    border-color: #3f729b;
}

.fxt-template-layout29 ul.fxt-socials li.fxt-instagram a:hover {
    background-color: transparent;
    color: #3f729b;
}

.fxt-template-layout29 ul.fxt-socials li.fxt-linkedin a {
    background-color: #0077B5;
    border-color: #0077B5;
}

.fxt-template-layout29 ul.fxt-socials li.fxt-linkedin a:hover {
    background-color: transparent;
    color: #0077B5;
}

.fxt-template-layout29 ul.fxt-socials li.fxt-youtube a {
    background-color: #c4302b;
    border-color: #c4302b;
}

.fxt-template-layout29 ul.fxt-socials li.fxt-youtube a:hover {
    background-color: transparent;
    color: #c4302b;
}

.fxt-template-layout29 ul.fxt-socials li.fxt-pinterest a {
    background-color: #bd081c;
    border-color: #bd081c;
}

.fxt-template-layout29 ul.fxt-socials li.fxt-pinterest a:hover {
    background-color: transparent;
    color: #bd081c;
}

.fxt-template-layout29 .fxt-footer h3 {
    font-size: 18px;
    font-weight: 500;
}
