/********************************* CORES *********************************/
.cverde {
  color: #6DB759;
}
.bverde {
  background-color: #6DB759;
}
.cverdeclaro {
  color: #99C66B;
}
.bverdeclaro {
  background-color: #99C66B;
}
.cverdeescuro {
  color: #0B6624;
}
.bverdeescuro {
  background-color: #0B6624;
}
.cpreto {
  color: #000;
}
.bpreto {
  background-color: #000;
}
.cescuro {
  color: #222;
}
.bescuro {
  background-color: #222;
}
.cgrafite {
  color: #333;
}
.bgrafite {
  background-color: #333;
}
.ccinzaescuro {
  color: #777;
}
.bcinzaescuro {
  background-color: #777;
}
.ccinza {
  color: #AAA;
}
.bcinza {
  background-color: #AAA;
}
.ccinzaclaro {
  color: #EEE;
}
.bcinzaclaro {
  background-color: #EEE;
}
.cgelo {
  color: #F7F7F7;
}
.bgelo {
  background-color: #F7F7F7;
}
.cbranco {
  color: #FFF;
}
.bbranco {
  background-color: #FFF;
}
/********************************* GERAL *********************************/
html,
body {
  font-size: 9px;
  overflow-x: hidden;
}
* {
  font-family: Open Sans, Arial, Helvetica, sans-serif;
  -webkit-transition: all 200ms ease-in-out;
  -moz-transition: all 200ms ease-in-out;
  -o-transition: all 200ms ease-in-out;
  transition: all 200ms ease-in-out;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}
.livvic {
  font-family: 'Livvic', Open Sans, Arial, Helvetica, sans-serif;
}
.no-transition {
  -webkit-transition: none !important;
  -moz-transition: none !important;
  -o-transition: none !important;
  transition: none !important;
}
.fast {
  -webkit-transition-duration: 100ms;
  -moz-transition-duration: 100ms;
  -o-transition-duration: 100ms;
  transition-duration: 100ms;
}
.clear {
  clear: both;
}
.hidden {
  display: none !important;
}
a,
button {
  text-decoration: none;
  color: inherit;
  border: 0;
  outline: 0;
  background: none;
  cursor: pointer;
}
a:hover,
button:hover {
  text-decoration: none;
}
ul,
ol {
  list-style-type: none;
}
.tabled {
  display: table;
}
.tabled > div {
  display: table-cell;
  vertical-align: middle;
}
/*********************************** FORMAS ***********************************/
.il {
  display: inline;
}
.bl {
  display: block;
}
.ib {
  display: inline-block;
}
.rd100 {
  border-radius: 100vh;
}
.rd0 {
  border-radius: 0px;
}
.rd5 {
  border-radius: 5px;
}
.rd10 {
  border-radius: 10px;
}
.m0 {
  margin: 0;
}
.mb05 {
  margin-bottom: 0.5em;
}
.mb1 {
  margin-bottom: 1em;
}
.mb2 {
  margin-bottom: 2em;
}
.mb3 {
  margin-bottom: 3em;
}
.p0 {
  padding: 0;
}
.p5 {
  padding: 5px;
}
.p10 {
  padding: 10px;
}
.p20 {
  padding: 20px;
}
.pl10 {
  padding-left: 10px;
}
.pt20 {
  padding-top: 20px;
}
.pt40 {
  padding-top: 40px;
}
.pb20 {
  padding-bottom: 20px;
}
/*********************************** FONTES TEXTOS ***********************************/
.w100 {
  font-weight: 100;
}
.w200 {
  font-weight: 200;
}
.w300 {
  font-weight: 300;
}
.w400 {
  font-weight: 400;
}
.w500 {
  font-weight: 500;
}
.w600 {
  font-weight: 600;
}
.w700 {
  font-weight: 700;
}
.w800 {
  font-weight: 800;
}
.w900 {
  font-weight: 900;
}
.i {
  font-style: italic;
}
.uc {
  text-transform: uppercase;
}
.tl {
  text-align: left;
}
.tc {
  text-align: center;
}
.tr {
  text-align: right;
}
.t11 {
  font-size: 1.1rem;
}
.t12 {
  font-size: 1.2rem;
}
.t13 {
  font-size: 1.3rem;
}
.t14 {
  font-size: 1.4rem;
}
.t15 {
  font-size: 1.5rem;
}
.t16 {
  font-size: 1.6rem;
}
.t18 {
  font-size: 1.8rem;
}
.t20 {
  font-size: 2.0rem;
}
.t22 {
  font-size: 2.2rem;
}
.t24 {
  font-size: 2.4rem;
}
.t26 {
  font-size: 2.6rem;
}
.t28 {
  font-size: 2.8rem;
}
.t32 {
  font-size: 3.2rem;
}
.t36 {
  font-size: 3.6rem;
}
.t37 {
  font-size: 3.7rem;
}
.t42 {
  font-size: 4.2rem;
}
.t48 {
  font-size: 4.8rem;
}
.t56 {
  font-size: 5.6rem;
}
.t72 {
  font-size: 7.2rem;
}
.t99 {
  font-size: 9.9rem;
}
.lh120 {
  line-height: 120%;
}
.lh140 {
  line-height: 140%;
}
.lh160 {
  line-height: 160%;
}
.lh180 {
  line-height: 180%;
}
.lh200 {
  line-height: 200%;
}
/*********************************** ELEMENTOS ***********************************/
@media all {
  .botao {
    display: inline-block;
    padding: 15px 30px;
    background-color: #FFF;
    font-size: 1.8rem;
    border: solid 4px #99C66B;
    border-radius: 100vh;
    color: #333;
    font-weight: 200;
    text-transform: uppercase;
  }
  .botao i {
    font-size: 2.4rem;
    margin-right: 5px;
  }
  .botao span {
    font-weight: 700;
  }
  .botao:hover {
    background-color: #ccf99e;
    border-color: #6DB759;
    color: #000;
  }
}
@media (min-width: 768px) {
  .botao {
    display: inline-block;
    padding: 15px 30px;
    background-color: #FFF;
    font-size: 2.8rem;
    border: solid 4px #99C66B;
    border-radius: 100vh;
    color: #333;
    font-weight: 200;
    text-transform: uppercase;
  }
  .botao i {
    font-size: 3.6rem;
    margin-right: 5px;
  }
  .botao span {
    font-weight: 700;
  }
}
/*********************************** MAPS ***********************************/
#maps {
  border-top: solid 12px #6DB759;
}
/*********************************** CAPA ***********************************/
@media (min-width: 768px) {
  #capa {
    background-image: url(../img/clinica.jpg);
	}
}
@media all {
  #capa {
    background-position: center center;
    background-size: cover;
    background-repeat: no-repeat;
    padding-top: 40px;
    padding-bottom: 20px;
  }
  #capa h1 {
    margin-bottom: 30px;
  }
  #capa h1 img {
    max-width: 350px;
  }
  #capa p {
    color: #333;
    font-size: 1.4rem;
    font-weight: 400;
  }
  #capa p i {
    margin-right: 10px;
    font-size: 2.2rem;
    color: #99C66B;
  }
  #capa p.tel {
    font-size: 2.2rem;
    font-weight: 700;
  }
  #capa p.tel i {
    font-size: 3.6rem;
  }
  #capa p.tel span {
    font-size: 1.4rem;
  }
  #capa p.hora {
    text-transform: uppercase;
  }
  #capa p a:hover {
    color: #777;
  }
  #capa .botao {
    margin-top: 30px;
  }
  #capa a.acesso {
    display: inline-block;
    padding: 20px;
    text-transform: uppercase;
    color: #333;
    font-size: 1.4rem;
    font-weight: 700;
  }
  #capa.acesso {
    min-height: 100vh;
  }
  #capa.acesso h1 {
    padding-bottom: 30px;
  }
  #capa.acesso .form {
    max-width: 500px;
    display: inline-block;
  }
  #capa.acesso .form form input {
    height: 60px;
    font-size: 2.8rem;
    margin-bottom: 20px;
  }
  #capa.acesso .form form button.botao {
    margin-top: 0px !important;
  }
}
@media (min-width: 576px) {
  #capa h1 {
    margin-bottom: 40px;
  }
  #capa p {
    font-size: 1.8rem;
    margin-bottom: 20px;
  }
  #capa p i {
    font-size: 2.4rem;
  }
  #capa p.tel {
    font-size: 2.8rem;
  }
  #capa p.tel i {
    font-size: 4.8rem;
  }
  #capa p.tel span {
    font-size: 1.8rem;
  }
}
@media (min-width: 768px) {
  #capa p {
    font-size: 2.2rem;
  }
  #capa p i {
    font-size: 2.8rem;
  }
  #capa p.tel {
    font-size: 3.6rem;
  }
  #capa p.tel i {
    font-size: 5.6rem;
  }
  #capa p.tel span {
    font-size: 1.8rem;
  }
  #capa p.hora {
    font-size: 1.8rem;
  }
  #capa a.acesso {
    font-size: 1.8rem;
  }
}
/*********************************** SOBRE ***********************************/
@media all {
  #sobre {
    border-bottom: solid 10px #6DB759;
    border-top: solid 10px #6DB759;
    padding-top: 80px;
    padding-bottom: 80px;
    background-image: url(../img/back-sobre.png);
    background-position: top left;
    background-size: cover;
    background-repeat: no-repeat;
  }
  #sobre h2 {
    font-size: 2.4rem;
    color: #0B6624;
    font-weight: 700;
    line-height: 200%;
    margin-bottom: 50px;
  }
  #sobre h2 span {
    font-weight: 400;
    color: #333;
    text-transform: uppercase;
  }
  #sobre h2 br {
    line-height: 300%;
  }
  #sobre ul.servicos {
    margin: 0;
    padding: 0;
  }
  #sobre ul.servicos li {
    margin-bottom: 15px;
  }
  #sobre ul.servicos li span {
    display: block;
    text-align: center;
    padding: 20px;
    background-color: #FFF;
    color: #333;
    font-size: 2.0rem;
    font-weight: 400;
    text-transform: uppercase;
    border: solid 3px #99C66B;
  }
  #sobre p {
    font-size: 1.6rem;
    color: #777;
    font-weight: 400;
  }
  #sobre p a {
    display: inline-block;
    padding: 5px;
  }
  #sobre p a i {
    font-size: 5.6rem;
  }
  #sobre p a i.fa-facebook-square {
    color: #3A559F;
  }
  #sobre p a i.fa-instagram {
    background: linear-gradient(to top right, #EE0002 0%, #B700A8 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
  }
  #sobre p a:hover i {
    transform: scale(1.2);
  }
  #sobre p.requisicao {
    font-size: 1.8rem;
  }
  #sobre p.requisicao a.botao {
    font-size: 1.6rem;
    padding: 10px 20px;
    font-weight: 800;
  }
  #sobre p.requisicao a.botao i {
    font-size: 2.4rem;
  }
  #sobre .parceiros {
    text-align: center;
  }
  #sobre .parceiros .bar {
    border-top: solid 1px #99C66B;
    margin-top: 30px;
  }
  #sobre .parceiros h3 {
    font-size: 3.6rem;
    text-transform: uppercase;
    text-align: center;
    font-weight: 700;
    color: #333;
    margin-top: 50px;
    margin-bottom: 20px;
  }
  #sobre .parceiros .logo {
    display: inline-block;
    padding: 20px;
    margin: 10px;
  }
  #sobre .parceiros .logo img {
    height: 100px;
    width: auto;
  }
  #sobre .gabriel h3 {
    font-size: 3.6rem;
    font-weight: 700;
    line-height: 200%;
    color: #000;
  }
  #sobre .gabriel p {
    font-size: 1.8rem;
    font-weight: 700;
    line-height: 200%;
    color: #0B6624;
  }
}
@media (min-width: 768px) {
  #sobre .row.flex {
    align-items: center;
  }
  #sobre h2 {
    max-width: 470px;
  }
  #sobre ul.servicos li span {
    font-size: 2.0rem;
  }
}
@media (min-width: 992px) {
  #sobre ul.servicos {
    padding-left: 30px;
    position: relative;
  }
  #sobre ul.servicos::before {
    content: '';
    display: block;
    position: absolute;
    left: 0;
    top: 37px;
    height: calc(100% - 72px);
    border-left: solid 1px #99C66B;
  }
  #sobre ul.servicos li {
    position: relative;
  }
  #sobre ul.servicos li::before {
    content: '';
    display: block;
    position: absolute;
    left: -30px;
    top: 50%;
    width: 20px;
    border-top: solid 1px #99C66B;
  }
}
@media (min-width: 1200px) {
  #sobre ul.servicos li span {
    font-size: 2.8rem;
    padding: 15px 40px;
    display: inline-block;
  }
}
/*********************************** contato ***********************************/
@media all {
  #contato {
    background-image: url(../img/back-contato.jpg);
    background-position: left top;
    background-repeat: repeat-x;
    background-color: #FFF;
    padding-top: 150px;
    padding-bottom: 60px;
  }
  #contato .row.flex {
    align-items: center;
  }
  #contato h4 {
    font-size: 5.6rem;
    color: #333;
    text-transform: uppercase;
    text-align: center;
    font-weight: 700;
    margin-top: 20px;
    margin-bottom: 20px;
  }
  #contato p {
    color: #333;
    font-size: 1.4rem;
    font-weight: 400;
    text-align: center;
  }
  #contato p i {
    margin-right: 10px;
    font-size: 2.2rem;
    color: #99C66B;
  }
  #contato p.tel {
    font-size: 2.2rem;
    font-weight: 700;
  }
  #contato p.tel i {
    font-size: 3.6rem;
  }
  #contato p.tel span {
    font-size: 1.4rem;
  }
  #contato p.hora {
    text-transform: uppercase;
  }
  #contato p a:hover {
    color: #777;
  }
  #contato .container {
    position: relative;
  }
  #contato .container .elemento-t-e {
    position: absolute;
    top: -50px;
    left: -60px;
    height: 140px;
    width: 140px;
    border-top: solid 14px #6DB759;
    border-left: solid 14px #6DB759;
  }
  #contato .container .elemento-t-d {
    position: absolute;
    top: -50px;
    right: -60px;
    height: 140px;
    width: 140px;
    border-top: solid 14px #6DB759;
    border-right: solid 14px #6DB759;
  }
  #contato .container .elemento-b-e {
    position: absolute;
    bottom: 250px;
    left: -60px;
    height: 140px;
    width: 140px;
    border-bottom: solid 14px #333;
    border-left: solid 14px #333;
  }
  #contato .container .elemento-b-d {
    position: absolute;
    bottom: 250px;
    right: -60px;
    height: 140px;
    width: 140px;
    border-bottom: solid 14px #333;
    border-right: solid 14px #333;
  }
  #contato .pets {
    margin: auto;
    display: block;
    position: relative;
    z-index: 99;
  }
  #contato form {
    padding: 0;
    position: relative;
    z-index: 110;
  }
  #contato form input,
  #contato form textarea {
    height: 55px;
    font-size: 1.6rem;
    color: #333;
    background-color: #F1FBEE;
    border: solid 1px #99C66B;
    outline: none;
    margin-bottom: 28px;
    border-radius: 0px;
    font-weight: 600;
    padding: 20px;
    line-height: 180%;
  }
  #contato form textarea {
    height: auto;
    resize: none;
  }
  #contato form button {
    display: block;
    font-size: 1.8rem;
    font-weight: 600;
    text-align: center;
    text-transform: uppercase;
    padding: 15px 20px;
    float: right;
    background-color: #FFF;
    transition: inherit;
  }
  #contato form button:hover {
    background-color: #6DB759;
  }
}
@media (min-width: 576px) {
  #contato p {
    font-size: 1.8rem;
    margin-bottom: 20px;
  }
  #contato p i {
    font-size: 2.4rem;
  }
  #contato p.tel {
    font-size: 2.8rem;
  }
  #contato p.tel i {
    font-size: 4.8rem;
  }
  #contato p.tel span {
    font-size: 1.8rem;
  }
}
@media (min-width: 768px) {
  #contato p {
    font-size: 2.2rem;
  }
  #contato p i {
    font-size: 2.8rem;
  }
  #contato p.tel {
    font-size: 3.6rem;
  }
  #contato p.tel i {
    font-size: 5.6rem;
  }
  #contato p.tel span {
    font-size: 1.8rem;
  }
  #contato p.hora {
    font-size: 1.8rem;
  }
}
/*********************************** RODAPÉ ***********************************/
@media all {
  #rodape {
    background-color: #333;
    text-align: center;
    border-top: solid 8px #6DB759;
  }
  #rodape h6 {
    color: #AAA;
    text-transform: uppercase;
    font-size: 1.6rem;
    font-weight: 600;
    padding: 25px 0;
    line-height: 200%;
  }
}
/*********************************** EXAMES ***********************************/
@media all {
  #exames {
    padding-top: 30px;
    padding-bottom: 150px;
  }
  #exames h1 a {
    padding: 10px 0px 30px;
    display: block;
  }
  #exames h1 a img {
    width: 200px;
  }
  #exames .dados {
    float: right;
    display: flex;
    align-content: center;
    align-items: center;
    height: 100%;
  }
  #exames .dados h4 {
    font-size: 2.8rem;
  }
  #exames .dados p a {
    font-size: 1.8rem;
    font-weight: 700;
    text-align: center;
    display: block;
    padding: 10px;
  }
  #exames .dados p a:hover {
    color: #0B6624;
  }
  #exames table {
    font-size: 1.8rem;
  }
  #exames table td,
  #exames table th {
    padding: 20px;
  }
  #exames table td i,
  #exames table th i {
    font-size: 2.8rem;
  }
  #exames table td i:hover,
  #exames table th i:hover {
    color: #0B6624;
  }
  nav.pagination {
    clear: both;
  }
  nav.pagination a,
  nav.pagination span {
    display: inline-block;
    padding: 4px 12px;
    background-color: #FFF;
    border: solid 1px #DDD;
    font-size: 2.0rem;
    font-weight: 700;
    color: #222;
    text-align: center;
    margin: 3px;
  }
  nav.pagination a:hover {
    color: #FFF;
    background-color: #0B6624;
  }
  nav.pagination span {
    background-color: #99C66B;
    color: #FFF;
  }
}
