/* ================================
   Il Moro della Molpa — THE HABIR
   Custom Theme CSS (drop-in)
   ================================ */

/* ========= PALETTE & TOKENS ========= */
:root{
  --clr-primary:   #edebe5;
  --clr-secondary: #3d3d3d; /* Bordeaux intenso */
  --clr-accent:    #C7A869; /* Oro/Beige */
  --clr-support:   #9A5A3C; /* Terracotta */
  --clr-bg:        #FAF6ED; /* Panna/Champagne */
  --clr-text:      #1C1C1C; /* Testo principale */

  --neutral-100: #ffffff;
  --neutral-200: #f4f4f4;
  --neutral-300: #e8e8e8;
  --neutral-700: #444444;
  --neutral-900: #111111;

  --success: #2E7D32;
  --warning: #B26A00;
  --error:   #C62828;
  --info:    #1565C0;

  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 16px;

  --shadow-1: 0 2px 10px rgba(0,0,0,.06);
  --shadow-2: 0 8px 24px rgba(0,0,0,.10);
}

/* ========= BASE ========= */
html, body{
  background: var(--clr-bg);
  color: var(--clr-text);
  line-height: 1.6;
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
body{
  font-family: "Source Sans Pro", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}
h1,h2,h3,h4{
  color: var(--clr-secondary); 
  letter-spacing: .2px;
  font-family: "Merriweather", Georgia, "Times New Roman", serif;
  margin-top: 0;
}
a{
  color: var(--clr-primary);
  text-decoration-color: rgba(13,81,52,.4);
}
a:hover, a:focus{
  color: #0a3e28; /* darken primary */
  text-decoration-color: rgba(13,81,52,.7);
}

/* Container padding più armonico */
.container, .container-fluid{
  padding-left: 1rem;
  padding-right: 1rem;
}

/* ========= HEADER / NAVBAR ========= */
.header, .navbar, .site-header, .t4-header, .sp-header{
  background: var(--clr-primary);
  color: #fff;
}
.header a, .navbar a, .site-header a{ color: #fff; }
.navbar .navbar-nav > li > a{
  padding: .8rem 1rem;
}
.navbar .navbar-nav > li > a:hover{
  background: rgba(0,0,0,.06);
}

/* Brand */
.navbar-brand img{ max-height: 60px; }

/* Dropdown */
.navbar .dropdown-menu{
  border-radius: var(--radius-sm);
  border: 1px solid var(--neutral-300);
  box-shadow: var(--shadow-1);
}
.navbar .dropdown-menu .dropdown-item:hover{
  background: #eef3f0; /* mix primario con bianco (soft) */
}

/* Topbar (se presente) */
.topbar, .t4-topbar, .sp-topbar{
  background: var(--clr-secondary);
  color: #fff;
}
.topbar a, .t4-topbar a, .sp-topbar a{ color: #fff; }

/* ========= FOOTER ========= */
.site-footer, footer{
  background: #0b452e; /* primary darken ~6% */
  color: #fff;
}
.site-footer a, footer a{
  color: #2b2b2b; /* contrast con accent */
  text-decoration-color: rgba(199,168,105,.4);
}
.site-footer a:hover, footer a:hover{
  color: #111;
  text-decoration-color: rgba(199,168,105,.7);
}

/* ========= CARD / MODULI ========= */
.card, .moduletable, .module, .blog-item, .t4-card{
  background: var(--neutral-100);
  border: 1px solid var(--neutral-300);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-1);
}
.card:hover, .moduletable:hover, .module:hover{ box-shadow: var(--shadow-2); }

/* Titoli modulo / sezione */
.section-title, .module-title, .page-header h1, .pagetitle h1{
  border-left: 6px solid var(--clr-accent);
  padding-left: .75rem;
  margin-bottom: 1rem;
  color: var(--clr-primary);
}

/* ========= BOTTONI ========= */
.btn,
button,
input[type="button"],
input[type="submit"]{
  border-radius: var(--radius-sm);
  border-width: 1px;
  padding: .6rem 1.1rem;
  transition: .2s ease;
  cursor: pointer;
}

/* Primary */
.btn-primary,
a.btn-primary,
button.btn-primary{
  background: var(--clr-primary);
  border-color: var(--clr-primary);
  color: #fff;
}
.btn-primary:hover,
.btn-primary:focus{
  background: #0a3e28; /* darken primary */
  border-color: #08331f;
  color: #fff;
}

/* Secondary */
.btn-secondary,
a.btn-secondary{
  background: var(--clr-secondary);
  border-color: var(--clr-secondary);
  color: #fff;
}
.btn-secondary:hover,
.btn-secondary:focus{
  background: #6e1a1f; /* darken secondary */
  border-color: #5b151a;
  color: #fff;
}

/* Accent */
.btn-accent, a.btn-accent{
  background: var(--clr-accent);
  border-color: #ae9156; /* accent darken ~8% */
  color: #111;
}
.btn-accent:hover, .btn-accent:focus{
  background: #b9965b; /* darken ~6% */
  border-color: #997f4c;
  color: #111;
}

/* Outline primary */
.btn-outline-primary, a.btn-outline-primary{
  background: transparent;
  border: 1px solid var(--clr-primary);
  color: var(--clr-primary);
}
.btn-outline-primary:hover{
  background: var(--clr-primary);
  color: #fff;
}

/* Readmore Joomla */
.readmore a, a.readmore{
  border-radius: 999px;
  background: transparent;
  border: 1px solid var(--clr-primary);
  color: var(--clr-primary);
  padding: .45rem 1rem;
  text-decoration: none;
}
.readmore a:hover, a.readmore:hover{
  background: var(--clr-primary);
  color: #fff;
}

/* ========= FORM ========= */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="url"],
input[type="tel"],
select, textarea{
  border-radius: var(--radius-sm);
  border: 1px solid var(--neutral-300);
  background: #fff;
  padding: .55rem .7rem;
  width: 100%;
}
input:focus, select:focus, textarea:focus{
  border-color: var(--clr-primary);
  box-shadow: 0 0 0 3px rgba(13,81,52,.15);
  outline: 0;
}

/* ========= ALERT ========= */
.alert-success{
  background: #eaf3eb; border-color: var(--success); color: #144d15;
}
.alert-warning{
  background: #f7efdf; border-color: var(--warning); color: #5a3c00;
}
.alert-danger{
  background: #f7e7e8; border-color: var(--error); color: #6a0f13;
}
.alert-info{
  background: #e7effa; border-color: var(--info); color: #0f407c;
}

/* ========= BREADCRUMB ========= */
.breadcrumb{
  background: transparent;
  padding: .75rem 0;
  margin-bottom: 0;
}
.breadcrumb .active{ color: var(--neutral-700); }
.breadcrumb a{
  color: var(--clr-secondary);
  text-decoration-color: rgba(140,31,40,.4);
}
.breadcrumb a:hover{
  color: #6e1a1f;
  text-decoration-color: rgba(140,31,40,.7);
}

/* ========= PAGINAZIONE ========= */
.pagination .page-link{
  color: var(--clr-primary);
  border-radius: var(--radius-sm) !important;
}
.pagination .active .page-link,
.pagination .page-link:hover{
  background: var(--clr-primary);
  color: #fff;
  border-color: var(--clr-primary);
}

/* ========= AcyMailing (modulo newsletter) ========= */
.acym_module, .acym_form{
  background: var(--neutral-100);
  border: 1px solid var(--neutral-300);
  border-radius: var(--radius-md);
  padding: 1.5rem;
}
.acym_form .subbutton.btn{ background: var(--clr-primary); border-color: var(--clr-primary); color:#fff; }
.acym_form .subbutton.btn:hover{ background: #0a3e28; }
.acym_form .unsubbutton.btn{ background: var(--clr-secondary); border-color: var(--clr-secondary); color:#fff; }
.acym_form .unsubbutton.btn:hover{ background: #6e1a1f; }

/* ========= Badge / Accenti Oro ========= */
.badge-accent{
  background: var(--clr-accent);
  color: #111;
  border-radius: 999px;
  padding: .35rem .6rem;
  font-weight: 600;
}

/* ========= Migliorie accessibilità ========= */
a:focus-visible,
button:focus-visible,
[role="button"]:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible{
  outline: 3px solid rgba(13,81,52,.45);
  outline-offset: 2px;
}

/* ========= Variante “Dark Accent” opzionale =========
   Aggiungi la classe .theme-dark al <body> per attivare.
*/
body.theme-dark{
  background: #141615;
  color: #e9e9e9;
}
body.theme-dark .header,
body.theme-dark .navbar,
body.theme-dark .site-header{ background: #0b2f21; color:#fff; }
body.theme-dark .site-footer, 
body.theme-dark footer{ background: #0a261b; color:#fff; }
body.theme-dark .card, 
body.theme-dark .moduletable, 
body.theme-dark .module{
  background: #1c1e1d; border-color: #2a2c2b;
}
body.theme-dark a{ color: #d7c28c; } /* accent lightened */
body.theme-dark a:hover{ color: #ead7a2; }


/* --- Aumenta altezza header + navbar nel T4 Habir --- */

/* Wrapper del logo + menu */
.t4-header, 
.t4-header .header-main {
    padding-top: 0px !important;
    padding-bottom: 0px !important;
    min-height: 100px !important; /* aumenta questo valore */
}

/* Menu principale */
.t4-navbar,
.t4-navbar .navbar,
.navbar {
    min-height: 80px !important;
    padding-top: 5px !important;
    padding-bottom: 5px !important;
}

/* Logo */
.t4-header .navbar-brand img {
    max-height: 80px !important;   /* aumenta se vuoi logo più grande */
}


/* 1) Imposta qui il colore che vuoi per TUTTA la barra sopra la slide iniziale */
:root {
  --header-bg: #edebe5; /* ← CAMBIA QUI il tuo colore */
  --header-text: #ffffff;
}


/* 2) Blocchi principali dell'header */
.header-block.header-block-2,
.header-block.header-block-2 .container-xxl,
.header-block.header-block-2 .header-wrap {
  background: var(--header-bg) !important;
}

.t4-subslider-0
 ,.t4-main-body {
	background: var(--header-bg) !important;
}

/* 3) Logo + menu + colonna destra */
.header-block .navbar-brand,
.header-block .t4-navbar,
.header-block .t4-navbar .navbar,
.header-block .t4-header-r {
  background: var(--header-bg) !important;
}

/* 4) Testi e link nell'header (colore chiaro) */
.header-block.header-block-2,
.header-block.header-block-2 a,
.header-block.header-block-2 .nav-link,
.header-block.header-block-2 .navbar-nav > li > a,
.header-block .t4-header-r .btn,
.header-block .t4-header-r .c-button {
  
}

/* 5) Rimuove bordi/ombre che “staccano” lo sfondo */
.header-block.header-block-2,
.header-block .t4-navbar .navbar {
  border: 0 !important;
  box-shadow: none !important;
}

/* 6) Spaziatura (facoltativo, lascia così se ti piace l'altezza attuale) */
.header-block.header-block-2 { padding: 1px 0 !important; }
.header-block .header-wrap { padding: 10px 0 !important; }

/* 7) Hover delle voci menu: mantieni tono coerente (leggero scurimento) */
.header-block .navbar-nav > li > a:hover,
.header-block .navbar-nav > li > a:focus {
  background: rgba(0,0,0,0.08) !important; /* patina leggera sullo stesso bg */
  
}

/* 8) Dropdown: due opzioni (scegline UNA)
   — A) dropdown con lo stesso sfondo uniforme dell'header: */
.header-block .t4-megamenu .dropdown-menu {
  background: var(--header-bg) !important;
  border: 0 !important;
  box-shadow: none !important;
}
.header-block .t4-megamenu .dropdown-item {
  
}
.header-block .t4-megamenu .dropdown-item:hover {
  background: rgba(0,0,0,0.08) !important;
  
}

/*   — B) (ALTERNATIVA) dropdown chiaro che si stacca (commenta A e usa questa)
.header-block .t4-megamenu .dropdown-menu {
  background: #ffffff !important;
  border: 1px solid rgba(255,255,255,0.15) !important;
  box-shadow: 0 8px 24px rgba(0,0,0,.12) !important;
}
.header-block .t4-megamenu .dropdown-item { color: #1c1c1c !important; }
.header-block .t4-megamenu .dropdown-item:hover {
  background: rgba(0,0,0,.04) !important; color: #0D5134 !important;
}
*/

/* 9) Burger/off-canvas trigger */
.header-block #triggerButton,
.header-block .t4-offcanvas-toggle {
  background: transparent !important;
  
}

/* 10) Pulsante “Donate Now” dentro l’header: bordo e hover armonizzati */
.header-block .t4-header-r .btn.btn-primary {
  border-color: rgba(255,255,255,0.85) !important;
  background: rgba(255,255,255,0.12) !important;
  
}
.header-block .t4-header-r .btn.btn-primary:hover {
  background: rgba(255,255,255,0.22) !important;
}

/* 11) Immagini logo: nessuno sfondo, trasparenza sullo stesso colore */
.header-block .navbar-brand img { background: transparent !important; }



/* ================================
   Sposta "Donate Now" accanto al logo che poi diventa richiedi un preventivo
   ================================ */

/* 1) La struttura header usa flex: cambio l'ordine dei blocchi */
.header-wrap {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
}

/* 2) Logo (navbar-brand) deve restare primo */
.header-wrap .navbar-brand {
    order: 1;
}

/* 3) Pulsante Donate Now deve venire subito dopo il logo */
.header-wrap .t4-header-r {
    order: 2;
    margin-left: 20px; /* distanza dal logo */
}

/* 4) Il menu deve venir dopo Donate */
.header-wrap .t4-navbar {
    order: 3;
}

/* 5) Centra verticalmente Donate */
.t4-header-r .custom {
    display: flex;
    align-items: center;
}

/* 6) (Opzionale) nascondi il burger mobile quando non serve */
.t4-header-r .t4-offcanvas-toggle {
    margin-left: 12px;
}
.bottonecustomrichiedipreventivo {
    /* proprietà equivalenti a btn btn-primary dark */
    color: var(--color-dark);
    font-weight: bold;

    /* proprietà ereditarie dai .btn */
    transition: all 0.3s linear 0s;
    border-radius: 0px;
    line-height: 1.5;
    position: relative;
    padding: .375rem .75rem;
    border: 1px solid transparent;

    /* colore di sfondo primario (puoi adattarlo se necessario) */
    background-color: var(--color-primary);
    border-color: var(--color-primary);
}

/* Hover / Focus come l’originale */
.bottonecustomrichiedipreventivo:hover,
.bottonecustomrichiedipreventivo:focus {
    background-color: var(--color-primary-dark);
    border-color: var(--color-primary-dark);
    color: #fff;
}

/* comportamento specifico del dark: cambio colore testo */
.bottonecustomrichiedipreventivo:hover {
    color: var(--color-white);
}


#sidepanel-styling157,
.sidepanel-styling157,
.t4-style-switcher,
.t4-style-switcher-toggle,
.t4-style-switcher-btn {
    display: none !important;
}
/* 1) Rende il limitatore la cornice di posizionamento */
#n2-ss-5 .n2-ss-slide .n2-ss-slide-limiter {
  position: relative !important;               /* il riferimento per l'assoluto */
}

/* 2) Popup centrato in basso dentro il limitatore */
#n2-ss-5 .n2-ss-slide .n2-ss-slide-limiter .POPUP_SLIDE_HOME {
  position: absolute !important;
  left: 50% !important;
  top: 150px !important;                      /* regola la distanza dal fondo */
  transform: translateX(-50%) !important;       /* centratura perfetta */
  z-index: 99999 !important;
  max-width: 92vw;                               /* sicurezza su mobile */
  box-sizing: border-box;
}
.POPUP_SLIDE_HOME_TESTO  
 {
	margin-top:30px !important;
}

/* --- IMMAGINE A SINISTRA SU DESKTOP --- */
.img-left {
    float: left;
    margin: 5px 20px 15px 0;
    max-width: 40%;            /* occupa max 40% della larghezza */
    height: auto;
}

/* Permette al testo di fluire di fianco all'immagine */
.request-quota-earendel > div {
    overflow: hidden;          /* IMPORTANTISSIMO */
}

/* --- VERSIONE MOBILE --- */
@media (max-width: 768px) {
    .img-left {
        float: none;           /* niente float su mobile */
        display: block;
        margin: 0 auto 20px auto;
        max-width: 100%;       /* immagine full width */
    }

    .request-quota-earendel > div {
        overflow: visible;     /* evita tagli su mobile */
    }
}

#mod-sp-simpleportfolio {
	background: var(--header-bg) !important;
}


/**********************************************************
 * 1) PORTFOLIO (SP Simple Portfolio) — come definito prima
 **********************************************************/
.sp-simpleportfolio .sp-simpleportfolio-item { text-align: center; }

.sp-simpleportfolio .sp-simpleportfolio-item .sp-simpleportfolio-title,
.sp-simpleportfolio .sp-simpleportfolio-item h3.sp-simpleportfolio-title,
.sp-simpleportfolio .sp-simpleportfolio-item .item-title,
.sp-simpleportfolio .sp-simpleportfolio-item .portfolio-title {
  margin: 12px 0 6px;
  font-family: "Open Sans", system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, sans-serif;
  font-weight: 700;
  font-size: clamp(18px, 2vw, 22px);
  line-height: 1.25;
  letter-spacing: 0.2px;
  text-align: center;
  color: #0d0d0d;
}
.sp-simpleportfolio .sp-simpleportfolio-item .sp-simpleportfolio-title a.active {
  color: #4a4a4a !important;

  text-decoration: none;
  transition: color .2s ease, text-shadow .2s ease;
}
.sp-simpleportfolio .sp-simpleportfolio-item .sp-simpleportfolio-title a:hover,
.sp-simpleportfolio .sp-simpleportfolio-item .sp-simpleportfolio-title a:focus {
  color: var(--body-link-color) !important;
  text-shadow: 0 1px 0 rgba(0,0,0,.04);
}
.sp-simpleportfolio .sp-simpleportfolio-item .sp-simpleportfolio-description,
.sp-simpleportfolio .sp-simpleportfolio-item .entry-summary,
.sp-simpleportfolio .sp-simpleportfolio-item .portfolio-desc,
.sp-simpleportfolio .sp-simpleportfolio-item p {
  margin: 0 auto;
  max-width: 52ch;
  font-family: "Open Sans", system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, sans-serif;
  font-weight: 400;
  font-size: clamp(14px, 1.6vw, 16px);
  line-height: 1.62;
  color: #4a4a4a;
  text-align: center;
  opacity: .95;
}
.sp-simpleportfolio .sp-simpleportfolio-item .sp-simpleportfolio-img { display:block; margin:0 auto; border-radius:8px; overflow:hidden; }
.sp-simpleportfolio .sp-simpleportfolio-item .sp-simpleportfolio-img img {
  display:block; width:100%; height:auto; transition: transform .35s ease, filter .35s ease;
}
.sp-simpleportfolio .sp-simpleportfolio-item:hover .sp-simpleportfolio-img img {
  transform: translateY(-2px) scale(1.01); filter: saturate(1.04);
}
.sp-simpleportfolio .sp-simpleportfolio-item .sp-simpleportfolio-overlay {
  background: linear-gradient(180deg, rgba(0,0,0,.0) 40%, rgba(0,0,0,.35) 100%);
}
@media (max-width: 900px) {
  .sp-simpleportfolio .sp-simpleportfolio-item .sp-simpleportfolio-title { margin-top: 10px; }
  .sp-simpleportfolio .sp-simpleportfolio-item .sp-simpleportfolio-description { max-width: 60ch; font-size: 15px; }
}
.sp-simpleportfolio .sp-simpleportfolio-item .sp-simpleportfolio-title a:focus-visible {
  outline: 2px solid #1890d7; outline-offset: 2px; border-radius: 4px;
}
/* Accento decorativo opzionale */
.sp-simpleportfolio .sp-simpleportfolio-item .sp-simpleportfolio-title { position: relative; }
.sp-simpleportfolio .sp-simpleportfolio-item .sp-simpleportfolio-title::after {
  content: ""; display: block; width: 56px; height: 2px; margin: 10px auto 0; background: #9A5A3C; opacity: .85;
}

/**********************************************************
 * 2) CARDS (Bootstrap 5 + Habir) — titoli centrati & testo elegante
 **********************************************************/

/* Contenitore card: aspetto premium ma leggero */
.card {
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 12px;
  overflow: hidden;
  background-color: #fff;
  box-shadow: 0 2px 10px rgba(0,0,0,.04);
  transition: box-shadow .25s ease, transform .25s ease, border-color .25s ease;
}

/* Hover micro-interazione */
.card:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 22px rgba(0,0,0,.09);
  border-color: rgba(24,144,215,.25); /* #1890d7 con trasparenza */
}

/* Immagini card: riempiono in modo elegante */
.card-img, .card-img-top, .card > img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
}

/* Body della card: spaziature coerenti */
.card-body {
  padding: 18px 18px 20px;
  text-align: center; /* centratura di default per titoli e testi */
}

/* Titolo della card */
.card-title, .card .item-title, .card h3, .card h4 {
  margin: 8px 0 6px;
  font-family: "Open Sans", system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, sans-serif;
  font-weight: 700;
  font-size: clamp(18px, 2vw, 22px);
  line-height: 1.25;
  letter-spacing: 0.2px;
  color: #0d0d0d;
  text-align: center;
}

/* Link nel titolo: elegante + transizione */
.card-title a, .card .item-title a, .card h3 a, .card h4 a {
  color: inherit;
  text-decoration: none;
  transition: color .2s ease, text-shadow .2s ease;
}
.card-title a:hover, .card .item-title a:hover, .card h3 a:hover, .card h4 a:hover,
.card-title a:focus, .card .item-title a:focus, .card h3 a:focus, .card h4 a:focus {
  color: #1890d7;
  text-shadow: 0 1px 0 rgba(0,0,0,.04);
}

/* Testo descrittivo della card */
.card-text, .card .entry-summary, .card p {
  margin: 0 auto;
  max-width: 60ch;
  font-family: "Open Sans", system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, sans-serif;
  font-weight: 400;
  font-size: clamp(14px, 1.6vw, 16px);
  line-height: 1.62;
  color: #4a4a4a;
  text-align: center;
  opacity: .95;
}

/* Pulsanti nella card: allineamento e look */
.card .btn, .card .btn-primary, .card .readmore, .card a.readmore {
  margin-top: 12px;
  border-radius: 8px;
  padding: 10px 16px;
  font-weight: 600;
}
.card .btn-primary, .card .readmore, .card a.readmore {
  background-color: #1890d7;
  border-color: #1890d7;
}
.card .btn-primary:hover, .card .readmore:hover, .card a.readmore:hover {
  filter: brightness(1.05);
}

/* Header/footer della card (se presenti): coerenza tipografica */
.card-header, .card-footer {
  background: #fff;
  border-color: rgba(0,0,0,.06);
}

/* Accessibilità focus: titoli e bottoni con focus visibile */
.card-title a:focus-visible, .card .item-title a:focus-visible, .card h3 a:focus-visible, .card h4 a:focus-visible,
.card .btn:focus-visible {
  outline: 2px solid #1890d7;
  outline-offset: 2px;
  border-radius: 6px;
}

/* Cards su sfondo scuro (se usi temi Dark del template) */
body.dark-mode .card,
.t4-body.dark .card {
  background: #111; border-color: rgba(255,255,255,.08);
  box-shadow: 0 2px 12px rgba(0,0,0,.5);
}
body.dark-mode .card-title,
.t4-body.dark .card-title { color: #f2f2f2; }
body.dark-mode .card-text,
.t4-body.dark .card-text { color: #cfcfcf; opacity: .95; }


/* ====== CARDS: variante "Accent Serif" per i testi ====== */
.card-text,
.card .entry-summary,
.card p {
  font-family: Georgia, "Times New Roman", Times, serif;
  font-size: clamp(16.5px, 1.8vw, 19px); /* un filo più grande della sans */
  line-height: 1.75;
  letter-spacing: 0.05px;
  color: #353535;
}

/* In dark mode, un contrasto leggermente più soft */
body.dark-mode .card-text,
.t4-body.dark .card-text,
body.dark-mode .card p,
.t4-body.dark .card p {
  color: #e0e0e0;
}

.sp-simpleportfolio-tags, .sp-simpleportfolio-info {
		background: var(--header-bg) !important;
}
.sp-simpleportfolio-tags {	
font-family: Georgia, "Times New Roman", Times, serif;
  font-size: var(--megamenu-font-size) !important;
  line-height: 1.05;
  letter-spacing: 0.05px;
  color: #353535;
  

}
.sp-simpleportfolio .sp-simpleportfolio-item.active .sp-simpleportfolio-title a {
  color: var(--neutral-700) !important;
}
#t4-footer > div > div > div
 {
	width:100%!important;
}

#redim-cookiehint-bottom , #redim-cookiehint {
	background: var(--header-bg) !important;
}
/* ============================================
   CookieHint – Pulsanti come "Richiedi preventivo"
   Testo nero + stesso sfondo dei bottoni primari
   ============================================ */

/* Stato normale */
#cookiehintsubmit,
#cookiehintsubmitno {
  /* Sfondo: usa variabili del template con fallback al tema */
  background-color: var(--color-primary, var(--clr-primary)) !important;
  border-color:     var(--color-primary, var(--clr-primary)) !important;

  /* Testo nero */
  color: #000 !important;

  /* Coerenza con il tuo bottone custom */
  font-weight: bold;
  line-height: 1.5;
  padding: .375rem .75rem;
  border: 1px solid transparent;
  border-radius: 0;           /* come .bottonecustomrichiedipreventivo */
  transition: all .3s linear;
}

/* Hover / Focus: stesso darkening del bottone */
#cookiehintsubmit:hover,
#cookiehintsubmit:focus,
#cookiehintsubmitno:hover,
#cookiehintsubmitno:focus {
  background-color: var(--color-primary-dark, #0a3e28) !important; /* fallback al "darken primary" che usi altrove */
  border-color:     var(--color-primary-dark, #08331f) !important;

  /* Restiamo su testo nero? Se preferisci più contrasto: metti #fff */
  color: #000 !important;
}

/* (Opzionale) Stati attivi/focus visibili per accessibilità */
#cookiehintsubmit:focus-visible,
#cookiehintsubmitno:focus-visible {
  outline: 2px solid rgba(0,0,0,.35);
  outline-offset: 2px;
  border-radius: 2px;
}




/**********************************************************
 * Smart Slider 3 — Testi popup Home
 * Heading = stile .sp-simpleportfolio-title (+ linea decorativa)
 * Paragraph = stile .sp-simpleportfolio-tags
 **********************************************************/

/* HEADING: come .sp-simpleportfolio-title */
#n2-ss-5 .POPUP_SLIDE_HOME_TESTO .n2-font-4d157ffb8b2568cb1dd1bf95cc6452da-hover {
  margin: 12px 0 6px !important;
  font-family: "Open Sans", system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, sans-serif !important;
  font-weight: 700 !important;
  font-size: clamp(18px, 2vw, 22px) !important;
  line-height: 1.25 !important;
  letter-spacing: 0.2px !important;
  color: #0d0d0d !important;
  text-align: center !important;
  text-decoration: none !important;
  position: relative !important; /* per la linea decorativa */
}

/* Linea decorativa sotto l’heading (coerente col portfolio) */
#n2-ss-5 .POPUP_SLIDE_HOME_TESTO .n2-font-4d157ffb8b2568cb1dd1bf95cc6452da-hover::after {
  content: "" !important;
  display: block !important;
  width: 56px !important;
  height: 2px !important;
  margin: 10px auto 0 !important;
  background: var(--clr-support, #9A5A3C) !important;
  opacity: .85 !important;
  border-radius: 1px !important;
}

@media (max-width: 480px) {
  #n2-ss-5 .POPUP_SLIDE_HOME_TESTO .n2-font-4d157ffb8b2568cb1dd1bf95cc6452da-hover::after {
    width: 44px !important;
  }
}

/* Hover / focus link nell’heading (come nel portfolio) */
#n2-ss-5 .POPUP_SLIDE_HOME_TESTO .n2-font-4d157ffb8b2568cb1dd1bf95cc6452da-hover a {
  color: inherit !important;
  text-decoration: none !important;
  transition: color .2s ease, text-shadow .2s ease !important;
}
#n2-ss-5 .POPUP_SLIDE_HOME_TESTO .n2-font-4d157ffb8b2568cb1dd1bf95cc6452da-hover a:hover,
#n2-ss-5 .POPUP_SLIDE_HOME_TESTO .n2-font-4d157ffb8b2568cb1dd1bf95cc6452da-hover a:focus {
  color: var(--body-link-color, #1890d7) !important;
  text-shadow: 0 1px 0 rgba(0,0,0,.04) !important;
}

/* PARAGRAPH: come .sp-simpleportfolio-tags */
#n2-ss-5 .POPUP_SLIDE_HOME_TESTO .n2-font-f4e5f6ce8bda5259f2a5afd6dedf31e1-paragraph {
  font-family: Georgia, "Times New Roman", Times, serif !important;
  font-size: var(--megamenu-font-size, 15px) !important;
  line-height: 1.05 !important;
  letter-spacing: 0.05px !important;
  color: #353535 !important;
  text-align: center !important;
}
[itemprop="headline"] {
    font-size: 2rem;
    font-weight: bold;
	color: var(--clr-secondary); 
}

/* Nasconde il <legend> del gruppo di campi nel modulo contatti */
.contact #contact-form fieldset legend {
    display: none !important;
}
.form-control {
     max-width:100% !important;
}

/* Mostra sempre il bottone e allinealo a sinistra */
.bottonecustomrichiedipreventivo {
    display: inline-flex !important;
    justify-content: flex-start !important;
    align-items: center;
    text-align: left !important;
    margin: 0 !important;
    float: left !important;
}

/* Se la colonna di destra dell’header viene nascosta su mobile, riattivala */
@media (max-width: 991.98px) {
    .t4-header .t4-header-r,
    .t4-header .t4-header-r .custom {
        display: block !important;
        text-align: left !important;
    }
}
.logo-image{min-width:0px !important}

/* Stile base: elegante, coerente e sempre a sinistra */
.bottonecustomrichiedipreventivo {
  display: inline-flex !important;
  align-items: center;
  justify-content: flex-start;
  gap: .5rem;                     /* spazio per eventuale icona */
  padding: .65rem 1rem;
  font-weight: 600;
  line-height: 1.2;
  text-decoration: none !important;
  
  
  border-radius: 999px;           /* pill-shaped */
  box-shadow: 0 6px 14px rgba(13, 110, 253, .18), 0 2px 4px rgba(13, 110, 253, .22);
  transition: transform .15s ease, box-shadow .2s ease, background-color .2s ease;
  text-align: left !important;
  margin: 0 !important;
  float: left;                    /* garantisce l’allineamento a sinistra */
}

.bottonecustomrichiedipreventivo:hover,
.bottonecustomrichiedipreventivo:focus {
  background: #0a3e28;
  transform: translateY(-1px);
  box-shadow: 0 10px 20px rgba(13,110,253,.20), 0 3px 8px rgba(13,110,253,.24);
}

/* opzionale: piccola freccia/chevron alla fine */
.bottonecustomrichiedipreventivo::after {
  content: "›";
  font-weight: 700;
  opacity: .9;
}


/* Mobile “più piccolo ed elegante” */
@media (max-width: 575.98px) {
  .bottonecustomrichiedipreventivo {
    font-size: .675rem;           /* ~14px */
    padding: .5rem .875rem;       /* più contenuto */
    border-radius: 999px;
    box-shadow: 0 4px 10px rgba(13,110,253,.14), 0 1px 3px rgba(13,110,253,.18);
    letter-spacing: .1px;         /* tocco elegante */
  }

  /* se l’header destro viene nascosto dal template su mobile, lo riattiviamo */
  .t4-header .t4-header-r,
  .t4-header .t4-header-r .custom {
    display: block !important;
    text-align: left !important;
  }
}


