/**
 * BridgeWorks — Banner e modale consenso cookie
 */

#bw-cc-root {
  --cc-cream: #fffbf7;
  --cc-ink: #292524;
  --cc-ink-dark: #1c1917;
  --cc-ink-soft: #57534e;
  --cc-sage: #3d9b7a;
  --cc-sage-dark: #2f7d62;
  --cc-sage-soft: #d1fae5;
  --cc-line: rgba(120, 113, 108, 0.18);
  --cc-shadow: 0 -8px 32px rgba(41, 37, 36, 0.12);
  --cc-radius: 16px;
  --cc-font: "Nunito", system-ui, -apple-system, sans-serif;
  font-family: var(--cc-font);
}

.bw-cc-banner {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 10050;
  padding: 1rem 1rem max(1rem, env(safe-area-inset-bottom));
  background: var(--cc-cream);
  border-top: 1px solid var(--cc-line);
  box-shadow: var(--cc-shadow);
  transform: translateY(0);
  transition: transform 0.35s ease, opacity 0.35s ease;
}

.bw-cc-banner[hidden] {
  display: none !important;
}

.bw-cc-banner.bw-cc-banner--exit {
  opacity: 0;
  transform: translateY(110%);
  pointer-events: none;
}

.bw-cc-inner {
  max-width: 1100px;
  margin: 0 auto;
  display: grid;
  gap: 1rem;
  align-items: start;
}

@media (min-width: 900px) {
  .bw-cc-inner {
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: 1.5rem;
  }
}

.bw-cc-text strong {
  color: var(--cc-ink);
  font-weight: 800;
}

.bw-cc-text p {
  margin: 0 0 0.4rem;
  font-size: 0.9rem;
  line-height: 1.55;
  color: var(--cc-ink-soft);
  font-weight: 600;
}

.bw-cc-text a {
  color: var(--cc-sage);
  font-weight: 800;
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* Layout azioni banner
   - Mobile: "Rifiuta" e "Accetta" su una sola riga, 50/50, stessa altezza.
             "Personalizza" sotto, come link centrato.
   - Desktop: "Personalizza" sinistra (o tra il testo), Rifiuta/Accetta a destra.
   In tutti i casi i due pulsanti decisionali hanno identica dimensione e peso visivo
   (linee guida Garante / EDPB su pari risalto dei pulsanti di consenso). */
.bw-cc-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.5rem 0.6rem;
  align-items: stretch;
}

.bw-cc-btn--reject {
  grid-column: 1;
  grid-row: 1;
}
.bw-cc-btn--accept {
  grid-column: 2;
  grid-row: 1;
}
.bw-cc-actions .bw-cc-btn--link {
  grid-column: 1 / -1;
  grid-row: 2;
  justify-self: center;
}

@media (min-width: 900px) {
  .bw-cc-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    justify-content: flex-end;
    align-items: center;
  }
  .bw-cc-actions .bw-cc-btn--link {
    margin-right: auto;
  }
}

/* Bottone base — geometria condivisa, così Rifiuta e Accetta sono
   automaticamente equivalenti per dimensione, padding e font-weight. */
.bw-cc-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0.7rem 1.4rem;
  border-radius: 999px;
  font-size: 0.92rem;
  font-weight: 800;
  font-family: inherit;
  line-height: 1;
  letter-spacing: 0.01em;
  cursor: pointer;
  border: 2px solid transparent;
  transition: transform 0.2s ease, background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.bw-cc-btn:focus-visible {
  outline: 2px solid #2dd4bf;
  outline-offset: 2px;
}

/* Pulsanti decisionali principali — pari risalto.
   Stessa size/peso/padding; due colori solidi ad alto contrasto su sfondo cream:
   Accetta sage (#3d9b7a), Rifiuta ink-scuro (#1c1917).
   Entrambi solidi, entrambi 44px di altezza minima, entrambi font-weight 800. */
.bw-cc-btn--accept {
  background: var(--cc-sage);
  color: #fff;
  border-color: var(--cc-sage);
}
.bw-cc-btn--accept:hover {
  background: var(--cc-sage-dark);
  border-color: var(--cc-sage-dark);
}

.bw-cc-btn--reject {
  background: var(--cc-ink);
  color: #fff;
  border-color: var(--cc-ink);
}
.bw-cc-btn--reject:hover {
  background: var(--cc-ink-dark);
  border-color: var(--cc-ink-dark);
}

/* Salva preferenze nel modale — outline sage, equivalente come geometria
   ma volutamente meno “riempito” (non è una scelta tra accettare/rifiutare). */
.bw-cc-btn--save {
  background: #fff;
  color: var(--cc-sage-dark);
  border-color: var(--cc-sage);
}
.bw-cc-btn--save:hover {
  background: var(--cc-sage-soft);
}

/* Azioni accessorie (Personalizza, Annulla) — a forma di link sottolineato.
   Volutamente meno prominenti perché non sono scelte di consenso. */
.bw-cc-btn--link {
  background: transparent;
  color: var(--cc-ink-soft);
  border-color: transparent;
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1.5px;
  font-weight: 700;
  min-height: 0;
  padding: 0.4rem 0.6rem;
}
.bw-cc-btn--link:hover {
  color: var(--cc-ink);
  text-decoration-thickness: 2px;
}

/* Retrocompatibilità: alias delle vecchie classi (se mai usate altrove) */
.bw-cc-btn--primary { background: var(--cc-sage); color: #fff; border-color: var(--cc-sage); }
.bw-cc-btn--ghost { background: transparent; color: var(--cc-ink); border-color: var(--cc-line); }
.bw-cc-btn--secondary { background: var(--cc-sage-soft); color: var(--cc-sage-dark); border-color: rgba(61, 155, 122, 0.35); }

.bw-cc-overlay {
  position: fixed;
  inset: 0;
  z-index: 10040;
  background: rgba(28, 25, 23, 0.45);
  backdrop-filter: blur(4px);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.25s ease;
}

.bw-cc-overlay.bw-cc-overlay--open {
  opacity: 1;
  pointer-events: auto;
}

.bw-cc-modal {
  position: fixed;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -48%) scale(0.96);
  z-index: 10060;
  width: min(92vw, 440px);
  max-height: min(88vh, 520px);
  overflow: auto;
  background: #fff;
  border-radius: var(--cc-radius);
  border: 1px solid var(--cc-line);
  box-shadow: 0 24px 48px rgba(41, 37, 36, 0.18);
  padding: 1.35rem 1.25rem 1.25rem;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.25s ease, transform 0.25s ease;
}

.bw-cc-modal.bw-cc-modal--open {
  opacity: 1;
  pointer-events: auto;
  transform: translate(-50%, -50%) scale(1);
}

.bw-cc-modal h2 {
  margin: 0 0 0.35rem;
  font-size: 1.15rem;
  font-weight: 800;
  color: var(--cc-ink);
}

.bw-cc-modal > p {
  margin: 0 0 1rem;
  font-size: 0.86rem;
  line-height: 1.5;
  color: var(--cc-ink-soft);
  font-weight: 600;
}

.bw-cc-cat {
  border: 1px solid var(--cc-line);
  border-radius: 12px;
  padding: 0.85rem 0.95rem;
  margin-bottom: 0.65rem;
  background: var(--cc-cream);
}

.bw-cc-cat-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

.bw-cc-cat-title {
  font-size: 0.88rem;
  font-weight: 800;
  color: var(--cc-ink);
}

.bw-cc-cat p {
  margin: 0.45rem 0 0;
  font-size: 0.78rem;
  line-height: 1.45;
  color: var(--cc-ink-soft);
  font-weight: 600;
}

.bw-cc-switch {
  position: relative;
  width: 44px;
  height: 26px;
  flex-shrink: 0;
}

.bw-cc-switch input {
  opacity: 0;
  width: 0;
  height: 0;
}

.bw-cc-slider {
  position: absolute;
  inset: 0;
  background: #d6d3d1;
  border-radius: 999px;
  transition: background 0.2s ease;
  cursor: pointer;
}

.bw-cc-slider::before {
  content: "";
  position: absolute;
  width: 20px;
  height: 20px;
  left: 3px;
  top: 3px;
  background: #fff;
  border-radius: 50%;
  transition: transform 0.2s ease;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.12);
}

.bw-cc-switch input:checked + .bw-cc-slider {
  background: var(--cc-sage);
}

.bw-cc-switch input:checked + .bw-cc-slider::before {
  transform: translateX(18px);
}

.bw-cc-switch input:disabled + .bw-cc-slider {
  background: var(--cc-sage-soft);
  cursor: not-allowed;
  opacity: 0.85;
}

/* Modale: Annulla (link) · Rifiuta tutto · Salva preferenze · Accetta tutto.
   Rifiuta tutto e Accetta tutto restano sempre allineati e di pari dimensione. */
.bw-cc-modal-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.5rem;
  margin-top: 1.1rem;
}
.bw-cc-modal-actions .bw-cc-btn--link {
  grid-column: 1 / -1;
  justify-self: center;
  order: 99;
}
.bw-cc-modal-actions .bw-cc-btn--reject {
  grid-column: 1;
}
.bw-cc-modal-actions .bw-cc-btn--accept {
  grid-column: 2;
}
.bw-cc-modal-actions .bw-cc-btn--save {
  grid-column: 1 / -1;
}

@media (min-width: 520px) {
  .bw-cc-modal-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    justify-content: flex-end;
    align-items: center;
  }
  .bw-cc-modal-actions .bw-cc-btn--link {
    margin-right: auto;
    order: 0;
  }
}

@media (prefers-reduced-motion: reduce) {
  .bw-cc-banner,
  .bw-cc-overlay,
  .bw-cc-modal,
  .bw-cc-slider,
  .bw-cc-slider::before {
    transition: none;
  }
}

/* Revoca consenso (in fondo al modale).
   GDPR art. 7(3): il consenso deve essere revocabile con la stessa facilità
   con cui è prestato. Visualmente è una zona dedicata, separata dai
   pulsanti decisionali principali. */
.bw-cc-revoke {
  margin-top: 1.1rem;
  padding-top: 0.95rem;
  border-top: 1px dashed var(--cc-line);
  text-align: center;
}

.bw-cc-revoke-hint {
  margin: 0 0 0.55rem !important;
  font-size: 0.78rem !important;
  line-height: 1.45 !important;
  color: var(--cc-ink-soft) !important;
  font-weight: 600 !important;
}

.bw-cc-revoke-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font: inherit;
  font-size: 0.82rem;
  font-weight: 700;
  font-family: inherit;
  padding: 0.45rem 0.85rem;
  background: transparent;
  color: #b91c1c;
  border: 1.5px solid rgba(185, 28, 28, 0.25);
  border-radius: 999px;
  cursor: pointer;
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.bw-cc-revoke-btn::before {
  content: "↺";
  font-size: 0.95rem;
  font-weight: 800;
  line-height: 1;
}

.bw-cc-revoke-btn:hover {
  background: #fff5f5;
  border-color: rgba(185, 28, 28, 0.6);
  color: #991b1b;
}

.bw-cc-revoke-btn:focus-visible {
  outline: 2px solid #2dd4bf;
  outline-offset: 2px;
}

.bw-cc-open-link {
  margin: 0;
  padding: 0;
  border: none;
  background: none;
  font: inherit;
  font-weight: 800;
  color: var(--cc-sage, #3d9b7a);
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.bw-cc-open-link:hover {
  color: var(--cc-sage-dark, #358f70);
}

.links .bw-cc-open-link,
.co-reg-foot .bw-cc-open-link {
  display: inline;
  vertical-align: baseline;
}
