/* COMMON */ 
html, body {height:100%;}


.badge-danger {
  background-color: #c00 !important;
}



input.error, textarea.error {
  border-color: #c00 !important;
  color: #c00;
}

label.error {
  color: #c00;
}

.aviso-poke {
  color: #c00;
}

body {
  font-family: 'Open Sans', sans-serif;
  font-weight: 100;  
  font-size: 14px;  
  font-weight: 400;
  line-height: 1.6;
  background: #fff;
  color: #333;
}

h1 {    
  font-weight: 700;
  color: #333;
  font-size: 21px;
  margin: 0 0 18px;
  text-transform: uppercase;
}

h1 hr {
  display: block;
  width: 50px;
  margin-left: 0;
  margin-top: 20px; 
  margin-bottom: 10px;
}

h2 {
  font-size: 18px;
  margin: 0 0 18px; 
  color: #666;
}

h3 {
  color: #666;
  font-size: 14px;
  margin: 0;  
}

p {margin-bottom: 20px;}

a:link, 
a:active,
a:hover {text-decoration: none;}

a {
  color: #333;    
  -webkit-transition: 0.25s ease-in-out;
  -moz-transition: 0.25s ease-in-out;
  transition: 0.25s ease-in-out; 
}
a:hover {
  color: #0409f4;
}

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

header {
  background: #fff;
  padding: 15px 0;
}

input, select, textarea, button {
  font-size: 14px;
  text-transform: uppercase;
  padding: 8px;
  line-height: 1.4;
  background: #fff;
  color: #333;
  border: 1px solid #333;
  -webkit-transition: 0.25s ease-in-out;
  -moz-transition: 0.25s ease-in-out;
  transition: 0.25s ease-in-out; 
}

hr {
  border-top: 1px solid #999;  
  height: 1px;
  display: block;
  border-left:none;
  border-right:none;
  border-bottom:none; 
}

form {overflow: hidden;}

/* CLASS */ 
.centro {text-align: center;}

.img-center {
  margin: 0 auto;
  display: table;
}

.small {
  line-height: 1.4;
  font-size: 10px; 
  margin: 2% 0;
}

.right {float: right;}
.left {float: left;}

.link {
  border: 1px solid #666;
  color: #666;
  border-radius: 2px;
  font-size: 14px;
  padding: 5px 10px;
}
.link:hover {
  color: #000;
  border-color: #000;
}

.btn, 
.btn:link, 
.btn:active, 
.btn:visited {  
  background-color: #FFF;
  padding: 8px 20px;
  color: #333;
  font-size: 12px;
  line-height: 3;
  text-transform: uppercase;
  font-weight: 700;
  border: 2px solid #333;
  -webkit-transition: 0.2s ease-in-out;
  -moz-transition: 0.2s ease-in-out;
  transition: 0.2s ease-in-out;
}
.btn:hover {
  background: #333;
  color: #fff;
}

.btn2, 
.btn2:link, 
.btn2:active, 
.btn2:visited {  
  padding: 8px 20px;
  color: #fff;
  font-size: 14px;
  line-height: 3;
  text-transform: uppercase;
  font-weight: 700;
  background: #0409f4;
  border: 2px solid #0409f4;
  -webkit-transition: 0.2s ease-in-out;
  -moz-transition: 0.2s ease-in-out;
  transition: 0.2s ease-in-out;
}
.btn2:hover {
  border-color: #333;
  background: #333;
  color: #fff;
}

.btn3, 
.btn3:link, 
.btn3:active, 
.btn3:visited {  
  font-size: 12px;
  text-decoration: none;
  line-height: 3;
  border: 1px solid #000;
  color: #000;
  font-weight: 700;
  text-transform: uppercase;
  padding: 10px 20px;
  border-radius: 3px;
  -webkit-transition: 0.2s ease-in-out;
  -moz-transition: 0.2s ease-in-out;
  transition: 0.2s ease-in-out;
}
.btn3:hover {
  background: #333;
  color: #fff;
}

.alert {
  padding: 10px;
  line-height: 1.4;
  border-radius: 2px;
  text-align: center;
  margin-bottom: 20px;
  border: none;
}
.alert-success {
  color: rgba(0, 150, 0, 0.7);
  background: rgba(0, 255, 0, 0.2); 
}
.alert-error {
  color: rgba(150, 0, 0, 0.7);
  background: rgba(255, 0, 0, 0.2);
}

.section-container {
  padding-bottom: 60px;
}

.header-title {
  display: block;
  position: relative;
  padding: 60px 0;
  overflow: hidden;
  margin-bottom: 60px;
}
.header-title h1 {
  font-size: 32px;
  color: #fff;
  margin-bottom: 0;
}

.filters {
  display: block;
  clear: both;
  line-height: 40px;
  overflow: hidden;
  background: #e9e9e9;
  padding: 5px 15px;
  font-size: 13px;
}
.filter-col {
    width: 33%;
    float: left;
}
.filters-up {
    margin-bottom: 30px;
}
.filters-down {
    margin-top: 30px;
}
.filters select {
    padding: 5px;
    background: #fff;
}

.form-inline {
    overflow: hidden; 
    margin-top: 10px;
}
.form-inline p {
  display: block; 
  overflow: hidden;
  line-height: 1;
}
.form-inline label {
  display: block;
  width: 100%;
  text-align: left;  
  margin-bottom: 5px;
}
.form-inline input, 
.form-inline select, 
.form-inline textarea {float: left; width: 100%;}

.col-2 {width: 50%; float: left; padding-right: 40px;}
.col-2:last-child {padding-right: 0px;}
.col-2-last {width: 50%; float: left; padding-right: 0px}
.col-3 {width: 33.3333333333%; float: left;}

.form-block .col-2 {overflow: hidden; margin-bottom: 15px;}
.form-block .size-full {width: 100%;}
.form-block label {
  display:block; 
  margin-bottom: 5px;
}

.embed-responsive {
  position: relative;
  display: block;
  height: 0;
  padding: 0;
  overflow: hidden;
}
.embed-responsive .embed-responsive-item,
.embed-responsive iframe,
.embed-responsive embed,
.embed-responsive object,
.embed-responsive video {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  height: 100%;
  width: 100%;
  border: 0;
}
.embed-responsive-16by9 {
  padding-bottom: 56.25%;
  margin-bottom: 30px;
}
.embed-responsive-4by3 {
  padding-bottom: 75%;
}

.breadcrumb {
  margin-bottom: 40px;
  overflow: hidden;
}

ul.list-line li {
  display: block; 
  line-height: 1.6;
  margin-bottom: 10px;
  padding-bottom: 9px;    
  border-bottom:1px solid #d9d9d9;
}

ul.list-bread {
  float: right;
  margin-top: 9px;
}
ul.list-bread li {
  float: left;
  margin-right: 7px;
  font-size: 12px;
  text-transform: uppercase;
  font-weight: 400;
  color: #fff;
}
ul.list-bread li a {
  color: #fff;
}
ul.list-bread li a:hover {color: #2477ab}
ul.list-bread li.active {
  color: #2477ab;
}
ul.list-bread li::after {
  content: "/";
  margin-left: 5px;
}
ul.list-bread li:last-child::after {
  content: "";
  margin-right: 0;
}

table.table-list {
  width: 100%;
}
table.table-list thead tr th {
  text-align: left;
  padding-bottom: 10px;
  border-bottom: 1px solid #e9e9e9;
  font-weight: bold;
}
table.table-list tbody tr td {
  padding: 10px 0;
  border-bottom: 1px solid #e9e9e9;
}
table.table-list tbody tr:last-child td {
  border-bottom: none;
}

.underline {text-decoration: underline !important;}

.field, .desc {float: left;}

.submenu {
  display: block;
  width: 100%;
  float: right;
}

.sidemenu {
  margin: 15px 0;
  background: #f0f0f0;
  padding: 40px;
  border-radius: 5px;
  overflow: hidden;
}

.titulo {
  display: block;
  margin-bottom: 15px;
}
.titulo h1 {text-align: center;}
.titulo h1 small {
  margin-top: 5px;
  display: block;
  font-size: 14px;
  line-height: 18px;
  text-transform: none;
  font-weight: 400;
}
.btn-footer {
  display: block;
  margin-top: 30px;  
}

/* PLUGINS */
.go-top {
  z-index: 1001;
  position: fixed;
  bottom: 0;
  right: 0;
  text-decoration: none;
  background-color: #2477ab;
  color: #fff;
  padding: 12px 20px;
  display: none;
}
.go-top i {font-size: 28px;}
.go-top:hover {background: #054973; color:#fff}

.videoWrapper {
  position: relative;
  padding-bottom: 56.25%; /* 16:9 */
  padding-top: 25px;
  height: 0;
}
.videoWrapper iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

ul.tabs {
  margin: 0;
  padding: 0;
  float: left;
  list-style: none;
  width: 100%;
  margin-top: 0px;
}
ul.tabs li {
  font-size: 16px;
  float: left;
  margin: 0;
  cursor: pointer;
  position: relative;
  padding: 15px;
  text-align:center;
  color: #fff;
  background: #444;
  z-index: 99;
  border-right: 1px solid #fff;
  -webkit-transition: 0.25s ease-in-out;
  -moz-transition: 0.25s ease-in-out;
  transition: 0.25s ease-in-out; 
}
ul.tabs li:last-child {border-right: 0;}
ul.tabs li:hover {
  background: #f50;
  color: #fff;  
}
ul.tabs li.active {
  text-align:center;
  background: #f50;
  color: #fff;
}
ul.tabs li.active:after {
  content: "";
  height: 10px;
  position: absolute;
  width: 0;
  margin-top:35px;
  left:47%;
  border: 10px solid transparent;
  border-top-color: #f50;  
}

.tab_container {
  clear: both;
  width: 100%;
  border-top: 0;
  overflow: auto;
}
.tab_content {
  display: none;
  padding: 30px;
  overflow: hidden;
  background: #d9d9d9;
}
.tab_drawer_heading {
  display: none;
}

/* FIXED NAV */
#nav-fixed {
  z-index: 1000;
  width: 100%;  
  padding: 10px 0;
  overflow: hidden;
  position:fixed;
  bottom: 0;
  background: #fff;
  border-top: 1px solid #e9e9e9;
}


ul.list-menu-fixed li strong {}
ul.list-menu-fixed li {
  float: left;
  height: 48px;
  line-height: 48px;
  margin-right: 20px;
}

/* HEADER */
.header-bar {
  width: 100%;
  background: #e9e9e9;
  color: #666;
  padding: 10px 0;    
  font-size: 13px;
}

.header-bar-right {text-align: right;}

ul.list-header-bar {
  display: inline-block;
  border-right: 1px solid #ccc;
}
ul.list-header-bar:last-child {
  border:none;
}
ul.list-header-bar li strong {
  font-weight: 700;
}
ul.list-header-bar li {
  display: inline-block;
  margin: 0 10px;
}
ul.list-header-bar li a {
  color: #666;    
  border-bottom: 2px solid transparent;
}
ul.list-header-bar li a:hover {
  color: #f50;
}
ul.list-header-bar li a.active {
  font-weight: 700;
  color: #f50;
  border-bottom: 2px solid #f50;
}

ul.direita {float: right}
ul.esquerda {float: left}

.header-cat {
  padding: 20px 0;
}

.search-box {
  padding: 0;
  display: block;  
  overflow: hidden;
  border: 1px solid #999;
}
.search-select {
  width: 30%;
  float: left;
}
.search-field {
    width: 80%;
    float: left;
}
.search-field input {
    font-size: 16px;    
    color: #666;
    width: 100%;    
    margin: 0;  
    border: 0;
    line-height: 48px;
    height: 48px;
    float: right;
    padding: 0 18px;
}
.search-btn {
    width: 20%;
    float: right;   
    color: #fff;
}
.search-btn button {
    height: 48px;   
    width: 100%;    
    margin: 0;  
    border: 0;
    color: #fff;
    background: #000;
    -webkit-transition: 0.25s ease-in-out;
    -moz-transition: 0.25s ease-in-out;
    transition: 0.25s ease-in-out; 
}
.search-btn button i {color: #fff}
.search-btn button:hover {background: #666;}

ul.list-menu {
  display: table;
  margin: 0 auto;
}
ul.list-menu li {
  display: inline-block;
}
ul.list-menu li a {
  font-size: 14px;  
  color: #222;
  padding-left: 10px;
  padding-right: 10px;
  display: inline-block;
  text-decoration: none;
  outline: 0;
  height: 48px;
  line-height: 48px;
}
ul.list-menu li a:hover {color: #f50}

/* Home Fone */
#home-fone {
  display: block;
  padding: 10px 0;
  background: #000;
  color: #999;
  font-size: 13px;
}
#home-fone strong {
  font-weight: 700;
  color: #fff;
}
.fone {
  margin: 0 15px;
  display: inline-block;
}

@media only screen and (max-width: 767px) {
  .fone {
    width: 100%;
    margin: 0;
    text-align: center;
  }
}

/* Home Serviço */
#home-servicos {
  display: block;
  padding: 60px 0;
}
#home-servicos h1 {}
#home-servicos h1 small {}

.serv-item {
  text-align: center;
  position: relative;
  margin: 15px 0;
}
.serv-item h1 {
  font-size: 18px;
  margin: 0;
  line-height: 26px;
  text-transform: none;
  color: #fff;
}

.serv-item .txt {
  position: absolute;
  width: 100%;
  height: 100%;
  /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#000000+0,000000+100&0+0,0.65+100 */
  background: -moz-linear-gradient(top, rgba(0,0,0,0) 0%, rgba(0,0,0,0.65) 100%); /* FF3.6-15 */
  background: -webkit-linear-gradient(top, rgba(0,0,0,0) 0%,rgba(0,0,0,0.65) 100%); /* Chrome10-25,Safari5.1-6 */
  background: linear-gradient(to bottom, rgba(0,0,0,0) 0%,rgba(0,0,0,0.65) 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00000000', endColorstr='#a6000000',GradientType=0 ); /* IE6-9 */
  color: #fff;
}
.serv-item a .txt {
  -webkit-transition: 0.25s ease-in-out;
  -moz-transition: 0.25s ease-in-out;
  transition: 0.25s ease-in-out;   
  border: 5px solid #fff;
}
.serv-item a:hover .txt {
  border: 5px solid #0409f4;
}
.serv-item .txt .bottom {
  position: absolute;
  bottom: 0;
  width: 100%;
  padding: 20px;
}

/* Home Sobre */
#home-sobre {
  background: url(../images/home-sobre-bg.jpg) top center ;
  display: block;
  padding: 60px 0;  
}
.fl-container {  
  display: -webkit-flex;
  display: flex;
  width: 100%;
  height: 317px;
}

.fl-item {
  text-align: left;
  margin: auto;
  width: 100% !important;
  height: auto !important;
}

@media only screen and (max-width: 991px) {
  .fl-container {
    height: auto;
    margin-top: 30px;
  }
  .fl-item {
    width: 80%;
    text-align: center;
  }
}

/* Home Clientes */
#home-clientes {
  display: block;
  padding: 60px 0;
}

.img-clientes {
  margin-top: 15px;
  margin-bottom: 15px;
}
@media only screen and (max-width: 991px) {}

/* Footer */
footer {
  background: #000;
  padding: 60px 0;
  color: #999;
  font-size: 13px;
}
footer a {color: #999}

.credits {float: right;}
.credits i {
  font-size: 18px;
  margin: 0 5px;

}

.infos {
  float: left;
}

.contato {
  float: left;
}
.contato strong {
  color: #fff;
  font-weight: 700;
  font-size: 14px;
}

.infos .logo {
  float: left;
}
.infos .txt {
  float: left;  
  margin: 0 40px 0 20px;
  width: 350px;
}

@media only screen and (max-width: 991px) {
  .infos {width: 100%;}
  .infos .logo {
    display: block;
    width: 100%;
    text-align: center;
  }
  .infos .txt {
    display: block;
    width: 100%;
    text-align: center;
    margin: 0;
  }

  .credits {
    float: left;
    width: 100%;
    text-align: center;
  }

  .contato {
    display: block;
    margin: 20px 0;
    text-align: center;
    width: 100%;
  }
}

@media only screen and (max-width: 768px) {
    ul.list-bread {
      width: 100%;
      margin: 0 0 10px;
    }

    /* HEADER */    
    h1 hr {
      display: block;
      margin: 20px auto 0 auto;
    }

    .logo {margin-bottom: 15px;}

    /* CONTATO */
    .contato-info {margin-top: 40px;}

    /* FOOTER */
    footer {margin: 0}
    footer h1 {text-align: center;}
}