/* ECM Cookie banner — neutro/ridistribuibile. I --ecmc-* sono override opzionali per-tema.
   Garante: "Accetta" e "Rifiuta" a PARITÀ visiva (stessa classe --equal). */

.ecm-cookie {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 99999;
  background: var(--ecmc-bg, #ffffff);
  color: var(--ecmc-ink, #1c2a39);
  border-top: 3px solid var(--ecmc-accent, #0066cc);
  box-shadow: 0 -6px 24px rgba(28, 42, 57, .18);
  padding: 1rem 1.25rem 1.1rem;
  display: flex; flex-wrap: wrap; align-items: center; gap: 1rem 1.5rem;
  font-size: .92rem;
}
.ecm-cookie[hidden] { display: none; }

.ecm-cookie__body { flex: 1 1 420px; min-width: 0; }
.ecm-cookie__title { font-size: 1.1rem; font-weight: 700; margin: 0 0 .35rem; color: var(--ecmc-ink, #1c2a39); }
.ecm-cookie__text { margin: 0; line-height: 1.55; }
.ecm-cookie__policy-link { color: var(--ecmc-accent, #0066cc); font-weight: 600; }

.ecm-cookie__close {
  position: absolute; top: .5rem; right: .75rem;
  background: transparent; border: 0; cursor: pointer;
  font-size: 1.6rem; line-height: 1; color: #5d7083;
  width: 40px; height: 40px;
}
.ecm-cookie__close:hover { color: var(--ecmc-ink, #1c2a39); }

/* pannello categorie */
.ecm-cookie__prefs { margin-top: .85rem; display: grid; gap: .5rem; flex-basis: 100%; }
.ecm-cookie__prefs[hidden] { display: none; }
.ecm-cookie__cat {
  display: flex; gap: .6rem; align-items: flex-start;
  padding: .5rem .65rem; border: 1px solid #dae0e6;
  border-radius: .375rem; background: #f2f6fa; line-height: 1.4;
}
.ecm-cookie__cat input { margin-top: .2rem; width: 18px; height: 18px; flex: 0 0 auto; }

/* azioni */
.ecm-cookie__actions { flex: 0 0 auto; display: flex; flex-wrap: wrap; gap: .6rem; align-items: center; }
.ecm-cookie__btn {
  cursor: pointer; border-radius: .375rem; font-weight: 600;
  padding: .7rem 1.4rem; min-height: 44px; border: 2px solid transparent;
  font-size: .95rem; white-space: nowrap;
}
/* PARITÀ Accetta/Rifiuta: stesso identico stile (requisito Garante) */
.ecm-cookie__btn--equal {
  background: var(--ecmc-accent, #0066cc); color: #fff; border-color: var(--ecmc-accent, #0066cc);
}
.ecm-cookie__btn--equal:hover { filter: brightness(.9); }
/* Personalizza: secondario (outline) */
.ecm-cookie__btn--ghost {
  background: transparent; color: var(--ecmc-accent, #0066cc); border-color: #dae0e6;
}
.ecm-cookie__btn--ghost:hover { background: #ebf2fa; }
/* Salva preferenze */
.ecm-cookie__btn--save { background: #008055; color: #fff; border-color: #008055; }
.ecm-cookie__btn--save[hidden] { display: none; }

/* Linguetta "Preferenze cookie" — fixed a sinistra, sola icona (stile widget privacy).
   Sta in basso a sinistra, sopra il banner; ruota leggermente l'icona all'hover. */
.ecm-cookie-reopen {
  position: fixed; left: 0; bottom: 90px; z-index: 99998;
  display: inline-flex; align-items: center; justify-content: center;
  width: 42px; height: 42px; padding: 0;
  background: var(--ecmc-accent, #0066cc); color: #fff;
  border: 0; border-radius: 0 8px 8px 0; cursor: pointer;
  box-shadow: 0 2px 10px rgba(28, 42, 57, .28);
  transition: width .15s ease, background .15s ease;
}
.ecm-cookie-reopen:hover { filter: brightness(.92); width: 46px; }
.ecm-cookie-reopen svg { display: block; transition: transform .4s ease; }
.ecm-cookie-reopen:hover svg { transform: rotate(60deg); }
@media (max-width: 767.98px) {
  .ecm-cookie-reopen { width: 38px; height: 38px; bottom: 70px; }
}

/* focus accessibile */
.ecm-cookie__btn:focus-visible,
.ecm-cookie__close:focus-visible,
.ecm-cookie-reopen:focus-visible { outline: 2px solid var(--ecmc-accent, #0066cc); outline-offset: 2px; }

/* mobile */
@media (max-width: 767.98px) {
  .ecm-cookie { flex-direction: column; align-items: stretch; padding-bottom: 1rem; }
  .ecm-cookie__actions { width: 100%; }
  .ecm-cookie__btn--equal { flex: 1 1 0; text-align: center; }
  .ecm-cookie__btn--ghost, .ecm-cookie__btn--save { flex: 1 1 100%; }
}
