/* -------------------------------------------------------------------------------------------------------------------*/
/* Recursos generales importados                                                                                      */
/* -------------------------------------------------------------------------------------------------------------------*/

@import url('https://fonts.googleapis.com/css2?family=Roboto:wght@400;500;600;700&display=swap');

/* -------------------------------------------------------------------------------------------------------------------*/
/* Definiciones generales                                                                                             */
/* -------------------------------------------------------------------------------------------------------------------*/

html, body {
    color: #333;
}

body {
    font-family: "Roboto", Helvetica Neue, Helvetica, Arial, sans-serif;
    font-size: 14px;
    line-height: 1.42857143;
    color: #333333;
    background-color: #F7F7F7;
    min-height: 100vh; /* mantener optimización */
}

a { color: #0aa4a1; cursor: pointer; }
a:hover, a:focus { color: #077472; }

header { background-color: #F7F7F7; margin-bottom: 10px; }

label {
    color: #333;
}

/* -------------------------------------------------------------------------------------------------------------------*/
/* Barra de navegacion                                                                                                */
/* -------------------------------------------------------------------------------------------------------------------*/

.navbar.navbar-default {
    background-color: #F7F7F7;
    color: #333;
    z-index: 1030;
}

.navbar-default .navbar-brand { color: #0aa4a1; }

.navbar-default .navbar-brand.user {
    color: #0aa4a1;
    margin: 0;
    padding: 8px 10px;
    border-bottom: 3px solid transparent;
    line-height: 1.5;
    font-size: 16px;
    display: flex;
    align-items: center;
}

.navbar-brand:hover { color: #077472; }

.navbar-default .navbar-nav > li { margin: 0 3px; }

.navbar-default .navbar-nav > li > a {
    color: #0aa4a1;
    text-decoration: none;
    border-bottom: 3px solid transparent;
    padding: 8px 10px;
    line-height: 1.5;
    font-size: 16px;
    display: flex;
    align-items: center;
}

.navbar-default .navbar-nav > li > a:hover,
.navbar-default .navbar-nav > li > a:focus,
.navbar-default a.user:hover,
.navbar-default a.user:focus {
    color: #077472;
    border-bottom-color: #077472; /* acento */
}

.navbar-toggler { color: #333; border: 1px solid #00000030; padding: 4px 8px; }

.navbar-toggler-icon { width: 1.5em; height: 1.5em; background-image: none; }

.navbar-toggler-icon:before {
    font-family: "Fontawesome", "Font Awesome 6 Free", "Font Awesome 6 Pro", "Font Awesome 5 Free", Arial, sans-serif;
    font-weight: 900;
    content: "\f0c9";
    display: block;
    line-height: 1;
    font-size: 20px;
    color: #333;
}

.navbar-header { display: flex; align-items: center; gap: 10px; }

.navbar.navbar-default .container { display: flex; align-items: center; flex-wrap: wrap; }

#navbarContainer { margin-left: auto; }

.navbar-default .navbar-brand.user,
#navbarContainer .navbar-nav > li > a,
#navbarContainer .navbar-nav .nav-link {
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

header .w-100 h1 { margin: 10px 0; text-align: center; }

#navbarContainer .navbar-nav {
    align-items: center;
    flex-wrap: nowrap;
}

#navbarContainer .navbar-nav .nav-item {
    display: flex;
    align-items: center;
}

#navbarContainer .navbar-nav > li > a,
#navbarContainer .navbar-nav .nav-link {
    display: flex;
    align-items: center;
    gap: 6px; /* small space between possible text and icon */
    white-space: nowrap; /* keep each menu label on a single line */
    font-size: 16px;
    padding: 8px 10px;
}

#navbarContainer .navbar-nav i {
    line-height: 1; /* avoid extra vertical space on icon */
}

/* -------------------------------------------------------------------------------------------------------------------*/
/* Logo                                                                                                               */
/* -------------------------------------------------------------------------------------------------------------------*/

#logo {
    display: block;
    margin: 10px auto 20px auto;
    content: url('../img/logos/logo_default.png');
    width: 150px;
    height: auto;
}

/* -------------------------------------------------------------------------------------------------------------------*/
/* Area de contenido (general)                                                                                        */
/* -------------------------------------------------------------------------------------------------------------------*/

.container {
    overflow-x: hidden;
}

.container .main {
    box-sizing: border-box;
    background: #ffffff;
    padding: 15px 0 50px 0;
    border: 1px solid #dddddd;
    border-radius: 5px;
    margin: 0 auto;
    box-shadow: 1px 1px 1px rgba(0,0,0,0.2);
}

.container .main,
.container .main p,
.container .main li {
    color: #333333;
}

.container .main .text-muted,
.container .main .form-text,
.container .main .help-block,
.container .main small {
    color: #6c757d;
}

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

.container h1.header {
    border-bottom: 1px solid #DBDFEA;
    background: none;
    color: #0aa4a1;
    font-size: 22px;
    padding: 15px 0 30px 0;
    margin-top: 0;
}

.container .main .btn-primary {
    font-size: 22px;
    padding: 8px 20px;
}

.container .main.row {
    -webkit-box-shadow: none !important;
    box-shadow: none !important;
}

/* Estilo general a la columna contenedora del formulario de alta */
.container .main .col {
    padding-left: 30px;
    padding-right: 30px;
}

h1.header {
    background-color: #0AA4A1;
    color: #FFF;
    padding: 0.5rem;
    margin-bottom: 20px;
    text-align: center;
    line-height: 1.4em;
}

.header { color: #0aa4a1; }

fieldset { border: 0; margin: 0; padding: 0; }

.form-group {
    margin-bottom: 30px;
}

.form-group input.form-control,
.form-group select.form-control {
    font-size: 15px;
}

.form-group input.form-control,
.form-group select.form-control,
.form-group textarea.form-control,
.form-group .form-control,
.form-group .form-select {
    width: 100%;
}

.form-control {
    border: 1px solid #ced4da;
}

.form-control:hover,
.form-control:focus {
    border-color: #0aa4a1;
    box-shadow: none;
}

.form-control,
.form-select,
input[type="text"],
input[type="password"],
input[type="email"],
input[type="number"],
input[type="search"],
input[type="tel"],
input[type="url"],
textarea {
    background-color: #ffffff;
    color: #000000;
}

.btn { font-size: 16px; padding: 12px 20px; }
.btn-primary { color: #ffffff; background-color: #0aa4a1; border-color: #098c89; }
.btn-primary:hover, .btn-primary:focus { color: #ffffff; background-color: #077472; border-color: #055251; }

.btn-lg { font-size: 22px; padding: 8px 20px; }
.btn-block { display: block; width: 100%; }

.center-block { display: block; margin-left: auto; margin-right: auto; float: none; }

.input-group {
    display: flex;
    align-items: center;
}

.input-group > .form-control {
    flex: 1 1 auto;
}

.input-group .input-group-btn {
    display: contents;
}

.input-group .btn {
    margin-left: 8px;
    white-space: nowrap;
}

label,
legend,
fieldset legend {
    color: #333;
}

/* -------------------------------------------------------------------------------------------------------------------*/
/* Area de contenido (cuenta correo)                                                                                  */
/* -------------------------------------------------------------------------------------------------------------------*/

#data-and-steps * {
    color: black;
}

.span-tyc {
    color: black;
}

.a-tyc {
    color: #2DD4BF;
}

.step-2-div-code, .step-2-div-code label, .masked-email, h1, h2, div.text-muted > small {
    color: black;
}

i.fa.fa-eye, i.fa.fa-eye-slash {
    color: #1A2E35;
}

#formulario .form-group input.form-control, .form-group select.form-control {
    margin: 0 !important;
}

input::placeholder {
    font-weight: 700;
    opacity: 0.7;
    font-size: 16px;
    font-family: "Roboto", Helvetica Neue, Helvetica, Arial, sans-serif;
}

div.wall * {
    color: black;
}

* {
    font-family: "Roboto", Helvetica Neue, Helvetica, Arial, sans-serif;
    box-sizing: border-box;
}

.form-control {
    display: block !important;
    width: 100% !important;
    font-weight: 400 !important;
    color: #495057 !important;
    background-color: #fff !important;
    background-clip: padding-box !important;
    border: 1px solid #ced4da !important;
    transition: border-color .15s ease-in-out, box-shadow .15s ease-in-out !important;
}

.form-control:hover,
.form-control:focus {
    border-color: #0aa4a1;
    box-shadow: none;
}

.form-control-lg {
    height: 48px !important;
    padding: .5rem 1rem;
    font-size: 20px !important;
    line-height: 1.5;
    border-radius: .3rem;
}

button, input, optgroup, select, textarea {
    margin: 0;
    font-family: inherit;
    font-size: inherit;
    line-height: inherit;
}

/* Campos de formulario con fondo blanco y texto negro */
.form-control,
.form-select,
input[type="text"],
input[type="password"],
input[type="email"],
input[type="number"],
input[type="search"],
input[type="tel"],
input[type="url"],
textarea {
    background-color: #ffffff;
    color: #000000;
}

.input-group input {
    border-right: 0;
}

.input-group-text {
    background-color: white !important;
    border: 1px solid #ced4da !important;
    border-left: 0 !important;
    color: #0aa4a1 !important;
}

.input-group {
    position: relative !important;
    display: -ms-flexbox !important;
    display: flex !important;
    -ms-flex-wrap: wrap !important;
    flex-wrap: wrap !important;
    -ms-flex-align: stretch !important;
    align-items: stretch !important;
    width: 100% !important;
}

.input-group:not(.has-validation) > .custom-file:not(:last-child) .custom-file-label::after, .input-group:not(.has-validation) > .custom-select:not(:last-child), .input-group:not(.has-validation) > .form-control:not(:last-child) {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
}

.input-group > .custom-file, .input-group > .custom-select, .input-group > .form-control, .input-group > .form-control-plaintext {
    position: relative !important;
    -ms-flex: 1 1 auto !important;
    flex: 1 1 auto !important;
    width: 1% !important;
    min-width: 0 !important;
    margin-bottom: 0 !important;
}

.input-group-append {
    margin-left: -1px;
}

.input-group-append, .input-group-prepend {
    display: -ms-flexbox;
    display: flex;
}

#btn-continuar {
    width: 100%;
}

#btn-enviar-codigo {
    width: 100%;
}

.fa, .fas {
    cursor: pointer;
}

/* -------------------------------------------------------------------------------------------------------------------*/
/* Formulario de contacto                                                                                             */
/* -------------------------------------------------------------------------------------------------------------------*/

#helpContainer {
    margin: 30px;
    padding-left: 20px;
    font-size: 16px;
}

#helpContainer ::marker {
    color: #006cd8;
    font-weight: bold;
}

#helpContainer {
    font-size: 14px;
    color: whitesmoke;
}

#contactoContainer {
    margin: 30px;
    font-size: 16px;
}

#contactoContainer ::marker {
    color: #006cd8;
    font-weight: bold;
}

#contactoContainer {
    font-size: 14px;
}

/* Aplicar solo a las cards dentro del #contactoContainer */
#contactoContainer .card {
    border: 1px solid rgba(255, 255, 255, 0.18); /* resalta levemente el borde sobre fondo oscuro */
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.35); /* sutil elevación para destacar la card */
    padding: 20px !important;
}

#contactoContainer .card .card-header,
#contactoContainer .card .card-body,
#contactoContainer .card .card-footer {
    color: inherit;
    background-color: inherit;
}

/* -------------------------------------------------------------------------------------------------------------------*/
/* Mensajeria y feedback                                                                                              */
/* -------------------------------------------------------------------------------------------------------------------*/

.feedbackPanel {
    display: block;
    padding: 0;
    margin: 0.5rem 0;
    list-style: none;
    width: 100%;
}

.feedbackPanel li,
.feedbackPanel .errorMessage {
    width: 100%;
}

.feedbackPanel .errorMessage span {
    display: block;
    width: 100%;
    background: #ad262b;
    color: #fff;
    border-radius: 4px;
    font-size: 12px;
    font-style: italic;
    padding: 5px 8px;
    margin-top: 4px;
    margin-bottom: 0.5rem;
}

fieldset .feedbackPanel { margin: 0; }

ul.feedbackPanel li { background-color: transparent !important; color: inherit; }

#id-custom-feedback-panel {
    margin: 0;
    padding: 0 95px 20px 95px;
    width: 100%;
    box-sizing: border-box;
}

#id-custom-feedback-panel .feedbackPanel { margin: 0; }

.alert {
    display: flex;
    align-items: center;
    padding: 10px 20px;
}

.alert span {
    display: flex;
    align-items: center;
}

.alert-success {
    background-color: #fff;
    border-color: #127f36;
    color: #555555;
}

.alert-success:before {
    display: block;
    float: left;
    font-size: 32px;
    color: #127f36;
    line-height: 1.3;
    margin-right: 10px;
}

.alert-success hr {
    border-top-color: #127f36;
}

.alert-success .alert-link {
    color: #3c3c3c;
}

.alert-info {
    background-color: #fff;
    border-color: #0aa4a1;
    color: #555555;
}

.alert-info:before {
    display: block;
    float: left;
    font-size: 32px;
    color: #0aa4a1;
    line-height: 1.3;
    margin-right: 10px;
}

.alert-warning {
    background-color: #fff;
    border-color: #d9534f;
    color: #555555;
}

.alert-warning:before {
    display: block;
    float: left;
    font-size: 32px;
    color: #d9534f;
    line-height: 1.3;
    margin-right: 10px;
}

.alert-warning hr {
    border-top-color: #cf9c69;
}

.alert-warning .alert-link {
    color: #3c3c3c; /* antes: #3c3c3c */
    text-decoration: underline;
}

.alert-danger {
    background-color: transparent;
    border-color: #d9534f;
    color: #555555;
}

.alert-danger:before {
    display: block;
    float: left;
    font-size: 32px;
    color: #d9534f;
    line-height: 1.3;
    margin-right: 10px;
}

.alert-danger hr {
    border-top-color: #982226;
}

.alert-danger .alert-link {
    color: #3c3c3c;
}

/* -------------------------------------------------------------------------------------------------------------------*/
/* Captcha                                                                                                            */
/* -------------------------------------------------------------------------------------------------------------------*/

.captcha {
    background-color: inherit !important;
    border: 0 !important;
    border-radius: 0;
    box-shadow: none !important;
    padding: 1.25rem;
    display: flex;
    justify-content: center;
}

.captcha .g-recaptcha {
    display: block;
    margin: 0 auto;
}

.captcha .box-captcha {
    display: flex;
    flex-direction: column;
    align-items: center;
}

#g-recaptcha-feedback {
    text-align: center;
}

.captcha .img-captcha {
    height: auto;
    max-width: 300px;
    width: 100%;
}

/* -------------------------------------------------------------------------------------------------------------------*/
/* Media queries                                                                                                      */
/* -------------------------------------------------------------------------------------------------------------------*/

@media (min-width: 1200px) {
    .container {
        max-width: 800px;
    }
}

@media (max-width: 1024px) {
    header { background: #F7F7F7; }
    .navbar-brand { color: #0aa4a1; padding-top: 0; padding-bottom: 0; }
    .navbar-collapse { padding: 0; }
    .navbar-collapse .navbar-nav > li { border-bottom: 1px solid #e5e5e5; padding: 10px 15px; margin: 0; }
    .navbar-collapse .navbar-nav > li a { color: #0aa4a1; }
    .navbar-header { width: 100%; justify-content: space-between; }
    .navbar-toggler { margin-left: auto; }
    .navbar-default .navbar-nav > li > a:hover,
    .navbar-default .navbar-nav > li > a:focus,
    .navbar-default .navbar-brand.user:hover,
    .navbar-default .navbar-brand.user:focus { border: none; }
}

@media (max-width: 991px) {
    #navbarContainer .navbar-nav {
        flex-wrap: wrap;
        row-gap: 4px;
    }
}

@media (min-width: 768px) and (max-width: 991px) {
    #id-custom-feedback-panel {
        padding-left: 30px;
        padding-right: 30px;
    }
}

@media (max-width: 767px) {
    #id-custom-feedback-panel {
        padding: 0 20px 16px 20px;
    }
}

@media only screen and (max-width: 599px) {
    /* Navbar fija arriba, por encima del resto */
    .navbar.navbar-default {
        position: fixed;
        left: 0;
        top: 0;
        width: 100%;
        background: #F7F7F7;
        z-index: 1030; /* alineado con Bootstrap */
    }

    /* El header reserva espacio para la navbar fija y contiene al logo */
    header {
        background: #F7F7F7;
        height: auto;          /* evita recortes del logo */
        padding-top: 56px;     /* compensación por la navbar fija */
        padding-bottom: 8px;   /* aire bajo el logo */
    }

    /* Logo/título centrados y compactos */
    header .w-100 h1 {
        margin: 8px 0 0 0;
        text-align: center;
    }

    /* Importante: evitar doble compensación global */
    body { padding-top: 0; }

    /* El contenido principal arranca debajo del header (logo) */
    .container .main {
        margin-top: 80px;
    }

    /* Botón principal a ancho completo en móviles chicos */
    .container .main .btn-primary {
        display: block;
        width: 100%;
        font-size: 18px;
    }

    /* Logo responsive */
    #logo {
        width: 120px;
        height: auto;
    }

    /* Si el navegador enfoca feedback/errores, que no queden ocultos bajo la navbar fija */
    #id-custom-feedback-panel,
    #id-custom-feedback-panel .feedbackPanel,
    #id-custom-feedback-panel .alert,
    #id-custom-feedback-panel .errorMessage,
    #id-custom-feedback-panel .errorMessage span {
        scroll-margin-top: 64px;
    }

}
