:root {
    --light-text: #fff;
    --light-text-alternative: #333333;
    --light-yellow: rgba(255,198,98);
    --warning: rgba(252,176,53);
    --dark-blue: #3abfd5;
    --dark: rgba(0,0,0,0.8);
    --navbar-gray: rgba(171, 171, 171, 0.8);
    --extra-light-gray: #f2f2f2;
    --light-gray: #B3B3B3;
    --mid-gray:  #999999;
    --dark-gray: #4D4D4D;
    --text-dark: #000;
    --primary: #3abfd5;
    --sp-red: #ff4700;
}
html {
    font-size: 14px;
}
.fontAwesome {
    font-family: 'Montserrat', sans-serif;
}
body {
    font-family: 'Montserrat', sans-serif;
    color: var(--text-dark);
    font-weight: 200;
    font-size: 1rem;
}

img.phone_tyto {
    height: 22rem;
    margin-top: -9rem;
    margin-left: 4rem;
}

.videoyoutube{
	width :450px; 
	height :315px;
}
.p-omr {
    padding: 1rem 7rem;
}
/* ----------------------------- NAVBAR --------------------------------------*/
.logo {
    width: 12rem;
    height: 4rem;
}

.navbar {
    position: fixed;
    top: 0;
    background: var(--navbar-gray) !important;
    z-index: 25;
}

.navbar-nav .dropdown {
    display: flex;
}
.nav-link {
    color: var(--light-text) !important;
    font-size: 0.8rem;
}

.dropdown-menu.show {
    background: var(--dark-gray);
    margin-top: 2.5rem;
    min-width: 7rem;
    margin-left: -2rem !important;
}
a.dropdown-item {
    color: var(--light-text);
    font-size: 0.8rem;
}
.nav-up {
    margin-top: -1.4rem;
    color: var(--dark-gray);
    text-align: end;
    padding-right: 0.5rem;
}

.navbar-light .navbar-toggler-icon{
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 30 30' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='rgba(255, 255, 255, 1)' stroke-width='2' stroke-linecap='' stroke-miterlimit='10' d='M4 8h24M4 16h24M4 24h24'/%3E%3C/svg%3E");
}


/*------------------------------------MOBILE NAVBAR --------------------------------------*/
.mobile-navbar button {
    border: none;
    background: none;
    color: white;
    font-size: 0.8rem;
    padding-left: 1rem;
    margin-bottom: 0.5rem;
}
.mobile-navbar p {
    margin-bottom: 0.5rem;
}

.nav-links {
    padding-left: 1rem !important;
}
.mobile-navbar p a {
    color: var(--light-text) !important;
    text-decoration: none;
    font-size: 0.8rem;
    padding-left: 2.1rem;
}

.logo-mobile {
    margin-left: -1.5rem;
    width: 7rem;
    height: 2.7rem;
}


@media (min-width: 768px) {
    .navbar-toggler[aria-expanded="true"] {
        margin-right: 33%;
    }
    .homebt {
        margin-top: 4rem !important;
    }
    .homebt1 {
        margin-top: 1.5rem !important;
    }
}

@media (min-width: 576px) {
    .navbar-toggler[aria-expanded="true"] {
        margin-right: 33%;
    }
    .videoyoutube {
	    width: 350px!important;
	    height: 300px!important;
	}
}

@media (min-width: 425px) {
    .navbar-toggler[aria-expanded="true"] {
        margin-right: 51%;
    }
    
}

@media (min-width: 375px) {
    .navbar-toggler[aria-expanded="true"] {
        margin-right: 51%;
    }
}

@media (min-width: 320px) {
    .navbar-toggler[aria-expanded="true"] {
        margin-right: 51%;
    }
}

@media (min-width: 1200px){
    .homebt {
        margin-top: 3.5rem !important;
    }
}

@media (min-width: 1400px) {
    .homebt {
        margin-top: 2rem !important;
    }
}

.navbar-toggler[aria-expanded="true"] .navbar-toggler-icon
{
   display: none;
}
i.fas.fa-times {
    color: white;
}
.navbar-toggler[aria-expanded="false"] .closecolapse
{
    display: none;
}

.navbar-toggler[aria-expanded="true"] .closecolapse{
display: block;
}
.navbar-toggler:focus {
    box-shadow: 0 0 0 !important; }
}
/* ----------------------------- BACKGROUNDS  --------------------------------------*/
.bg-warning-dark {
    background-color: var(--warning);
}
.bg-warning-sp {
    background-color: var(--light-yellow);
}
.bg-light {
    background: var(--light-text);
}
.bg-muted {
    background: var(--light-gray);
}
.bg-muted-dark {
    background: var(--dark-gray);
}
.bground-primary {
    background: var(--primary);
}
.bg-primary-grad {
    background: linear-gradient(90deg, rgba(58,191,213,1) 21%, rgba(182,229,237,1) 111%);
}

.bg-warning-grad {
    background: linear-gradient(90deg, rgba(248,174,55,255) 67%, rgba(255,255,255,1) 131%);
}
.bg-extra-light {
    background: var(--extra-light-gray);
}

.bg-sp-red {
    background: var(--sp-red);
}										  

.error-bg {
    background-image: url("./images/404-min.jpg");
    background-repeat: no-repeat;
    background-size: cover;
    background-position: 63% 35%;
}
.overlay {
    background-color: rgba(38, 44, 61, 0.4);
    --bs-gutter-x: 2rem;
}
.product-overlay {
    width: 100%;
    height: 44vh;
}
.product-overlay-med {
    width: 100%;
    height:100%;
}
.product-overlay h2 {
    padding-top: 26% !important;
}

.bg-psycho {
    background-image: url("./images/videoconsult-min.png");
    background-size: cover;
    height: 26rem;
  	box-shadow:inset 0 0 0 2000px rgb(23 19 21 / 30%)
}

.bg-pic-1 {
    background-image: url("./images/hands.jpg");
    background-size: cover;
    border-radius: 10px 10px;
    margin-bottom: 1rem;
}
.bg-girl {
    background-image: url("./images/Plano_Saude_Ideal_612x355-min.jpg");
    background-size: cover;
    background-position: center;
}
.bg-product-sp {
    background-image: url("./images/Plano_Saude_Ideal_612x355-min.jpg");
    background-size: cover;
    height: 24rem;
    background-position: right;
    margin-top: -2rem;
    border-radius: 5px;
}
.bg-product-ss {
    background-image: url("./images/Seguro_Saude_612x355-min.jpg");
    background-size: cover;
    height: 24rem;
    background-position: right;
    margin-top: -2rem;
    border-radius: 5px;
}
.bg-product-sm {
    background-image: url("./images/Video-Consulta_620x350-min.jpg");
    background-size: cover;
    height: 19rem;
    background-position: bottom;
    margin-top: -2rem;
    border-radius: 5px;
}
.bg-tooth {
    background-image: url("./images/Plano_Saude_Oral_612x355-min.jpg");
    background-size: cover;
    background-position: center;
}
.bg-plane {
    background-image: url("./images/Seguro_Saude_612x355-min.jpg");
    background-size: cover;
    background-position: center;
}

.card-img-top {
    object-fit: cover;
    height: 17rem;
}
.med-services {
    height: 18rem;
    background-position: bottom;
    background-size: cover;
}
.med-services-1 {
    background-image: url("/images/sp3/Video-Consulta_620x350-min.jpg");
	background-position: center;
}
.med-services-2 {
    background-image: url("/images/sp3/sm_medico_em_casa-min.jpg");
}
.med-services-3{
    background-image: url("/images/sp3/Opiniao_Medica_620x350-min.jpg");
}

.med-services-4{
	background-image: url('/images/tytocare_home/Tyto_645_tiny.jpg')
}
.light-logo {
    background-image: url("/images/sp3/Marca_FHC_RedeMedica_200px.png");
    height: 5rem;
    width: 11em;
    background-size: cover;
    margin-bottom: 1rem;
}
/* ----------------------------- TEXT COLOR  --------------------------------------*/
.light-text {
    color: var(--light-text) !important;
}
.warning-text {
    color: var(--warning);
}
.primary-text {
    color: var(--dark-blue);
}
.gray-text {
    color: var(--mid-gray);
}

.light-gray-text {
    color: var(--light-gray);
}
.text-dark {
    color: var(--text-dark);
}

.sp-red {
    color: var(--sp-red);
}		 						 

/* ----------------------------- TEXT SIZE/WEIGHT --------------------------------------*/

.title {
    font-size: 3rem;
    font-weight: 900;
    margin-top: 5rem !important;
}
.fw-200 {
    font-weight: 200 !important;
}
.fw-400 {
    font-weight: 400 !important;
}
b, strong, .bold {
    font-weight: 700 !important;
}
.bolder {
    font-weight: 800!important;
}
.xs-text {
    font-size: 0.8rem;
}
.small-text {
    font-size: 0.9rem;
}
.medium-text {
    font-size: 1.3rem;
}
.m-text {
    font-size: 1.5rem;
}
.lg-text {
    font-size: 2.2rem;
}
.icon-medical {
    font-size:2.7rem;
}
.xl-text {
    font-size: 3.5rem;
}
/*
h3 {
    font-size: 1.3rem;
}
*/

.w-90 {
    width: 90% !important;;
}
.w-92 {
    width: 92% !important;;
}

/* ----------------------------- HR AND DOTS  --------------------------------------*/
.blue-hr {
    background-size: 2rem 1rem;
    height: 4px;
    background: var(--primary);
}
.yellow-hr {
    background-image: linear-gradient(to right, var(--light-yellow) 30%, rgba(255, 255, 255, 0) 0%);
    background-size: 2rem 1rem;
    height: 4px;
}


.blue-dot {
    height: 11px;
    width: 11px;
    background-color: var(--primary);
    border-radius: 50%;
    display: block;
    margin-top: -0.3rem;
    margin-left: -1rem;
}
.yellow-dot {
    height: 11px;
    width: 11px;
    background-color: var(--warning);
    border-radius: 50%;
    display: block;
    margin-top: -0.3rem;
/*    float: right;*/
/*    margin-right: -1rem;*/
    margin-left: -1rem;
}
.blue-dot-final {
    height: 11px;
    width: 11px;
    background-color: var(--primary);
    border-radius: 50%;
    display: block;
    margin-top: -0.7rem;
    float: right;
    margin-right: -1rem;
}
.yellow-dot-final{
    height: 11px;
    width: 11px;
    background-color: var(--warning);
    border-radius: 50%;
    display: block;
    float: right;
    margin-top: -0.7rem;
    margin-right: -1rem;
}
.yellow-dot-final-1 {
    height: 11px;
    width: 11px;
    background-color: var(--warning);
    border-radius: 50%;
    display: block;
    float: right;
    margin-top: -0.3rem;
    margin-right: -1rem;
}
.blue-dot-middle {
    height: 11px;
    width: 11px;
    background-color: var(--primary);
    border-radius: 50%;
    display: block;
    margin: -2rem auto 0.7rem;
}
/* ----------------------------- MARGINS/ BORDERS  --------------------------------------*/
.mt-neg-1 {
    margin-top: -1rem;
}

.neg-mt {
    margin-top: -1.7rem !important;
}
.mt-6 {
    margin-top: 9rem;
}
.rounded-3 {
    border-radius: 0.3rem !important;
}
.rounded-5 {
    border-radius: 1.5rem !important;
}

.rounded-lft {
    border-radius:2rem 0 0 2rem!important;
}
.rounded-rght {
    border-radius:0 2rem 2rem 0!important;
}
.circle {
    border-radius: 50%;
}
.b-warning {
    border-bottom: 4px solid var(--warning);
    border-radius: 0px;
}
.b-primary {
    border: 2px solid var(--primary);
}

.b-error {
    border: 2px solid var(--error);
}
.border-dashed {
    border: 2px dashed var(--warning);
    border-top: none;
    height: max-content;
}

.by-primary {
    border-top: 2px solid var(--primary);
    border-bottom: 2px solid var(--primary);
}

/* ----------------------------- INPUTS  --------------------------------------*/
.yellow-box{
    background-color: var(--warning) !important;
    border: 2px solid var(--light-text) !important;
    outline: none;
    height: 1rem;
    width: 1rem;
}
.yellow-box:checked {
    outline: none;
}

input#mensal, input#trimestral, input#semestral, input#anual{
/*    background-color: var(--primary) !important;*/
    border: 1px solid var(--primary) !important;
    outline: none;
    height: 0.9rem;
    width: 0.9rem;
    vertical-align: text-top;
    border-radius: 1px;
}
.message-input {
    border-bottom: 2px solid var(--primary);
    outline: none;
}
input{
    border: none;
    outline: none;
}
.form-control-sp {
    border: 2px solid var(--warning);
    border-radius: 3rem 3rem;
    outline: none;
    padding: 0px 13px;
}
.form-control-sp::placeholder {
    color: var(--warning);
}
.form-control-sp-2 {
    border: 2px solid var(--primary);
    border-radius: 25px 25px;
    margin-bottom: 1rem;
    outline: none;
}

.form-control-sp-2::placeholder {
    color: var(--primary);
}
.form-control-input {
    border: 2px solid var(--primary);
    border-radius: 2rem;
 /*   padding: 0.2rem;*/
}

.form-control-input input[type="text"] {
    height: 1rem;
    line-height: 0.5rem;
    font-size: 0.8rem;
    border: none;

}
/* ----------------------------- BULLETS  --------------------------------------*/
.check-li::marker {
    font-family: 'Font Awesome 5 Pro';
    font-weight: 900;
    content: "\f00c";
    color: var(--primary);
}
.white-bullets .check-li::marker {
    color: var(--light-text);
}
.yellow-bullets .check-li::marker {
    color: var(--warning);
}
.yellow-bullets .plus-li::marker{
    font-weight: 900;
    color: var(--warning);
}

.blue-bullets .plus-li::marker{
    font-weight: 900;
    color: var(--primary);
    content: "\f067";
    font-family: 'Font Awesome 5 Pro';
}

.plus-li::marker {
    content: "\f067";
    font-family: 'Font Awesome 5 Pro';
    font-size: 1rem;
    font-weight: bolder;
}

.sp-warning{
    color: var(--warning);
    font-size: 1.5rem;
    font-weight: 400;
}
.sp-primary {
    color: var(--primary);
    font-size: 1.5rem;
    font-weight: 400;
}
.sp-muted {
    color: var(--mid-gray);
    font-size: 1.5rem;
    font-weight: 400;

}

.bullets-simulation li {
    font-size: 0.9rem;
    padding-left: 0.8rem;
}
ul.bullets-simulation {
   padding-left: 0.9rem;
}
/* ----------------------------- BUTTONS  --------------------------------------*/
.btn-light-blue {
    background: var(--light-text);
    color: var(--primary);
    border-radius: 2rem;
    font-size: 0.9rem;
    font-weight: bold;
    width: 100%;
}

.btn-products {
    padding: 0.7rem 2.2rem !important;
}
.btn-warning {
    background: var(--warning);
    width: 100%;
    color: var(--light-text);
    border-radius: 2rem;

}
.btn-primary {
    background: var(--primary);
    padding: 0.5rem 0.9rem;
    border-radius: 2rem;
    color: var(--light-text);
    border: none;
}
.btn-blue-xl {
    background: var(--primary);
    color: var(--light-text);
    padding: 0.2rem 6rem;
    border-radius: 1rem;
}

.btn-light {
    background: var(--light-text);
    padding: 0.6rem 1.7rem;
    border-radius: 2rem;
}
.btn-promo {
    border: 2px solid var(--primary);
    border-radius: 14px 14px;
    background: var(--light-text);
    padding: 0.5rem;
    color: var(--primary);
    width: -webkit-fill-available;
    outline: none !important;
    display: flex;
    justify-content: space-evenly;
    align-items: center;
}

.btn-subscribe {
    border-radius: 1rem;
    border: none;
    padding: 0.3rem 6%;
    background-color: var(--primary);
    float: right;
    font-size: 1rem;
}
.yellow-hover:hover {
    border: 2px solid var(--warning);
    background-color: var(--warning);
    color: var(--light-text);
}
.btn-back {
    border: 2px solid var(--primary);
    color: var(--primary);
    border-radius: 2rem 2rem;
    font-weight: 700;
}

/* ----------------------------- ICONS  --------------------------------------*/

    /* ----- Facebook and LinkedIn Icons  ------*/
.icon-body {
    padding: 0.5rem 0.8rem !important;
}

.lg-icon {
    font-size: 4rem;
}
.xl-icon {
    font-size: 9rem;
}

.flag-icon {
    color: var(--light-text);
    background: var(--primary);
    padding: 4rem;
    border-radius: 1rem 1rem;
    font-size: 8rem;
}

.heart-icon {
    -webkit-transform: scaleX(-1);
    transform: scaleX(-1);
    color: var(--primary);
    font-size: 9rem;
    border: 4px solid var(--warning);
    text-align: center;
    padding: 5rem;
    border-radius: 0.5rem;
}
.book-icon {
    font-size: 10rem;
    color: var(--light-text);
    background: var(--warning);
    border-radius: 0.5rem;
    text-align: center;
    padding: 5rem;
}
.social-net-icons {
    width: 10rem;
    margin-top: -1.25rem;
    margin-left: -1rem;
}

.footer-icons .sgs-logo {
    height: 3rem;
}

.complaint-logo {
    height: 2.8rem;
}

.circle-icon {
    border: 3px solid var(--light-text);
    padding: 0.5rem;
    border-radius: 50%;
}

.primary-icon-padding {
    padding-right: 2rem;
    padding-left: 1.8rem;
}

.blue-lock i:hover {
    background: var(--primary);
    color: var(--light-text);
    font-size: 2rem;
    border-radius: 50%;
}

.blue-lock i:hover + .info-title {
    color: #000000 !important;
}
.info-title{
    color: #ffffff;
}

.message-icon {
    font-size: 6rem;
}

.btn_validar_cupao {
    border: none;
    background: none;
    color: var(--primary);
    outline: none;
}


. phone-paragraph p {
    font-size: 0.9rem;
}
.phone-homepage {
    height: 46vh;
    width: 52vw;
    margin-top: -8rem;
    float: right;
    margin-right: -2rem;
}
.phone-text p{
    padding: 0 !important;
    font-size: 0.8rem;
}

.phone-text button{
    font-size: 0.7rem;
}
.phone-desktop {
    height: 62vh;
    width: 105%;
    margin-top: -24rem;
    margin-right: -2rem;
}
.products-title .title{
    margin-bottom: 2.5rem;
}
.benefits-table th {
    font-size: 1.2rem;
}
.benefits-table th, .benefits-table .check-table{
    text-align: center;
}

.dets-link {
    text-decoration: none;
    background: var(--warning);
    color: var(--light-text);
    border-radius: 2rem;
    padding: 0.7rem 1.5rem;
    font-weight: 400;
    margin-top: 2rem;
}

.icon-sp i {
    max-width: 3rem;
    margin-right: 1rem;
}

.carousel-control-prev-icon{
    filter: invert(72%) sepia(41%) saturate(819%) hue-rotate(146deg) brightness(90%) contrast(85%);
}
.carousel-control-next-icon{
    filter: invert(72%) sepia(41%) saturate(819%) hue-rotate(146deg) brightness(90%) contrast(85%);
}

a.carousel-control-prev.bg-transparent.w-aut {
    margin-left: -3%;
}

a.carousel-control-next.bg-transparent.w-aut {
    margin-right: -3%;
}

#documentos1 .documents-links, #documentos .documents-links, #documentos2 .documents-links  {
    text-decoration: none !important;
    color: var(--dark);
    font-weight: 700;
}


.iframe-responsability iframe {
    height: 18rem;
}
.mh {
    min-height: 84vh;
}

.products-btn button{
    width: 10rem;
}

.products-btn .bg-pic-1 {
    height: 20rem;
}

@media only screen and (min-width: 1200px) {
    .phone-paragraph {
        margin-left: -1.2rem;
    }

    .phone-text {
        margin-left: 4rem;
    }
}
.was-validated .form-control:invalid ~ .invalid-feedback, .form-control.is-invalid ~ .invalid-feedback, .was-validated .form-control:invalid ~ .invalid-tooltip, .form-control.is-invalid ~ .invalid-tooltip {
    display: block;
}

.is-invalid {
    color: #3abfd5 !important;
    border: 2px solid #3abfd5 !important;
}

.text-decoration-none {
    text-decoration: none;
}

table#idades {
    width: 82vw;
}

.calendar-homepage {
    padding: 1.6rem 1.8rem !important;
}

.personvalue {
    padding: 1px !important;
}

.form-control.is-invalid, .was-validated .form-control:invalid:before {

}

.fw-800 {
    font-weight: 800 !important;
}

.agentes-selects {
    background: var(--primary);
    border-radius: 2rem;
    margin-bottom: 1rem;
}

.agentes-selects select {
    background: transparent;
    border: none;
    color: var(--light-text) !important;
}

select#county_agentes, select#district_agentes {
    background-color: var(--primary);
    color: var(--light-text) !important;
    background-image: linear-gradient(
            45deg
            , transparent 50%, #fff 50%), linear-gradient(
            135deg
            , #fff 50%, transparent 50%), linear-gradient(to right, transparent, transparent);
    background-position: calc(100% - 20px) calc(1em + 2px), calc(100% - 15px) calc(1em + 2px), 100% 0;
    background-size: 5px 5px, 5px 5px, 2.5em 2.5em;
    background-repeat: no-repeat;
}

.agentesnetwork-wrapper, .border-top-none.card-footer {
    border: none;
}
.card-footer {
    border: none;
background: var(--light-text);
}

.listagemdemediadores h4 {
    color: var(--primary);
}

.btn_phone {
    background-color: var(--light-text);
    border-radius: 3rem;
    padding: 0.5rem 1rem;
    text-align: center;
}
a.btn_phone_link {
    color: var(--warning) !important;
    text-decoration: none !important;
    font-weight: 800 !important;
}
.border-dashed2 {
    border: 7px dashed var(--warning);
    border-top: none;
    height: max-content;
}

.tyto-logo {
    width: 13rem;
    background: white;
    padding: 1rem 4rem;
    border-radius: 1rem 0 0 0;
    float: right;
    margin-bottom: 2rem;
    margin-right: -2rem;
}

.omr-div {
    margin-top: 10rem;
    background: var(--light-text);
    border-radius: 1rem;
    font-weight: 700;
    font-size: 0.8rem;
    color: var(--sp-red);
    height: fit-content;
    padding: 1.3rem 10rem 1.3rem 1.3rem;
}

.omr-div-img {
    height: 13rem;
    width: 15rem;
    margin-top: 9rem;
    margin-left: -8rem;
}
*/
.omr-div {	  
    margin-top: 3rem;
    background: var(--light-text);
    border-radius: 1rem;
    font-weight: 700;
    font-size: 0.7rem;
    color: var(--sp-red);
    height: fit-content;
    padding: 1rem 6rem 0rem 1rem;
    width: 20rem;
    margin-left: 1rem;
}

.omr-div-img {
    height: 9.6rem;
    width: 10rem;
    margin-top: -8.4rem;
    margin-left: 13.5rem;
}

.omr-div a {
    text-decoration: none;
    background: var(--sp-red);
    color: var(--light-text);
    padding: 0.5rem 1rem;
    border-radius: 1rem;
    margin-bottom: 0;
}
