/*
 Theme Name:   Innovah
 Theme URI:    https://www.innovah.it
 Description:  Tema child di Hello Elementor con palette personalizzata
 Author:       Antonio Musilli
 Author URI:   https://www.innovah.it
 Template:     hello-elementor
 Version:      1.0
*/

@import url('https://fonts.googleapis.com/css2?family=Libre+Baskerville&family=Montserrat:wght@300&display=swap');

:root {
  --color-navy: #0A1F44;
  --color-blu-industriale: #19547B;
  --color-grigio-chiaro: #F2F2F2;
  --color-verde-acqua: #2EC4B6;
  --color-arancione: #FF6B35;

  --font-titoli: 'Libre Baskerville', serif;
  --font-paragrafi: 'Montserrat', sans-serif;
}

body {
  font-family: var(--font-paragrafi);
  color: var(--color-navy);
  background-color: var(--color-grigio-chiaro);
  font-weight: 300;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-titoli);
  color: var(--color-navy);
  font-weight: normal;
}

/* Limita l'overflow orizzontale su body */
/* Nasconde scrollbar su tutto il sito */
html, body {
    overflow-x: hidden;
}

/* Nasconde scrollbar nei browser Webkit (Chrome/Edge/Safari) */
*::-webkit-scrollbar {
    display: none;
}


.elementor-button {
  background-color: var(--color-arancione);
  color: white;
  border-radius: 5px;
  padding: 12px 24px;
  font-weight: 400;
  transition: background-color 0.3s ease;
}

.elementor-button:hover {
  background-color: var(--color-verde-acqua);
}

.section-dark {
  background-color: var(--color-navy);
  color: white;
}

.section-blu-industriale {
  background-color: var(--color-blu-industriale);
  color: white;
}

.section-light {
  background-color: var(--color-grigio-chiaro);
  color: var(--color-navy);
}

a {
  color: var(--color-verde-acqua);
  text-decoration: underline dotted;
}

a:hover {
  color: var(--color-arancione);
}

header.site-header {
  background-color: var(--color-navy);
  color: white;
}
.vertical-divider {
  width: 1px;
  height: 50px;
  background-color: #fff;
  margin-left: 0px;
  margin-right: 20px;
  margin-bottom: 20px;
  margin-top: 20px;
}
a.link-footer-gast {
  color: #FFF !important;
}

a:visited.link-footer-gast {
  color: #FFF;
}

a:hover.link-footer-gast {
  color: #FF6B35 !important;
}
.privacy-label {
	font-family: Montserrat !important;
	font-size: 0.9rem !important;
	color: #666666;
	line-height: 0px;
}
.privacy-label a {
	font-family: Montserrat !important;
	font-size: 0.9rem !important;
	color: #666666;
	line-height: 0px;
	font-weight: bold;
}
.privacy-label a:hover {
	text-decoration:underline !important;
}


.elementor-button-icon svg {
  height: auto;
  width: 4em;
}
.elementor-widget-image a img[src$=".svg"] {
  width: 100px !important;
}
document.body.style.overflowX = "hidden";

/* Posiziona la freccia accanto al testo */
.elementor-nav-menu--main .elementor-item.has-submenu .sub-arrow {
  display: inline-flex;
  align-items: center;
  margin-left: 6px; /* spazio fra testo e freccia */
  position: static; /* rimuove eventuali posizionamenti assoluti */
  transform: none;  /* evita rotazioni strane */
  vertical-align: middle;
}

/* Rimuove padding/margini che causano l'offset */
.elementor-nav-menu--main .elementor-item .sub-arrow svg {
  width: 15px;
  height: 15px;
  fill: #B0BF1A; /* Verde acido (lo puoi sostituire con #B0BF1A o quello che vuoi) */
}

.cert-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 30px;
}
.cert-grid > .elementor-container {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}


/* stessa dimensione e stile per tutti i breadcrumb */
.breadcrumb,
.breadcrumb a,
.breadcrumb span{
  font-size:16px !important;   /* uniforma la misura */
  font-weight:400 !important;   /* peso normale */
  text-transform:none !important; /* niente maiuscole forzate */
  line-height:1.2;
  letter-spacing:.2px;
  color:whitesmoke;
}

/* separatore e corrente */
.breadcrumb .sep{ opacity:.8; }
.breadcrumb .crumb-current{ font-weight:600 !important; }

/* underline solo su hover */
.breadcrumb a{
  text-decoration:none;
}
.breadcrumb a:hover{
	color: white !important;
  text-decoration:underline !important;
  text-underline-offset:4px;
  text-decoration-thickness:1px;
}

/* Lista requisiti in stile "annuncio lavoro" */
.requisiti-list {
  list-style: none;          /* niente pallini standard */
  margin: 0;
  padding: 0;
  color: #0A1F44;            /* grigio simile allo screenshot */
  font-size: 18px;           /* adattabile */
  font-weight: 400;          /* testo regolare */
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
}

.requisiti-list li {
  margin-bottom: 8px;        /* spazio tra i punti */
}
.blu-breadcrumb a{
  text-decoration:none;
}
.blu-breadcrumb a:hover{
	color: #19547B;
  text-decoration:underline;
  text-underline-offset:4px;
  text-decoration-thickness:1px;
}
.requisiti-list li strong {
  font-weight: 600;          /* bold come nello screen */
  color: #4a4a4a;            /* leggermente più scuro */
}

/* Wrapper */
.custom-language-switcher {
  display: flex;
  align-items: center;
  background: transparent !important;
  padding: 0 !important;
  margin: 0 !important;
  line-height: 1;
  position: relative; z-index: 999; /* sopra video/overlay */
  font-family: 'Montserrat', sans-serif;
}

/* Lista inline */
.custom-language-switcher .lang-list {
  display: flex; align-items: center;
  list-style: none; margin: 0; padding: 1px;
}

/* Item e separatore */
.custom-language-switcher .lang-item { display: flex; align-items: center; }
.custom-language-switcher .lang-sep { margin: 0 6px; opacity: .4; color: #fff; }

/* Link */
.custom-language-switcher .lang-link {
  color: #fff !important;
  text-decoration: none !important;
  opacity: .72; transition: opacity .2s ease;
  font-weight: 600; font-size: 14px; vertical-align: middle;
  background: transparent !important; border: 0 !important; box-shadow: none !important;
}
.custom-language-switcher .lang-link:hover { opacity: 1; }

/* Corrente */
.custom-language-switcher .current,
.custom-language-switcher .is-current .lang-link {
  opacity: 1 !important; font-weight: 700 !important; cursor: default;
}

/* Mobile */
@media (max-width: 768px){
  .custom-language-switcher .lang-link { font-size: 13px; }
  .custom-language-switcher .lang-sep { margin: 0 6px; }
}

/* Ninja Tables – forza testo bianco in tutta l'intestazione */
.ninja_table_wrapper table thead,
.ninja_table_wrapper table thead tr,
.ninja_table_wrapper table thead th,
.ninja_table_wrapper table thead th *,
.ninja_table_wrapper table thead th a,
.ninja_table_wrapper table thead th span,
.ninja_table_wrapper table thead th div {
  color: #fff !important;
  opacity: 1 !important;              /* se il preset usa opacità sul thead/tr */
  mix-blend-mode: normal !important;  /* evita blend strani su sfondi scuri */
  -webkit-text-fill-color: #fff !important;
}

/* icone/simboli di ordinamento */
.ninja_table_wrapper table thead th .fa,
.ninja_table_wrapper table thead th svg,
.ninja_table_wrapper table thead th [class*="sort"] {
  color: #fff !important;
  fill: #fff !important;
  opacity: 1 !important;
}
/* Ninja Tables – forza testo bianco in tutta l'intestazione */
.ninja_table_wrapper table thead,
.ninja_table_wrapper table thead tr,
.ninja_table_wrapper table thead th,
.ninja_table_wrapper table thead th *,
.ninja_table_wrapper table thead th a,
.ninja_table_wrapper table thead th span,
.ninja_table_wrapper table thead th div {
  color: #fff !important;
  opacity: 1 !important;              /* se il preset usa opacità sul thead/tr */
  mix-blend-mode: normal !important;  /* evita blend strani su sfondi scuri */
  -webkit-text-fill-color: #fff !important;
}
/* Ninja Tables – forza testo bianco in tutta l'intestazione */
.ninja_table_wrapper table thead,
.ninja_table_wrapper table thead tr,
.ninja_table_wrapper table thead th,
.ninja_table_wrapper table thead th *,
.ninja_table_wrapper table thead th a,
.ninja_table_wrapper table thead th span,
.ninja_table_wrapper table thead th div {
  color: #fff !important;
  opacity: 1 !important;              /* se il preset usa opacità sul thead/tr */
  mix-blend-mode: normal !important;  /* evita blend strani su sfondi scuri */
  -webkit-text-fill-color: #fff !important;
}

/* icone/simboli di ordinamento */
.ninja_table_wrapper table thead th .fa,
.ninja_table_wrapper table thead th svg,
.ninja_table_wrapper table thead th [class*="sort"] {
  color: #fff !important;
  fill: #fff !important;
  opacity: 1 !important;
}
/* Ninja Tables – forza testo bianco in tutta l'intestazione */
.ninja_table_wrapper table thead,
.ninja_table_wrapper table thead tr,
.ninja_table_wrapper table thead th,
.ninja_table_wrapper table thead th *,
.ninja_table_wrapper table thead th a,
.ninja_table_wrapper table thead th span,
.ninja_table_wrapper table thead th div {
  color: #fff !important;
  opacity: 1 !important;              /* se il preset usa opacità sul thead/tr */
  mix-blend-mode: normal !important;  /* evita blend strani su sfondi scuri */
  -webkit-text-fill-color: #fff !important;
}

/* nascondi SOLO visivamente l’input nativo, NON display:none */
.elementor-field-type-upload input[type="file"]#form-field-cv{
  position:absolute;
  left:-9999px;
  width:1px; height:1px; 
  opacity:0;
}

/* wrapper e look */
.custom-file-wrapper{
  display:flex; align-items:center; gap:12px; flex-wrap:wrap;
}
.custom-file-btn{
  background:#0A3150; color:#fff; padding:12px 24px; border-radius:6px;
  font-weight:600; font-size:15px; cursor:pointer; transition:.2s;
  display:inline-flex; align-items:center; justify-content:center;
}
.custom-file-btn:hover{ background:#154a78; }
.custom-file-name{ font-size:14px; color:#222; }
