/*
Theme Name: Indaweb Child
Template: Divi
Theme URI: https://indaweb.it
Author: Indaweb
Author URI: https://indaweb.it
Description: Flexible Multi-Purpose Responsive WordPress Theme
Version: 1.0
Tags: one-column, two-columns, three-columns, four-columns, left-sidebar, right-sidebar, custom-menu, featured-images, flexible-header, post-formats, sticky-post, translation-ready

/* Below you can write your style */
/*Menu*/
/* HEADER centrato cross-browser (Divi) */
#main-header {
  /* dimensioni */
  width: min(90%, 1820px) !important;  /* 90% ma non oltre 1320px, regola a piacere */
  border: 0 !important;
  box-shadow: 1px 1px 29px -2px rgba(79,71,100,0.5) !important;
  border-radius: .5rem !important;

  /* centratura affidabile anche con position:fixed */
  position: fixed;                /* Divi lo imposta comunque, ribadisco */
  left: 50% !important;
  right: auto !important;
  transform: translateX(-50%);
  margin: 0 !important;          /* evita che margin interferisca con il calcolo */
}

/* Variante quando Divi aggiunge la classe sticky/fixed: mantieni la centratura */
#main-header.et-fixed-header {
  left: 50% !important;
  right: auto !important;
  transform: translateX(-50%);
}

/* Mobile toggle colore */
.mobile_menu_bar:before{
  color:#3a73d8 !important;
}

/* Mobile: stessa centratura, puoi anche ridurre la larghezza se serve */
@media (max-width: 980px){
  #main-header{
    width: calc(100% - 20px) !important; /* un po' di respiro ai lati su smartphone */
    /* centratura resta attiva via left/transform */
  }
}

/* (Opzionale) se noti micro-sbandamenti durante lo scroll su iOS */
@supports (-webkit-touch-callout: none) {
  #main-header { will-change: transform; }
}

.et_fixed_nav #main-header {
    position: absolute!important;
}
.et_mobile_menu{
	border-top: 3px solid #3a73d8;
}
/*------------------------------------------------*/
#top-menu-nav li.voce-contatti a{
	color: #FFFFFF!important;
    border-width: 1.5px!important;
    border-radius: .5rem .2rem .2rem .2rem;
    background-color: #3A73D8;
	border:solid 1px #3A73D8;
}
#top-menu-nav li.voce-contatti a:hover{
    background-color: #4F4764;
	border:solid 1px #4F4764;
	opacity:1!important;
}

.et_header_style_left #et-top-navigation nav>ul>li.voce-contatti>a{
	padding:10px 20px!important;
}

/*------------------------------------------------*/
/*Bottoni*/
.et_pb_button{
	border-top-left-radius:.5rem!important;
	border-top-right-radius:.2rem!important;
	border-bottom-right-radius:.2rem!important;
	border-bottom-left-radius:.2rem!important;
	font-size:24px!important;
}
/*Form*/
@media screen and (min-width: 981px) {
.row-one-half {
	display: flex!important;
    flex-direction: row!important;
    column-gap: 20px!important;
}
.row-one-half div{
	max-width:100%!important;
	width:50%!important;
	}
}
/*HOME*/
.riga {
  background-color: #ffffff; /* colore di sfondo iniziale */
  transition: all 0.5s ease; /* animazione morbida */
}
.riga:hover {
  background-color: #3a73d8; /* colore di sfondo al passaggio del mouse */
  color: #ffffff; /* colore testo al passaggio del mouse */
}
.riga:hover * {
  color: #ffffff !important;
}
.servizi-home .dipl_horizontal_scrolling_card_item_0 .dipl_horizontal_scrolling_card_inner:before{
	background-color:#3a73d8!important;
}
.servizi-home h4{
	margin-bottom:25px!important;
}
/*Bando*/
/* Griglia bottoni: 2 colonne su schermi grandi, 1 colonna su mobile */
.iw-bando-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px; /* spaziatura tra i bottoni */
}

/* Mobile: i bottoni vanno uno sotto l'altro */
@media (max-width: 767px) {
    .iw-bando-grid {
        grid-template-columns: 1fr;
    }
}

/* Stile pulsanti aggiornato */
.iw-bando-btn {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    padding: .6rem 1rem;
    text-decoration: none;
    border: none;
    border-top-left-radius: .5rem;
    border-top-right-radius: .2rem;
    border-bottom-right-radius: .2rem;
    border-bottom-left-radius: .2rem;
    font-size: 22px;
    color: #3A73D8 !important;
    background-color: #fff !important;
    line-height: 1.2;
    transition: all 0.3s ease;
    width: 100%;
    box-sizing: border-box;
}
@media screen and (max-width:980px){
	.iw-bando-btn {
    font-size: 16px;
	}
}

/* Icona Divi a destra */
.iw-bando-btn::after {
    content: "\e03e";
    font-family: "ETmodules" !important; /* icone Divi */
    speak: none;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    transition: all 0.5s ease; /* animazione morbida */
}

/* Hover: inversione colori */
.iw-bando-btn:hover {
    background-color: #3c364c !important;
    color: #fff !important;
}
.iw-stato-prefix {
    margin-right: .25rem;
}

.iw-stato-attivo {
    font-weight: 600;
    background-color: #6CD247;
	color:#fff;
	padding: 0.2rem .8rem;
	border-top-left-radius: .5rem;
    border-top-right-radius: .2rem;
    border-bottom-right-radius: .2rem;
    border-bottom-left-radius: .2rem;
}

.iw-stato-inattivo {
    font-weight: 600;
    /* personalizza come vuoi: */
    color: #B00020; /* rosso esempio */
}

/*SERVIZI*/
.btn-bandi-all{
	font-size:18px!important;
}
/* Lista articoli con bordo divisorio */
.iw-ac-list {
    list-style: none;
    margin: 0;
    padding: 0;
    border-top: 1px dashed #dbdde3;
}
.iw-ac-item {
    border-bottom: 1px dashed #dbdde3;
}

/* Riga cliccabile: titolo a sinistra, stato+icona a destra */
.iw-ac-link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 14px 12px;
    text-decoration: none;
    color: inherit;
    transition: all 0.5s ease; /* animazione morbida */
}
.iw-ac-link:hover {
    background-color: #3a73d8;
}
.iw-ac-link:hover *{
    color: #fff;
}
@media screen and (max-width:980px){
	.iw-ac-link {
    gap: 15px;
	}
}
/* Titolo a sinistra */
.iw-ac-title {
    font-size: 24px;
    font-weight: 600;
    text-align: left;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Colonna destra: stato + icona */
.iw-ac-right {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

/* Icona Divi */
.iw-ac-icon::before {
    content: "\e03e";
    font-family: "ETmodules" !important;
    font-style: normal;
    font-weight: normal;
    line-height: 1;
    display: inline-block;
	font-size:24px
}

/* Stati */
.iw-ac-stato {
    font-weight: 600;
    font-size: 14px;
}
.iw-stato-attivo {
    color: #fff; /* verde */
}
.iw-stato-inattivo {
    color: #B00020; /* rosso */
}

/* Mobile */
@media (max-width: 767px) {
    .iw-ac-link {
        padding: 12px 10px;
        flex-direction: column;
        align-items: flex-start;
        gap: 6px;
    }
    .iw-ac-right {
        align-self: flex-end;
    }
}
/*--------------------------------------*/

/* ========== DESKTOP MEGA ========== */
#iw-mega-servizi{
	max-width:90%!important;
	margin:auto!important;
	border-radius: 0 0 .5rem .5rem!important;
}
.iw-mega {
    position: absolute;
    left: 0; right: 0; top: 0;
    transform: translateY(-10px);
    opacity: 0; visibility: hidden; pointer-events: none;
    background: #fff;
    box-shadow: 0 20px 40px rgba(0,0,0,.08);
    transition: opacity .18s ease, transform .18s ease, visibility .18s ease;
	box-shadow: 1px 25px 29px -2px rgba(79,71,100,0.5)!important;
    z-index: 9999;
}
.iw-mega.is-open { opacity: 1; transform: translateY(0); visibility: visible; pointer-events: auto; }

.iw-mega__inner {
    max-width: 1320px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 32px;
    padding: 32px 20px;
}
.iw-mega__list { list-style: none; margin: 0; padding: 0; }
.iw-mega__item + .iw-mega__item { border-top: 1px dashed #dbdde3; }
.iw-mega__link {
    display: block;
    padding: 25px 6px;
    text-decoration: none;
    color: #3c364c;
    font-weight: 600;
    transition: color .15s ease, background-color .15s ease;
}
.iw-mega__link:hover,
.iw-mega__link:focus {
	color: #fff;
	background: #3A73D8;
	border-radius: .5rem .2rem .2rem .2rem;
}

.iw-mega__right { display: grid; align-items: center; justify-items: center; }
.iw-mega__image-wrap {
    width: 100%; aspect-ratio: 4/3;
    background: #f3f4f6; border-radius: 12px; overflow: hidden;
    display: grid; place-items: center;
}
.iw-mega__image-wrap img{
	object-fit:cover!important;
	height:600px;
}
.iw-mega__image { max-width: 100%; max-height: 100%; display: block; opacity: 0; transition: opacity .2s ease; }
.iw-mega__image.is-ready { opacity: 1; }
.iw-mega__title{
	font-size:1.8em;
	padding-left:25px;
}

/* NASCONDI IL SUBMENU NATIVO SOLO PER LA VOCE CON CLASSE .mega-servizi */
li.mega-servizi > .sub-menu,
.menu-item.mega-servizi > .sub-menu,
.et_pb_menu .et-menu > li.mega-servizi > .sub-menu,
.et_pb_fullwidth_menu .et-menu > li.mega-servizi > .sub-menu {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

/* RIMUOVI FRECCIA/ARROW MOBILE DI DIVI SOLO SU QUELLA VOCE */
.et_mobile_menu .menu-item.mega-servizi > a .menu-toggle,
.et_mobile_menu .menu-item.mega-servizi > a .et_mobile_menu_arrow,
.et_pb_menu .et-menu .menu-item.mega-servizi > a .et_mobile_menu_arrow {
  display: none !important;
}

/* ========== MOBILE PANEL ========== */
.iw-mega-m {
    position: fixed; inset: 0;
    background: #fff;
    transform: translateX(100%);
    transition: transform .25s ease;
    z-index: 10000;
    visibility: hidden;
}
.iw-mega-m.is-open { transform: translateX(0); visibility: visible; }

.iw-mega-m__inner { padding: 18px 16px 24px; height: 100%; display: flex; flex-direction: column; }
.iw-mega-m__back {
    appearance: none; border: 0; background: transparent; display: inline-flex; align-items: center; gap: 8px;
    font-weight: 700; font-size: 16px; padding: 8px 0; cursor: pointer; color: #3c364c;
}
.iw-mega-m__back-icon::before {
    content: "\e03b"; /* icona Divi - freccia indietro */
    font-family: "ETmodules" !important;
    font-style: normal; font-weight: normal; line-height: 1;
    display: inline-block;
}

.iw-mega-m__list { list-style: none; margin: 12px 0 0; padding: 0; }
.iw-mega-m__item + .iw-mega-m__item { border-top: 1px solid #eee; }
.iw-mega-m__link {
    display: block; padding: 14px 4px; text-decoration: none;
    color: #3c364c; font-weight: 600;
}
.iw-mega-m__link:active { background: #f7f7f9; }

/* ========== RESPONSIVE BEHAVIOR ========== */
@media (max-width: 980px) {
    /* Nascondi pannello desktop sotto 980px */
    .iw-mega { display: none; }
}
@media (min-width: 981px) {
    /* Assicura che il pannello mobile resti fuori su desktop */
    .iw-mega-m { display: none; }
}
/* Nascondi DAVVERO il submenu mobile nativo sotto "I nostri servizi" e azzera lo spazio */
.et_mobile_menu .menu-item.mega-servizi > ul.sub-menu {
  display: none !important;
  height: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  overflow: hidden !important;
  visibility: hidden !important;
  opacity: 0 !important;
}

/* Evita che Divi segni l'item come "aperto" con margini/padding extra */
.et_mobile_menu .menu-item.mega-servizi.opened > ul.sub-menu {
  display: none !important;
}

/* Nascondi la freccia toggle solo per questa voce */
.et_mobile_menu .menu-item.mega-servizi > a .et_mobile_menu_arrow {
  display: none !important;
}
/* Pannello mobile: assicurati che sia sopra al menu mobile di Divi */
.iw-mega-m {
  position: fixed;        /* già così, ribadisco */
  inset: 0;
  z-index: 2147483647 !important; /* MAX per sovrastare ogni overlay di Divi */
}

/* Nascondi davvero il submenu nativo sotto "I nostri servizi" su mobile */
.et_mobile_menu .menu-item.mega-servizi > ul.sub-menu {
  display: none !important;
  height: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  overflow: hidden !important;
  visibility: hidden !important;
  opacity: 0 !important;
}

/* Evita che Divi mostri il toggle/freccia su quella voce */
.et_mobile_menu .menu-item.mega-servizi > a .et_mobile_menu_arrow,
.et_mobile_menu .menu-item.mega-servizi > a .menu-toggle {
  display: none !important;
}
/* === MENU MOBILE FULLSCREEN CUSTOM === */
.iw-menu-m {
  position: fixed;
  inset: 0;
  background: #fff;
  transform: translateX(100%);
  transition: transform .3s ease;
  z-index: 2147483647 !important;
  visibility: hidden;
}

.iw-menu-m.is-open {
  transform: translateX(0);
  visibility: visible;
}

.iw-menu-m__inner {
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: 18px 20px 40px;
}

/* Bottone chiudi */
.iw-menu-m__close {
  appearance: none;
  border: 0;
  background: transparent;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 700;
  font-size: 16px;
  padding: 8px 0;
  cursor: pointer;
  color: #3c364c;
}
.iw-menu-m__close-icon::before {
  content: "\e03b"; /* icona Divi freccia sinistra */
  font-family: "ETmodules" !important;
  display: inline-block;
  font-style: normal;
  font-weight: normal;
  line-height: 1;
}

/* Lista */
.iw-menu-m__list {
  list-style: none;
  margin: 20px 0 0;
  padding: 0;
  flex: 1;
  overflow-y: auto;
}
.iw-menu-m__item + .iw-menu-m__item {
  border-top: 1px solid #eee;
}
.iw-menu-m__link {
  display: block;
  padding: 16px 4px;
  text-decoration: none;
  color: #3c364c;
  font-weight: 600;
}
.iw-menu-m__link:active {
  background: #f7f7f9;
}
body.iw-menu-open .et_mobile_menu {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
}
