/* Scoped: tutto dentro #itera-fn-footer */
#itera-fn-footer{ padding: 28px 18px; }
#itera-fn-footer .itera-nl-section{ max-width: var(--itera-maxw); margin: 0 auto 22px auto; }

#itera-fn-footer .itera-nl-card{
  display: grid;
  grid-template-columns: 72px 1fr auto;
  gap: 14px;
  align-items: center;
  background: #fff;
  border-radius: 18px;
  box-shadow: 0 10px 26px rgba(0,0,0,.06);
  padding: 18px 18px;
}

#itera-fn-footer .itera-nl-logo{ width: 64px; height: 64px; object-fit: contain; }
#itera-fn-footer .itera-nl-title{ font-weight: 700; color:#0f1b1c; font-size: 16px; line-height: 1.2; }
#itera-fn-footer .itera-nl-subtitle{ color: rgba(15,27,28,.65); font-size: 13px; margin-top: 3px; }

/* ===========================
   NEWSLETTER FORM – STACK (DESKTOP + MOBILE)
   =========================== */
#itera-fn-footer .itera-nl-form{
  display:flex;
  flex-direction: column;     /* <<< uno sopra l’altro anche su desktop */
  gap: 12px;
  align-items: stretch;
  justify-content: flex-start;
}

/* base input: SUPER specifico per vincere contro Astra/global */
#itera-fn-footer .itera-nl-form input.itera-nl-input,
#itera-fn-footer .itera-nl-form input[type="text"].itera-nl-input,
#itera-fn-footer .itera-nl-form input[type="email"].itera-nl-input{
  box-sizing: border-box !important;

  width: 100% !important;
  max-width: 830px !important;   /* armonico su desktop */
  margin: 0 auto !important;     /* centrato nella colonna */

  height: 44px !important;
  min-height: 44px !important;
  line-height: 44px !important;

  border-radius: 999px !important;
  border: 1px solid rgba(0,0,0,.12) !important;
  padding: 0 16px !important;

  outline: none !important;
  background: #fff !important;
  font-size: 16px !important;    /* evita zoom iOS sugli input */
}

/* Bottone: stessa larghezza degli input */
#itera-fn-footer .itera-nl-btn{
  box-sizing: border-box !important;

  width: 100% !important;
  max-width: 520px !important;
  margin: 2px auto 0 auto !important;

  height: 44px !important;
  border-radius: 999px !important;
  border: 0 !important;
  cursor: pointer;

  background: #d8b36c;
  color: #1a1a1a;
  font-weight: 700;
  white-space: nowrap;
}
#itera-fn-footer .itera-nl-btn:hover{ filter: brightness(.98); }

#itera-fn-footer .itera-nl-hp{ position:absolute !important; left:-9999px !important; width:1px; height:1px; opacity:0; }
#itera-fn-footer .itera-nl-msg{ grid-column: 1 / -1; font-size: 13px; margin-top: 6px; }
#itera-fn-footer .itera-nl-msg.ok{ color: #0b7a2a; }
#itera-fn-footer .itera-nl-msg.err{ color: #b00020; }

/* ===========================
   FOOTER
   =========================== */
#itera-fn-footer .itera-footer{ max-width: var(--itera-maxw); margin: 0 auto; }
#itera-fn-footer .itera-footer-grid{
  display: grid;
  grid-template-columns: repeat(var(--itera-cols-d), minmax(0,1fr));
  gap: var(--itera-gap-d);
  padding: 18px 0 8px 0;
}
#itera-fn-footer .itera-col-title{ font-weight: 800; color:#0f1b1c; margin-bottom: 10px; }
#itera-fn-footer .itera-col-text{ color: rgba(15,27,28,.72); font-size: 13px; line-height: 1.55; }
#itera-fn-footer .itera-links{ list-style:none; margin: 10px 0 0 0; padding: 0; }
#itera-fn-footer .itera-links li{ margin: 6px 0; }
#itera-fn-footer .itera-links a{
  display: inline-flex;
  gap: 8px;
  align-items: center;
  color: rgba(15,27,28,.78);
  text-decoration: none;
  font-size: 13px;
}
#itera-fn-footer .itera-links a:hover{ text-decoration: underline; }
#itera-fn-footer .itera-dot{
  width: 6px; height: 6px; border-radius: 50%;
  background: #d8b36c;
  display:inline-block;
}
#itera-fn-footer .itera-cta{
  display:inline-flex;
  margin-top: 12px;
  padding: 10px 12px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.12);
  text-decoration:none;
  color:#0f1b1c;
  font-weight: 700;
  font-size: 13px;
}
#itera-fn-footer .itera-cta:hover{ background: rgba(0,0,0,.03); }

#itera-fn-footer .itera-social{ max-width: var(--itera-maxw); margin: 14px auto 0 auto; display:flex; justify-content:center; }
#itera-fn-footer .itera-social-row{ display:flex; gap: 14px; }
#itera-fn-footer .itera-social-btn{
  width: 42px; height: 42px;
  border-radius: 999px;
  display:flex; align-items:center; justify-content:center;
  text-decoration:none;
  border: 1px solid rgba(0,0,0,.10);
  background: #fff;
}
#itera-fn-footer .itera-social-btn.ig{ color:#d62976; }
#itera-fn-footer .itera-social-btn.yt{ color:#ff0000; }
#itera-fn-footer .itera-social-btn.fb{ color:#1877f2; }
#itera-fn-footer .itera-social-btn.tt{ color:#111; }

#itera-fn-footer .itera-bottom-note{ max-width: var(--itera-maxw); margin: 10px auto 0 auto; text-align:center; color: rgba(0,0,0,.55); font-size: 12px; }

/* ===========================
   Responsive
   =========================== */
@media (max-width: 980px){
  #itera-fn-footer .itera-nl-card{ grid-template-columns: 72px 1fr; }
  #itera-fn-footer .itera-nl-form{ grid-column: 1 / -1; }
  /* su mobile li vogliamo full width: */
  #itera-fn-footer .itera-nl-form input.itera-nl-input,
  #itera-fn-footer .itera-nl-btn{
    max-width: none !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
}

@media (max-width: 740px){
  #itera-fn-footer{ padding: 20px 14px; }
  #itera-fn-footer .itera-footer-grid{
    grid-template-columns: repeat(var(--itera-cols-m), minmax(0,1fr));
    gap: var(--itera-gap-m);
  }
  #itera-fn-footer .itera-nl-card{ padding: 16px; }
}


