*, *:before, *:after {
    box-sizing: border-box;
}

html {
    overflow-y: scroll;
}

body {
   /* background: #a7d7fb ;*/
    font-family: 'Titillium Web', sans-serif;
}

.footer {
    position: static;
    left: 0;
    bottom: 0;
    width: 100%;
    /*background-color: #a7d7fb;
*/    color: #3c3c3c;
    text-align: center;
 }

input::placeholder {
    color: #3e3e3e;
    font-size: 0.8em;
  }

.alinear-logo{
    display: block;
    margin-left: auto;
    margin-right: auto;
    width: 50%;
    margin-bottom: 20px;
}
.h1, h1 {
    font-size: 2rem;
}
a {
    text-decoration: none;
    color:#36b6ea;
    transition: .5s ease;
}
a:hover {
    color: #56abf0;
}

.form {
    background-color: rgba(255, 255, 255, 0.941);
    padding: 40px;
    max-width: 600px;
    margin: 40px auto;
    border-radius: 4px;
    box-shadow: 7px 12.124px 54px 0px rgba(30, 48, 138, 0.08);
    height: 100%;
}

.tab-group {
    list-style: none;
    padding: 0;
    margin: 0 0 40px 0;
}
.tab-group:after {
    content: "";
    display: table;
    clear: both;
}
.tab-group li a {
      display: block;
    text-decoration: none;
    padding: 15px;
    color: #131524;
    font-size: 20px;
    font-weight: 700;
    float: left;
    width: 50%;
    text-align: center;
    cursor: pointer;
    transition: .5s ease;
    border: 1px solid transparent;
    border-bottom: 1px solid rgb(202, 207, 230);
}
.tab-group li a:hover {
        color: #36b6ea;
}
.tab-group .active a {
        color: #36b6ea;
    border: 1px solid rgb(202, 207, 230);
    border-bottom: transparent;
}

.tab-content > div:last-child {
    display: none;
}

h1 {
    text-align: center;
    color: #131524;
    font-weight: 700;
    margin: 0 0 40px;
    font-size: 36px;
}

.label-frm {
    position: absolute;
    transform: translateY(11px);
    left: 13px;
    color: #3e3e3e;
    transition: all 0.25s ease;
    -webkit-backface-visibility: hidden;
    pointer-events: none;
    font-size: 1rem;
}
.label-frm .req {
    margin: 2px;
   color: #131524;
}

.label-frm.active {
    transform: translateY(50px);
    left: 2px;
    font-size: 14px;
}
.label-frm.active .req {
    opacity: 0;
}

.label-frm.highlight {
    color: #3e3e3e;
}

input, textarea {
    font-size: 21px;
    display: block;
    width: 100%;
    height: 100%;
    padding: 10px 10px;
    background: none;
    background-image: none;
    border: 1px solid rgb(202, 207, 230);
    color: #3e3e3e;
    border-radius: 0;
    transition: border-color .25s ease, box-shadow .25s ease;
}

input:focus, textarea:focus {
    outline: 0;
    border-color: #56abf0;
}

textarea {
    border: 2px solid #a0b3b0;
    resize: vertical;
}

.box-perent:after {
    content: "";
    position: absolute;
    background: url(/familias/assets/media/box.png) no-repeat center center;
    background-size: contain;
    width: 21px;
    height: 21px;
    top: 11px;
    right: 9px;
}
.lock-perent:after {
    content: "";
    position: absolute;
    background: url(/familias/assets/media/lock.png) no-repeat center center;
    background-size: contain;
    width: 21px;
    height: 21px;
    top: 11px;
    right: 9px;
}
.field-wrap {
    position: relative;
    margin-bottom: 20px;
}

.top-row:after {
    content: "";
    display: table;
    clear: both;
}
.top-row > div {
    float: left;
    width: 48%;
    margin-right: 4%;
}
.top-row > div:last-child {
    margin: 0;
}

.button {
       border: 0;
    outline: none;
    border-radius: 0;
    padding: 15px 0;
    font-size: 2rem;
    font-weight: 600;
    text-transform: uppercase;
    background: #36b6ea;
    color: #ffffff;
    transition: all 0.5s ease;
    -webkit-appearance: none;
    background-color: rgb(54, 182, 234);
    box-shadow: 10.725px 8.999px 40px 0px rgb(0 91 182 / 14%);
}

.button:hover, .button:focus {
    background: #56abf0;
}

.button-block {
    display: block;
    width: 100%;
}

.forgot {
    margin-top:20px;
    text-align: right;
}

.background-image {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
}

.background-image::after {
    content: "";
    z-index: 10;
    background-color: rgba(0, 0, 0, 0.75);
    /*width: 100%;
    height: 100%;*/
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    left: 0;
}

.background-image img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
}

.particles-background {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 1;
}

.card {
    background-color: rgba(70, 70, 70, 0.85);
    min-height: 250px;
    font-size: 2.5rem;
    color: #3e3e3e;
    display: flex;
    flex-direction: row;
}

.card:hover {
    cursor: pointer;
    background-color: #56abf0;
    color: #3e3e3e;
}

.card:hover .card-icon {
    font-size: 3.5rem;
}

.table {
    background-color: rgba(240, 244, 245, 0.85);
}

.styled-table {
    border-collapse: collapse;
    margin: 25px 0;
    font-size: 0.9em;
    font-family: sans-serif;
    min-width: 400px;
    box-shadow: 0 0 20px rgba(0, 0, 0, 0.15);
}


.label .req {
    color: red;
}

input[type='checkbox'] {
    height: inherit !important;

}

#terms_section {
    color: rgb(33, 33, 33);
    text-decoration: underline;
}

@media (max-width: 1200px) {
    .modal-xl {
        max-width: 1100px;
    }
}

.radio-input {
    visibility: hidden;
}
.radio-label {
    position: relative;
    padding-left: 35px;
}
.radio-label:after {
    content: "";
    display: block;
    width: 20px;
    height: 20px;
    position: absolute;
    left: 0px;
    top: 0px;
    border-radius: 50%;
}
.radio-border {
   width: 20px;
    height: 20px;
    display: inline-block;
    position: absolute;
    left: 0px;
    top: 0px;
    border-style: solid;
    border-width: 1px;
    border-color: rgb(202, 207, 230);
    border-radius: 50%;
}
.radio-input:checked + .radio-label:after {
    transition: all 0.5s;
    background-color: #fff;
    border: 6px solid rgb(54, 182, 234);
}

.bottom-row:after {
    content: "";
    display: table;
    clear: both;
}
.bottom-row > div {
    float: left;
    width: 48%;
    margin-right: 4%;
}
.bottom-row > div:nth-child(2) {
    width: 48%;
}
.bottom-row > div:last-child {
    margin: 0;
}
.bottom-row button {
    padding: 4px;
    width: 100%;
}

.select2 {
    width: 100% !important;
}

.select2-selection {
    height: 100% !important;
    padding: 8px 10px;
    border: 1px solid rgb(202, 207, 230) !important;
    border-radius: 0 !important;
}

.select2-selection__arrow {
    height: 35px !important;
}

.bg-image-vertical {
    position: relative;
    overflow: hidden;
    background-repeat: no-repeat;
    background-position: right center;
    background-size: auto 100%;
}
.search-bar{
    background: #7a83ae;
    position: absolute;
    right: 0;
    top: 0;
    height: 100%;
    width: 40px;
}
.search-bar .ladda-button{
    background: transparent;
    height: 100%;
}
.alert-info {
    color: #131524 !important;
    background-color: #e5f8ff !important;
        margin-bottom: 2rem !important;
            border-color:transparent;
}
.alert-dismissible .close {
    top: 18px !important;
    height: 65% !important;
    right: -24px !important;
    padding: 0.75rem 0.75rem !important;
    background-color: #fff !important;
    box-shadow: 5.657px 5.657px 24px 0px rgb(30 48 138 / 8%) !important;
    opacity: 1 !important;
    font-weight: 300 !important;
}
.img-responsive {
    display: block;
    max-width: 100%;
    height: auto;
}

.fill {
    object-fit: fill;
}

.select2-container--default .select2-selection--single .select2-selection__arrow {
    top: 7px !important;
    right: 4px !important;
}
.select2-container--default .select2-selection--single .select2-selection__placeholder {
    color: #3e3e3e !important;
}
.label-frm.active{
    transform: translateY(47px);
}

.modcont {
    padding: 30px !important;
}

@media (min-width: 1025px) {
    .h-custom-2 {
        height: 100%;
    }
}
@media(max-width: 992px){
    .label-frm{
        transform: translateY(14px);
        left: 8px;
        font-size: .750rem;
    }
    .select2-container--default .select2-selection--single .select2-selection__placeholder {
     font-size: .750rem;
}
}
@media (max-width: 768px){
    .select2-selection{
        padding: 5px 10px;
    }
    .label-frm.active{
    transform: translateY(41px);
}
    h1{
        font-size: 30px;
    }
    .button{
     padding: 10px 0;
    font-size: 1.5rem;
    }
    .form{
        height: 100%;
    }
    input, textarea{
        font-size: 16px;
    }
}

