/*
Theme Name: Facility Soluções
Theme URI: facility-toss-v1
Author: TOSS STUDIO
Description: Tema criado pela TOSS
Version: 1.0
*/

@import url("css/materialize.css");

  body { color: #ffffff; font-size: 18px; line-height: 26px; font-weight: 400; font-family: "Space Grotesk", sans-serif;background: #050505; font-size-adjust: auto; }
  html { scroll-behavior: smooth; }

  h1, h2, h3, h4, h5, nav, .wp_pagination, .categoria, footer .menu, .visualizar, .home-slider .slider p a, .btn, .btn-large { font-family: "Space Grotesk", sans-serif; text-transform: uppercase; }

  h1 { font-size: 110px; color: #fff; line-height: 100px; font-weight: 600; text-transform: uppercase; }
  h2 { font-size: 50px; color: #fff; line-height: 54px; font-weight: 600; }
  h3 { font-size: 36px; color: #fff; line-height: 40px; font-weight: 600; }
  h4 { font-size: 28px; color: #fff; line-height: 34px; font-weight: 600; }
  h5 { font-size: 24px; color: #fff; line-height: 34px; font-weight: 400; }


  a { color: #050505; transition: .3s; }
  a:hover { color: #d7d7d7; }

  strong { color: #fff; font-weight: 600; }
  b { font-weight: 600; }

  .divider { margin: 25px 0; }

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

  .material-icons { vertical-align: middle; }

  .clear {  clear: both; }

  blockquote { font-weight: 700; font-style: italic; border-left: 5px solid #000000; text-align: justify; }

  .divider { margin: 50px 0 60px; }

  .container { width: 84%; max-width: 1600px; }

  #sidenav-overlay { z-index: 99!important; }

  .row ul { margin-top: 20px; margin-left: 20px; margin-bottom: 40px; }
  .row ul li { margin-bottom: 1px; padding-bottom: 1px; list-style: disc; }

  .row ol { margin-top: 20px; margin-bottom: 20px; }
  .row ol li { margin-bottom: 1px; padding-bottom: 1px; }

  #gallery-1 .gallery-item { float: left; text-align: center; width: 23.9%!important; margin: 0.5%!important; }
  #gallery-1 img { border: 0!important; border-radius: 8px; }

  .cky-consent-container .cky-consent-bar { border-radius: 4px!important; }
  .cky-title { margin: 0!important; }

/* Header */
  nav { height: 130px!important; line-height: 130px!important; padding: 0; background: transparent; z-index: 999; position: fixed; z-index: 999; top: 0; }
  nav .nav-wrapper { background-color: transparent; z-index: 998; }
  nav .brand-logo { margin: 30px 0 0 0; padding: 0; height: 100px!important; line-height: 100px!important; }
  nav .brand-logo img { width: 222px; height: auto; }

  nav ul { margin: 40px 0 0 0; }
  nav ul li { list-style: none!important; margin-top: 0; height: 50px; line-height: 50px; }
  nav ul li a { font-size: 18px; font-weight: 500; color: #fff; text-transform: uppercase; background: transparent; border: 2px solid transparent; padding: 0 25px; transition: .3s; border-radius: 2px; }
  nav ul li a:hover { background: #000000; color: #050505; border: 2px solid #000000;}

    ul.conversar { margin: 40px 0 0 20px; }
    ul.conversar li a { background: #050505; color: #ffffff; border: 1px solid #e3b82a;  }
    ul.conversar li a:hover { background: #050505; color: #fff; }

    nav .sub-menu { position: absolute; display: none; /*display: block;*/ max-width: 360px; margin-top: 0; background: #fff; border-radius: 20px; padding: 15px 0 20px 0; box-shadow: 0 30px 50px 0 rgba(0,0,0,0.1),0 30px 50px 0 rgba(0,0,0,0.1);  transition: all .3s; z-index: 1; }
    nav .sub-menu li { display: contents!important; white-space: normal; }
    nav .sub-menu li a { font-size: 14px; line-height: 18px; color: #050505; border-radius: 0; border-bottom: 1px dotted #eaeaea; padding-top: 10px; padding-bottom: 10px; }
    nav .sub-menu li a:before { content: '•'; margin-right: 5px; transition: .3s; }
    nav .sub-menu li a .menu-item-description { display: block; vertical-align: top; white-space: normal; font-size: 13px; line-height: 14px; text-transform: none; font-weight: 400; color: #9a9a9a; padding-right: 20px; margin: 3px 0 0 0; transition: .3s; }
    nav .sub-menu li a:hover { color: #fff; background: #050505; border-bottom: 1px dotted #050505; }
    nav .sub-menu li a:hover .menu-item-description { color: #fff; }
      nav .sub-menu li .sub-menu { top: 0; left: 360px; width: 250px; min-height: 100%; height: auto; margin-left: -20px; padding: 15px 0 20px 0;background: #050505; border-radius: 0 20px 20px 0; box-shadow: none; }
      nav .sub-menu li .sub-menu a { color: #fff; white-space: normal; line-height: 14px; padding-top: 10px; border: 0; }
      nav .sub-menu li .sub-menu a:hover { color: #050505; }


    li.menu-item-has-children:hover > .sub-menu { display: block; }


  .z-depth-1, nav, .card-panel, .card, .toast, .btn, .btn-large, .btn-floating, .dropdown-content, .collapsible, .side-nav { box-shadow: none; }

  .main { padding: 20px; }


  .titulo-paginas { padding: 0; margin: 0; background-attachment: fixed; background-size: cover; background-color: #000000;  }
  .titulo-paginas .gradiente { padding: 200px 0 50px; background: rgb(0,0,0); background: linear-gradient(0deg, rgba(0,0,0,0.4009978991596639) 0%, rgba(0,0,0,0.6026785714285714) 100%); }
  .titulo-paginas .gradiente .row { margin: 0; padding: 0; }
  .titulo-paginas .gradiente .row h1 { color: #fff; }
  .titulo-paginas .gradiente .row h3 { font-size: 24px; line-height: 30px; font-weight: 300; margin: 10px 0; color: #fff; }


  /* SLIDER */
  .section.home-slider { margin: 0; padding: 0; z-index: 1; }
  .section.home-slider .slider { height: 100vh!important; z-index: 0; }
  .section.home-slider .slider .slides { height: 100vh!important; background: #000000!important; }
  .section.home-slider .slider .slides li img { opacity: 1; }
  .section.home-slider .slider .slides li .caption { top: 48%!important; left: 10%; width: 60%; text-align: left; }
  .section.home-slider .slider .slides li .caption h1 { font-size: 70px; color: #050505; line-height: 80px; color: #fff; margin: 0 0 15px; }
  .section.home-slider .slider .slides li .caption h4 { color: #000000; margin: 0 0 35px; width: 100%; font-weight: 300; }
  .section.home-slider .slider .slides li .caption .btn { background: transparent; color: #fff; border: 2px solid #fff; height: 44px; line-height: 40px; z-index: 999; }
  .section.home-slider .slider .indicators { left: 10%; bottom: 100px; height: 50px; text-align: left; z-index: 9; }
  .section.home-slider .slider .indicators .indicator-item { margin: 0 10px; width: 10px; height: 10px; background: transparent; border: 2px solid #fff!important; border-radius: 10px; opacity: .5; }
  .section.home-slider .slider .indicators .indicator-item.active { background-color: #fff; border: 2px solid #fff; opacity: 1; }


  .home-ivan { text-align: center; padding: 100px 0; }
  .home-ivan h1 { color: #fff; overflow-wrap: break-word; font-size: 200px; line-height: 138px; }



  /* 1) Grid sem espaçamento (gutter) só no portfolio */
  .section.portfolio > .row {
    margin-left: 0;
    margin-right: 0;
  }

  .section.portfolio > .row > article.col {
    padding: 0; /* remove o gutter do Materialize */
  }

  /* 2) Card: fundo + título dentro do box */
  .section.portfolio .tema-card{
    display: block;
    position: relative;
    width: 100%;
    overflow: hidden;
    text-decoration: none;
  }

  /* garante que o box tenha altura via ratio */
  .section.portfolio .tema-thumb{
    position: relative;
    width: 100%;
    overflow: hidden;
  }

  /* se sua ratio-4x3 já existe, ok. Se não, use esta: */
  .section.portfolio .ratio-4x3{
    padding-top: 75%; /* 4:3 */
  }

  /* fundo ocupando tudo */
  .section.portfolio .tema-bg{
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    transform: scale(1);
    transition: transform .25s ease;
    will-change: transform;
  }

  /* hover zoom leve */
  .section.portfolio .tema-card:hover .tema-bg{
    transform: scale(1.06);
  }

  /* título dentro do box, embaixo à esquerda */
  .section.portfolio .tema-title {
    position: absolute;
    left: 25px;
    bottom: 25px;
    margin: 0;
    z-index: 2;
    line-height: 1.1;
    color: #fff!important;
    font-size: 18px;
    line-height: 20px;
    font-weight: 500;
  }



  /* (opcional) uma camada de contraste só na base, pra leitura */
  .section.portfolio .tema-card::after{
    content:"";
    position: absolute;
    inset: 0;
    z-index: 1;
    background: linear-gradient(to top, rgba(0,0,0,.55), rgba(0,0,0,0) 60%);
    pointer-events: none;
  }

  /* garante que o texto fique acima do overlay */
  .section.portfolio .tema-title{ z-index: 2; }


  .section.portfolio.portfolio-relacionados { padding: 100px 0; background: #101010; }
  .section.portfolio.portfolio-relacionados .cta { padding: 50px 0 0; }

  /* FOOTER */
   footer.page-footer { margin: 0; padding: 50px 0 100px; background: #050505; }
   footer.page-footer .footer-copyright { height: 100%; line-height: normal; color: #fff; font-weight: 400; background: transparent; }
   footer.page-footer .footer-copyright .col { padding: 0 30px; }
   footer.page-footer .footer-copyright ul { margin: 0 0 0 17px; }
   footer.page-footer .footer-copyright ul li { font-family: 'Roboto', sans-serif; }
   footer.page-footer .footer-copyright h5 { color: #fff; margin: 0 0 20px; font-weight: 600; }
   footer.page-footer .footer-copyright a { color: #ffffff; font-weight: 400; }
   footer.page-footer .footer-copyright a:hover { color: #999999; }
   footer .social a { font-size: 30px; text-decoration: none; font-weight: 400; color: #fff!important; width: 54px; height: 54px; line-height: 54px; margin: 0; text-align: center; border: 1px solid #222222; border-radius: 4px; }
   footer .social a:hover { background: #000000; color: #050505!important; }
   footer.page-footer .footer-copyright .copy { margin-top: 50px; padding: 10px 0; text-align: center; font-size: 12px; line-height: 18px; text-transform: uppercase; border-top: 1px solid #222222; }


  .btn, .btn-large, .wpcf7 input[type=submit], .search-submit { font-size: 17px; font-weight: 600; background: #fff; color: #050505; border: 2px solid #fff; text-transform: uppercase; padding-left: 25px; padding-right: 25px; height: 54px; line-height: 48px; border-radius: 2px; box-shadow: 0; transition: 0.3s; vertical-align: middle; }
  .btn:hover, .btn-large:hover, .wpcf7 input[type=submit]:hover { color: #fff; background: #444; border: 2px solid #444; box-shadow: 0 20px 30px 0 rgba(0,0,0,0.1),0 20px 30px 0 rgba(0,0,0,0.1);}

  .btn.branco { background: #fff; color: #050505; border: 2px solid #fff; }
  .btn.branco:hover { color: #fff; background: #050505; border: 2px solid #000000; }



/*************** RESPONSIVO ***************/

@media only screen and (max-width: 1600px) {

  body { font-size: 16px; line-height: 22px; }

  h1 { font-size: 80px; line-height: 80px; }
  h2 { font-size: 40px; line-height: 44px; }
  h3 { font-size: 30px; line-height: 34px; }
  h4 { font-size: 24px; line-height: 28px; }
  h5 { font-size: 20px; line-height: 24px; }

  /* Header */
    nav { height: 140px!important; line-height: 140px!important; }
    nav .brand-logo { margin: 25px 0 0 0; padding: 0; height: 100px!important; line-height: 100px!important; }
    nav .brand-logo img { width: 200px; height: auto; }

    nav ul { margin: 45px 0 0 0; }
    nav ul li { list-style: none!important; margin-top: 0; height: 46px; line-height: 46px; }
    nav ul li a { font-size: 15px;  padding: 0 22px;  }
      ul.conversar { margin: 45px 0 0 20px; }


  .container { width: 90%; }

  /* SLIDER */
  .section.home-slider .slider .slides li .caption { top: 47%!important; left: 7%; width: 65%; text-align: left; }
  .section.home-slider .slider .slides li .caption h1 { font-size: 56px; line-height: 66px; }
  .section.home-slider .slider .slides li .caption h4 { font-size: 24px; line-height: 32px; }
  .section.home-slider .slider .indicators { left: 7%; bottom: 50px; height: 50px; text-align: left; z-index: 9; }
  .section.home-slider .slider .indicators .indicator-item { margin: 0 10px; width: 10px; height: 10px; }


}

@media only screen and (max-width: 1280px) {

  /* SLIDER */
  .section.home-slider { margin-top: 0; }
  .section.home-slider .slider .indicators { left: 9.5%; bottom: 50px; height: 50px; text-align: left; z-index: 9; }

}


@media only screen and (max-width: 992px) {

  body { font-size: 16px; line-height: 22px; }

  h1 { font-size: 50px; line-height: 46px; }
  h2 { font-size: 32px; line-height: 34px; }
  h3 { font-size: 28px; line-height: 30px; }
  h4 { font-size: 22px; line-height: 24px; }
  h5 { font-size: 18px; line-height: 20px; }

  .container { max-width: 90%; width: 90%; }

  .sub-nav { display: none; }

  nav { height: 120px!important; line-height: 120px!important; }
  nav .brand-logo { left: 50px!important; margin: 0; -webkit-transform: translateX(0); transform: translateX(0); height: 120px!important; line-height: 120px!important; }
  nav .brand-logo img { width: 160px; }

  nav ul li a { font-size: 13px; height: 36px!important; line-height: 30px!important; padding: 0 18px; }

    ul.conversar { margin: 40px 50px 0 15px; }
    ul.conversar li a { height: 36px!important; line-height: 30px!important; }

  nav a.button-collapse { float: right; margin: 0; height: 128px!important; line-height: 128px!important; }
  nav a.button-collapse img { width: 30px!important; margin: 0 8px 0 0; }


  /* SIDE MOBILE MENU */
  .side-nav { width: 100%; background: #050505; padding-top: 50px; z-index: -1; }
  .side-nav li { line-height: 40px; }
  .side-nav a { background: #050505; color: #fff; font-weight: 600; margin: 1px 0; height: 40px; line-height: 40px; border: 0; border-radius: 0; padding: 0 30px; }
  .side-nav a:hover { color: #050505; background: #fff; border-radius: 0; }
  #menu-menu-mobile { margin: 0; }


  .titulo-paginas { padding: 0; margin: -100px 0 0 0; }
  .titulo-paginas .gradiente { padding: 180px 0 40px; }


  /* SLIDER */
  .section.home-slider { margin-top: 0; }
  .section.home-slider .slider .indicators { left: 0; bottom: 25px; text-align: center; z-index: 9; }
  .section.home-slider .slider .indicators .indicator-item { margin: 0 10px; width: 10px; height: 10px; }


/* FOOTER */


}

@media only screen and (max-width: 600px) {

  nav { height: 80px!important; line-height: 80px!important; }
  nav .brand-logo { left: 25px!important; height: 88px!important; line-height: 88px!important; padding: 0; }
  nav .brand-logo img { width: 170px; }

  nav a.button-collapse { float: right; margin: 0; height: 90px!important; line-height: 90px!important; }

  nav ul li a { font-size: 12px; height: 36px!important; line-height: 34px!important; padding: 0 15px; }

    ul.conversar { margin: 21px 5px 0 10px; }
    ul.conversar li a { height: 36px!important; line-height: 32px!important; }

  .section.home-slider .slider .slides li .caption { top: 55%!important; left: 5%; width: 90%; text-align: center; }
  .section.home-slider .slider .slides li .caption h1 { font-size: 30px; line-height: 40px; margin: 0 0 10px; }
  .section.home-slider .slider .slides li .caption h4 { font-size: 16px; line-height: 24px; }

  .home-ivan { text-align: center; padding: 50px 0; }
  .home-ivan h1 { color: #fff; overflow-wrap: break-word; font-size: 90px; line-height: 60px; }




}
