/*
Theme Name: Emdutos
Theme URI: https://emdutos.com.br/
Author: Toborino (a partir de theme by Jakson)
Author URI: https://toborino.com/
Description: Tema para o site Emdutos.
Requires at least: 6.7
Tested up to: 6.7
Requires PHP: 7.4
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: emdutos
Tags: Block Editor Patterns, Site Editor

/*  Smoot Scroll */
html {
  scroll-behavior: smooth;
}

/*  Reduced motion prefs  */
@media screen and (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }
}

@view-transition {
  navigation: auto;
}

/*  Navigation Block Breakpoint. Credit: https://wpdocs.io/ */
body .wp-block-navigation__responsive-container-open:not(.always-shown) {
  display: block !important;
}

body .wp-block-navigation__responsive-container:not(.hidden-by-default):not(.is-menu-open) {
  display: none !important;
}

/* Change the width to the breakpoit of the Nav */
@media (min-width: 799px) {
  body .wp-block-navigation__responsive-container-open:not(.always-shown) {
    display: none !important;
  }

  body .wp-block-navigation__responsive-container:not(.hidden-by-default):not(.is-menu-open) {
    display: block !important;
  }
}

/* end nav break point */

/* Nicley wrapped headlines */
h1,
h2,
h3,
h4 {
  text-wrap: balance;
}

.entry-content {
  display: grid;
  gap: 3rem;
  grid-template-columns: 1fr;
}

.single-post .entry-content {
  gap: 0;
}

/* I've no idea why when you add a backgroud colour to a column, WP by default adds padding to it... so weird - this get's rid of that */
:where(.wp-block-columns.has-background) {
  padding: initial;
}

/* Pull Quote */
.wp-block-pullquote blockquote {
  display: grid;
  gap: 20px;
}

.wp-block-pullquote cite {
  font-size: 80%;
  font-weight: 600;
}

/* Search Block */
.wp-block-search__input {
  border: 1px solid;
}

.wp-block-search__button {
  box-shadow: none;
  border: 1px solid var(--wp--preset--color--custom-blue-10);
  border-radius: 0;
  color: white;
  padding: 0.4rem 1rem 0.5rem 1rem;
  font-weight: 700;
}

/* Comments */
.comment-form-cookies-consent {
  font-size: 14px;
  line-height: 2;
}

/* Keep our titles link the off black color*/
.wp-block-post-title :where(a) {
  color: var(--wp--preset--color--custom-off-black);
}

/* Button hover state  - core button block still does not have this and I can't figure out how to do it in theme.json! */
.wp-block-button__link,
a {
  transition: 0.5s;
}

.wp-block-button.is-style-fill .wp-block-button__link:hover,
#commentform .form-submit.wp-block-button input:hover {
  background: var(--wp--preset--color--custom-white);
  color: var(--wp--preset--color--custom-blue-10);
}

.wp-block-button .wp-block-button__link:hover {
  background: var(--wp--preset--color--custom-white);
  color: var(--wp--preset--color--custom-blue-10);
  border-color: var(--wp--preset--color--custom-blue-10);
}

.wp-block-button.is-style-outline .wp-block-button__link {
  border-color: var(--wp--preset--color--custom-blue-10);
  color: var(--wp--preset--color--custom-blue-10);
}

.wp-block-button.is-style-outline .wp-block-button__link:hover {
  background: var(--wp--preset--color--custom-blue-10);
  color: var(--wp--preset--color--custom-white);
  border-color: var(--wp--preset--color--custom-blue-10);
}

a:hover:not(.wp-block-navigation-link a, .wp-block-site-title a, .wp-block-button__link.wp-element-button, a.wp-block-read-more) {
  text-decoration: underline !important;
}

.wp-block-navigation-link a:hover {
  color: #ffffff !important;
}

.site-footer .wp-block-navigation-link a:hover {
  text-decoration: underline !important;
}

.wp-block-button.is-style-outline--2 .wp-block-button__link {
  padding: 0.6rem 1rem;
  border-width: 1px;
}

/* Clip-path do Hero Home */
.home-image-hero {
  position: relative;
}

figure.home-image,
figure.home-image img {
  display: block;
  width: 100%;
}

figure.home-image {
  -webkit-mask: url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%201200%20500%22%3E%3Cpath%20d%3D%22M%2010%2C0%20L%201190%2C0%20Q%201200%2C0%201200%2C10%20L%201200%2C445%20Q%201200%2C455%201190%2C455%20L%20874%2C455%20L%20808%2C499%20L%20391%2C499%20L%20325%2C455%20L%2010%2C455%20Q%200%2C455%200%2C445%20L%200%2C10%20Q%200%2C0%2010%2C0%20Z%22%20fill%3D%22black%22%2F%3E%3C%2Fsvg%3E") no-repeat center / 100% 100%;
  mask: url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%201200%20500%22%3E%3Cpath%20d%3D%22M%2010%2C0%20L%201190%2C0%20Q%201200%2C0%201200%2C10%20L%201200%2C445%20Q%201200%2C455%201190%2C455%20L%20874%2C455%20L%20808%2C499%20L%20391%2C499%20L%20325%2C455%20L%2010%2C455%20Q%200%2C455%200%2C445%20L%200%2C10%20Q%200%2C0%2010%2C0%20Z%22%20fill%3D%22black%22%2F%3E%3C%2Fsvg%3E") no-repeat center / 100% 100%;
}

.hero-textos {
  position: absolute;
  width: 100%;
  bottom: 0px;
}

.hero-textos strong {
  color: var(--wp--preset--color--custom-blue-06);
}

.hero-textos img,
.hero-text img,
.arrow-up-right-blog img {
  vertical-align: middle;
}

.hero-topo {
  position: absolute;
  top: -25px;
  left: 30px;
  z-index: 100;
}

.popover-lateral {
  position: relative;
}

.pills-cidade {
  position: absolute;
  top: 100px;
  margin-left: -30px !important;
}

.pills-40anos {
  position: absolute;
  bottom: 100px;
  right: 0;
  margin-right: -10px !important;
}

/* Sobre Nós - Home */
/* Sobrescreve o overlay padrão do Cover */
.cover-gradient .wp-block-cover__background {
  background: linear-gradient(190deg, transparent 0%, transparent 40%, rgba(0, 0, 0, 0.75) 100%) !important;
  opacity: 1 !important;
  border-radius: 16px;
}

.cover-gradient-image {
  background: linear-gradient(190deg, transparent 0%, transparent 40%, rgba(0, 0, 0, 0.75) 100%);
  border-radius: 16px;
  width: 100%;
}

.cover-gradient-image img {
  mix-blend-mode: multiply;
}

.cover-content img {
  mix-blend-mode: normal;
}

.atuacao .wp-block-cover {
  padding: 0.5em;
}

.bloco_iso {
  background: rgba(255, 255, 255, 0.9);
}

.bloco_pilar {
  display: flex;
  align-items: end
}

mark {
  border-radius: 8px;
}

.img_blog {
  position: relative;
}

.link_blog {
  position: absolute;
  bottom: 0;
  width: 100%;
}

.arrow-up-right-blog {
  position: relative;
  display: inline-flex;
  align-items: center;
  color: #ffffff;
  background: radial-gradient(circle, rgba(99, 145, 255, 1) 20%, rgba(45, 98, 227, 1) 80%);
  text-decoration: none;
  width: 40px;
  height: 40px;
  border-radius: 50%;
}

a.wp-block-read-more {
  position: relative;
  display: inline-flex;
  align-items: center;
  color: #1A2551;
  background: #F0F6FE;
  border: 1px solid #F0F6FE;
  border-radius: 40px;
  font-size: var(--wp--preset--font-size--medium);
  font-style: normal;
  font-weight: 700;
  line-height: 2;
  padding-top: 0.15rem;
  padding-right: 1rem;
  padding-bottom: 0.15rem;
  padding-left: 1rem;
  box-shadow: none;
}

a.wp-block-read-more:hover {
  color: #F0F6FE !important;
  background: #1A2551 !important;
  border-color: #1A2551;
}

.pilha_space {
  justify-content: space-between;
}

/* 1. Corrige o espaço fantasma dentro do figure */
.wp-block-image img {
  display: block;
  /* fallback */
}

/* 2. Alinha a figura verticalmente com o texto no container flex */
.wp-block-group.is-layout-flex .wp-block-image {
  /*align-self: center;*/
  line-height: 0;
  /* elimina qualquer espaço residual de inline */
}

.bloco-img-produto {
  display: flex;
  align-items: center;
  justify-content: center;
}

.w-100 {
  width: 100%;
}

/* ===========================
   Bloco Details - FAQ Style
   =========================== */

/* Wrapper — se usar vários details seguidos dentro de um Group */
.wp-block-details+.wp-block-details {
  margin-top: 10px;
}

/* Card principal */
.wp-block-details {
  background-color: var(--wp--preset--color--custom-blue-02);
  border-radius: 8px;
  padding: 0;
  border: none;
  overflow: hidden;
}

/* Remove triângulo nativo */
.wp-block-details summary {
  list-style: none;
}

.wp-block-details summary::-webkit-details-marker {
  display: none;
}

/* Summary — linha clicável */
.wp-block-details>summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 14px 20px;
  font-size: var(--wp--preset--font-size--medium);
  font-weight: 700;
  color: var(--wp--preset--color--custom-off-black);
  cursor: pointer;
  user-select: none;
  line-height: 1.4;
  /* remove estilo padrão do WP */
  background: transparent;
  border: none;
}

/* Ícone + */
.wp-block-details>summary::after {
  content: "+";
  font-size: 2.5rem;
  font-weight: 400;
  color: var(--wp--preset--color--custom-blue-07);
  flex-shrink: 0;
  line-height: 1;
  /* remove a seta SVG padrão do WP */
  background-image: none !important;
  width: auto;
  height: auto;
  display: inline-block;
  transition: transform 0.3s ease;
  transform: rotate(0deg);
}

/* Ícone − quando aberto */
.wp-block-details[open]>summary::after {
  content: "+";
  transform: rotate(45deg);
}

/* Conteúdo interno */
.wp-block-details>*:not(summary) {
  padding: 0 20px 18px;
  color: var(--wp--preset--color--custom-off-black);
  line-height: 1.6;
  margin: 0;
  overflow: hidden;
  max-height: 0;
  opacity: 0;
  transition: max-height 0.35s ease, opacity 0.3s ease;
}

/* Quando aberto */
.wp-block-details[open]>*:not(summary) {
  max-height: 500px;
  /* valor maior que o conteúdo real */
  opacity: 1;
}

.wp-block-latest-posts li {
  margin-bottom: 1rem;
}

/* Funcionalidades */
.w-100 {
  width: 100%;
}

.is-desktop {
  display: flex !important;
}

.is-mobile,
.is-mobile-flex {
  display: none !important;
}

/* Bloco Produtos */

.produtos_representados a {
    text-decoration: none;
}

@media (max-width: 767px) {
  .is-mobile {
    display: block !important;
  }

  .is-mobile-flex {
    display: flex !important;
  }

  .is-desktop {
    display: none !important;
  }

  figure.home-image,
  figure.home-image img {
    mask: none;
    aspect-ratio: 1;
    object-fit: cover;
    border-radius: 1rem;
  }

  .is-style-area-but .wp-block-button__link {
    padding-left: 0.5rem;
  }

  .site-footer {
    text-align: center;
  }

  .wp-block-navigation.is-vertical {
    flex-direction: row;
    justify-content: space-evenly;
    margin-bottom: 1rem;
  }

  .site-footer .wp-block-navigation {
    font-size: var(--wp--preset--font-size--regular) !important;
  }

  .is-reverse {
    flex-direction: column-reverse;
  }

  .entry-content .sobre {
    display: flex;
    flex-direction: column;
  }

  .colocation .wp-block-columns>.wp-block-column {
    flex-basis: 30% !important;
  }

  .pilares {
    display: block !important;
  }
}

.menu-pt .alignwide,
.menu-en .alignwide,
.menu-es .alignwide {
  width: 100%;
}


/* Contact Form 7  */
.wpcf7-form label {
	text-transform: uppercase;
	font-size: .85rem;
	font-weight: 500;
}

.wpcf7-form-control.wpcf7-text,
.wpcf7-form-control.wpcf7-textarea,
.wpcf7-form-control.wpcf7-file,
.wpcf7-form-control.wpcf7-number.wpcf7-validates-as-number,
.wpcf7-form-control.wpcf7-select {
	border: 1px solid var(--wp--preset--color--custom-blue-04);
	padding: 10px;
	font-size: 1rem;
	width: 100%;
	box-sizing: border-box;
	border-radius:1rem;
	font-family: inherit;
}

.wpcf7-form-control.wpcf7-submit {
	background-color: var(--wp--preset--color--custom-blue-09);
	color: var(--wp--preset--color--custom-white);
	border: 2px solid var(--wp--preset--color--custom-blue-09);
	border-radius: 30px;
	font-size: 1rem;
	text-transform: uppercase;
	padding: .425rem 1.7rem .35rem;
	cursor: pointer;
	float: right;
	font-family: inherit;
}

.wpcf7-form-control.wpcf7-submit:hover {
	background-color: var(--wp--preset--color--custom-white);
	color: var(--wp--preset--color--custom-blue-09);
	border: 2px solid var(--wp--preset--color--custom-blue-09);
}

.wpcf7 form .wpcf7-response-output {
	font-family: inherit;
	padding: 1rem;
	font-weight: 700;
	text-align: center;
	margin: 2rem 0;
}

.wpcf7-form-control.wpcf7-not-valid {
	border-color: #dc3232;
}

.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output,
.wpcf7 form.payment-required .wpcf7-response-output {
	border-color: #ffb900;
	background: #ffb900;
	color: var(--wp--preset--color--custom-white);
}

.wpcf7 form.sent .wpcf7-response-output {
	border-color: #009900;
	background: #009900;
	color: var(--wp--preset--color--custom-white);
	/* Green */
}

.wpcf7 form.failed .wpcf7-response-output,
.wpcf7 form.aborted .wpcf7-response-output {
	border-color: #dc3232;
	background: #dc3232;
	color: var(--wp--preset--color--custom-white);
	/* Red */
}

.wpcf7-spinner {
	display: block;
}