/* Castro & Partners — Website UI kit page styles
   Built on top of ../../colors_and_type.css */

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html { overflow-x: hidden; }
body {
  font-family: var(--cp-font-body);
  background: var(--cp-bg-1);
  color: var(--cp-fg-1);
  overflow-x: hidden;
  min-width: 320px;
}

/* WordPress block layout costringe i figli del main a contentSize/wideSize.
   Le nostre cp-section gestiscono già la larghezza via .cp-container interno —
   liberiamole da quel vincolo per fare full-width vero. */
.wp-site-blocks,
.wp-site-blocks > main,
main.wp-block-group,
main.wp-block-group.is-layout-flow,
main.wp-block-group.is-layout-constrained,
.entry-content,
.wp-block-post-content {
  max-width: none !important;
  width: 100% !important;
  margin-inline: 0 !important;
  padding-inline: 0 !important;
}
main.wp-block-group > .cp-section,
main.wp-block-group > .cp-hero-wrap,
main.wp-block-group > .cp-cta,
main.wp-block-group > .cp-ma-band,
main.wp-block-group > section,
.entry-content > .cp-section,
.entry-content > .cp-hero-wrap,
.entry-content > .cp-cta,
.entry-content > .cp-ma-band,
.entry-content > section,
.wp-block-post-content > .cp-section,
.wp-block-post-content > .cp-hero-wrap,
.wp-block-post-content > .cp-cta,
.wp-block-post-content > .cp-ma-band,
.wp-block-post-content > section {
  max-width: none !important;
  width: 100% !important;
  margin-inline: 0 !important;
}
/* override .is-layout-constrained che impone max-width: contentSize ai figli */
.is-layout-constrained > .cp-section,
.is-layout-constrained > .cp-hero-wrap,
.is-layout-constrained > .cp-cta,
.is-layout-constrained > .cp-ma-band,
.is-layout-constrained > section.cp-section,
.is-layout-flow > .cp-section,
.is-layout-flow > .cp-hero-wrap,
.is-layout-flow > section.cp-section,
.is-layout-flow > section.cp-hero-wrap {
  max-width: none !important;
  width: 100% !important;
  margin-inline: 0 !important;
}

img { max-width: 100%; display: block; }

.cp-container {
  width: 100%;
  max-width: var(--cp-container);
  margin: 0 auto;
  padding-inline: var(--cp-gutter);
}
.cp-container--wide { max-width: var(--cp-container-wide); }
.cp-container--narrow { max-width: var(--cp-container-narrow); }
.cp-container--full { max-width: none; padding-inline: var(--cp-gutter); }

/* ---------- Header ---------- */
.cp-hdr {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(255,255,255,0.96);
  backdrop-filter: saturate(120%) blur(8px);
  -webkit-backdrop-filter: saturate(120%) blur(8px);
  border-bottom: 1px solid var(--cp-border);
}
.cp-hdr__inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: 24px;
  /* padding verticale 14px, padding orizzontale ereditato da .cp-container (var(--cp-gutter)) */
  padding-block: 14px;
}
.cp-hdr__logo { height: 44px; width: auto; display: block; }
.cp-nav { display: flex; gap: 28px; align-items: center; }
.cp-nav__item {
  font-family: var(--cp-font-body);
  font-size: 14px;
  font-weight: 500;
  color: var(--cp-fg-1);
  cursor: pointer;
  position: relative;
  padding: 8px 0;
  letter-spacing: 0;
}
.cp-nav__item:hover { color: var(--cp-brand-700); }
.cp-nav__caret { margin-left: 4px; font-size: 9px; opacity: 0.6; }
.cp-nav__menu {
  position: absolute;
  top: calc(100% + 6px);
  left: -16px;
  min-width: 280px;
  background: #fff;
  border: 1px solid var(--cp-border);
  box-shadow: var(--cp-shadow-3);
  padding: 8px 0;
  display: none;
  z-index: 100;
}
.cp-nav__item:hover .cp-nav__menu { display: block; }
.cp-nav__menu a {
  display: block;
  padding: 10px 18px;
  font-size: 13px;
  color: var(--cp-fg-1);
  font-weight: 500;
}
.cp-nav__menu a:hover { background: var(--cp-brand-100); color: var(--cp-brand-700); text-decoration: none; }

/* ---------- Buttons ---------- */
.cp-btn {
  font-family: var(--cp-font-display);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 14px 26px;
  border: none;
  cursor: pointer;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  transition: background var(--cp-dur-fast) var(--cp-ease-out), color var(--cp-dur-fast) var(--cp-ease-out);
  border-radius: 0;
}
.cp-btn--primary { background: var(--cp-brand-700); color: #fff; }
.cp-btn--primary:hover { background: var(--cp-brand-800); color: #fff; text-decoration: none; }
.cp-btn--secondary { background: transparent; color: var(--cp-brand-700); border: 1.5px solid var(--cp-brand-700); padding: 12.5px 24.5px; }
.cp-btn--secondary:hover { background: var(--cp-brand-700); color: #fff; text-decoration: none; }
.cp-btn--ghost { background: transparent; color: var(--cp-brand-700); padding: 14px 8px; }
.cp-btn--ghost:hover { color: var(--cp-brand-800); text-decoration: underline; }
.cp-btn--dark { background: #fff; color: var(--cp-brand-900); }
.cp-btn--dark:hover { background: var(--cp-brand-100); color: var(--cp-brand-900); text-decoration: none; }
.cp-btn--sm { font-size: 11px; padding: 10px 18px; }

/* ---------- Eyebrow block ---------- */
.cp-eb__label {
  font-family: var(--cp-font-display);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--cp-brand-700);
  display: block;
  margin-bottom: 14px;
}
.cp-eb__heading {
  font-family: var(--cp-font-display);
  font-weight: 800;
  font-size: clamp(22px, 3.6vw, 48px);
  line-height: 1.12;
  letter-spacing: -0.015em;
  color: var(--cp-ink);
  margin: 0 0 18px;
  text-wrap: balance;
  overflow-wrap: break-word;
  word-break: break-word;
}
.cp-eb__body {
  font-family: var(--cp-font-body);
  font-size: 17px;
  line-height: 1.6;
  color: var(--cp-fg-2);
  max-width: 60ch;
  margin: 0;
}

/* ---------- Hero ---------- */
.cp-hero-wrap {
  width: 100%;
  background: #fff;
}
.cp-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: stretch;
  min-height: clamp(420px, 62vh, 680px);
  background: #fff;
  width: 100%;
}
/* Break-out automatico: se l'hero è figlio di .cp-container (pillar pages legacy
   che hanno l'hero inline nel post content), forza full-bleed comunque. */
.cp-container > .cp-hero,
.cp-section .cp-container > .cp-hero {
  width: 100vw;
  position: relative;
  left: 50%;
  right: 50%;
  margin-left: -50vw;
  margin-right: -50vw;
  /* compensa l'overflow orizzontale che 100vw può causare con scrollbar */
  max-width: 100vw;
}
.cp-hero__copy {
  /* padding-left = gutter container, così il copy parte ESATTAMENTE dove inizia
     il contenuto del resto della pagina. Niente margin-left:auto: il copy va
     ancorato al bordo SINISTRO dello schermo (col gutter), non centrato nella
     sua colonna grid. */
  padding: clamp(48px, 7vw, 96px) clamp(32px, 5vw, 80px) clamp(48px, 7vw, 96px) var(--cp-gutter);
  display: flex; flex-direction: column; justify-content: center;
  width: 100%;
  min-width: 0; /* permette al titolo di shrink dentro grid */
}
.cp-hero__kicker {
  font-family: var(--cp-font-display);
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--cp-brand-700);
  margin-bottom: 18px;
}
.cp-hero__title {
  font-family: var(--cp-font-display);
  font-weight: 900;
  font-size: clamp(28px, 5.2vw, 64px);
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: var(--cp-ink);
  margin: 0 0 22px;
  text-wrap: balance;
  /* Lascia che le parole lunghe vadano in overflow controllato, ma NON sillabare
     ("framework" non deve diventare "fra-mework"). */
  overflow-wrap: break-word;
  word-break: normal;
  hyphens: none;
  -webkit-hyphens: none;
}
.cp-hero__lead {
  font-family: var(--cp-font-body);
  font-size: 19px;
  line-height: 1.55;
  color: var(--cp-fg-2);
  margin: 0 0 36px;
  max-width: 28ch;
}
.cp-hero__image {
  background-size: cover; background-position: center;
  min-height: clamp(280px, 50vh, 680px);
  position: relative;
}
.cp-hero__image::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(105deg, rgba(0,0,0,0) 60%, rgba(0,38,63,0.25) 100%);
}

/* ---------- Section scaffolding ----------
   I padding usano clamp() per scalare dolcemente dal mobile al desktop.
   Le sezioni occupano sempre 100% larghezza disponibile; il vincolo di lettura
   è interno (.cp-container max 1440px). */
.cp-section {
  padding: clamp(48px, 8vw, 96px) 0;
  width: 100%;
  max-width: none;
}
.cp-section--tight { padding: clamp(40px, 6vw, 64px) 0; }
.cp-section--alt { background: var(--cp-warm-050); }
.cp-section--dark { background: var(--cp-brand-900); color: #fff; }
.cp-section__intro { max-width: 720px; margin: 0 auto clamp(32px, 4vw, 56px); text-align: center; }
.cp-section__intro--left { text-align: left; margin-left: 0; }

/* ---------- Luciano intro ---------- */
.cp-luciano {
  display: grid; grid-template-columns: 320px 1fr;
  gap: 56px; align-items: center;
}
.cp-luciano__portrait {
  width: 100%; aspect-ratio: 1 / 1;
  border-radius: 50%;
  background-size: cover; background-position: center;
  overflow: hidden;
  background-color: var(--cp-brand-100);
}
.cp-luciano__role {
  font-family: var(--cp-font-display);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--cp-brand-700);
}
.cp-luciano__name {
  font-family: var(--cp-font-display);
  font-weight: 900;
  font-size: 44px;
  line-height: 1.05;
  letter-spacing: -0.015em;
  margin: 6px 0 4px;
}
.cp-luciano__title {
  font-family: var(--cp-font-body); font-size: 16px; color: var(--cp-fg-2);
  margin-bottom: 20px;
}
.cp-luciano__bio p { font-size: 16px; line-height: 1.65; color: var(--cp-fg-2); margin: 0 0 12px; max-width: 56ch; }
.cp-luciano__bio strong { color: var(--cp-ink); font-weight: 600; }

/* ---------- Dual product cards ---------- */
.cp-dual { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; }
.cp-product-card {
  background: #fff;
  border: 1px solid var(--cp-border);
  padding: 40px 36px;
  display: flex; flex-direction: column; gap: 18px;
  transition: box-shadow var(--cp-dur-base) var(--cp-ease-out);
  box-shadow: var(--cp-shadow-1);
}
.cp-product-card:hover { box-shadow: var(--cp-shadow-3); }
.cp-product-card__logo {
  height: 56px;
  background: var(--cp-brand-100);
  border-radius: 4px;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--cp-font-display); font-weight: 800; letter-spacing: 0.04em;
  color: var(--cp-brand-700);
  font-size: 18px;
  padding: 0 22px;
}
.cp-product-card__h {
  font-family: var(--cp-font-display); font-weight: 800; font-size: 28px;
  letter-spacing: -0.01em; line-height: 1.15; color: var(--cp-ink); margin: 0;
}
.cp-product-card__p { font-size: 15px; line-height: 1.6; color: var(--cp-fg-2); margin: 0; }
.cp-product-card .cp-btn { align-self: flex-start; margin-top: 6px; }

/* ---------- Press strip ---------- */
/* Layout base ridefinito in cp-extras.css (.cp-press grid + tessere bianche).
   Niente filter qui: i loghi devono apparire a colori originali. */
.cp-press {
  display: flex; flex-wrap: wrap; gap: 36px 56px;
  justify-content: center; align-items: center;
}
.cp-press__item {
  font-family: var(--cp-font-display);
  font-weight: 800;
  font-size: 22px;
  letter-spacing: -0.01em;
  color: var(--cp-gray-700);
  text-transform: uppercase;
}
.cp-press__item--serif { font-family: Georgia, "Times New Roman", serif; font-weight: 700; text-transform: none; letter-spacing: 0.01em; }

/* ---------- Client strip ---------- */
.cp-clients {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 0;
  border-top: 1px solid var(--cp-border);
  border-left: 1px solid var(--cp-border);
}
.cp-clients__cell {
  border-right: 1px solid var(--cp-border);
  border-bottom: 1px solid var(--cp-border);
  padding: 22px 16px;
  display: flex; align-items: center; justify-content: center;
  aspect-ratio: 2/1;
  font-family: var(--cp-font-display);
  font-weight: 700;
  font-size: 15px;
  color: var(--cp-gray-700);
  letter-spacing: 0;
  text-align: center;
  line-height: 1.1;
  transition: background var(--cp-dur-base) var(--cp-ease-out);
}
.cp-clients__cell:hover { background: var(--cp-brand-050); color: var(--cp-brand-700); }

/* ---------- Course cards ---------- */
.cp-courses { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.cp-course {
  background: #fff;
  border: 1px solid var(--cp-border);
  padding: 0;
  display: flex; flex-direction: column;
  overflow: hidden;
  transition: box-shadow var(--cp-dur-base) var(--cp-ease-out);
  box-shadow: var(--cp-shadow-1);
}
.cp-course:hover { box-shadow: var(--cp-shadow-3); }
.cp-course__media {
  height: 180px;
  background: var(--cp-brand-100);
  position: relative;
  overflow: hidden;
}
.cp-course__media::before {
  content: "";
  position: absolute; inset: 0;
  background:
    linear-gradient(135deg, var(--cp-brand-700) 0%, var(--cp-brand-900) 100%);
  opacity: 0.95;
}
.cp-course__media-label {
  position: relative; z-index: 1;
  color: #fff;
  font-family: var(--cp-font-display); font-weight: 800;
  font-size: 13px; letter-spacing: 0.18em; text-transform: uppercase;
  padding: 22px 24px; opacity: 0.85;
}
.cp-course__media-title {
  position: relative; z-index: 1;
  color: #fff;
  font-family: var(--cp-font-display); font-weight: 900;
  font-size: 30px; line-height: 1.0; letter-spacing: -0.02em;
  padding: 0 24px 22px;
}
.cp-course__body { padding: 26px 28px; display: flex; flex-direction: column; gap: 16px; flex: 1; }
.cp-course__h {
  font-family: var(--cp-font-display); font-weight: 800; font-size: 20px;
  line-height: 1.2; letter-spacing: -0.005em; color: var(--cp-ink); margin: 0;
}
.cp-course__p { font-size: 14px; line-height: 1.55; color: var(--cp-fg-2); margin: 0; flex: 1; }
.cp-course__tags { display: flex; gap: 6px; flex-wrap: wrap; }

/* ---------- Case study cards (cp-cs-*) ---------- */
.cp-cs-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.cp-cs-card {
  background: #fff;
  border: 1px solid var(--cp-border);
  border-radius: var(--cp-radius-lg);
  overflow: hidden;
  box-shadow: var(--cp-shadow-1);
  display: flex; flex-direction: column;
  transition: box-shadow var(--cp-dur-base) var(--cp-ease-out);
}
.cp-cs-card:hover { box-shadow: var(--cp-shadow-3); }
.cp-cs-card__media {
  height: 160px;
  position: relative;
  overflow: hidden;
  background: var(--cp-brand-100);
}
.cp-cs-card__media img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  filter: saturate(1.02) contrast(1.02);
}
.cp-cs-card__pill {
  position: absolute; left: 14px; top: 14px;
  background: #fff;
  color: var(--cp-brand-700);
  font-family: var(--cp-font-display);
  font-size: 9.5px; font-weight: 700;
  letter-spacing: 0.1em; text-transform: uppercase;
  padding: 5px 11px;
  border-radius: var(--cp-radius-pill);
  box-shadow: 0 1px 3px rgba(11,11,12,0.14);
}
.cp-cs-card__body {
  padding: 20px 22px;
  display: flex; flex-direction: column; flex: 1;
}
.cp-cs-card__eyebrow {
  font-size: 9.5px; font-weight: 700;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--cp-fg-3);
}
.cp-cs-card__h {
  font-family: var(--cp-font-display);
  font-weight: 800; font-size: 17px;
  line-height: 1.15; letter-spacing: -0.005em;
  color: var(--cp-ink);
  margin: 6px 0 12px;
}
.cp-cs-card__p {
  font-size: 13px; line-height: 1.6;
  color: var(--cp-gray-800);
  margin: 0 0 16px; flex: 1;
}
.cp-cs-card__p b { color: var(--cp-brand-700); }
.cp-cs-card__meta {
  font-size: 9.5px; font-weight: 600;
  letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--cp-gray-500);
  margin-bottom: 12px;
}
.cp-cs-card__cta {
  display: inline-flex; align-items: center; gap: 6px;
  align-self: flex-start;
  font-family: var(--cp-font-display);
  font-size: 11px; font-weight: 700;
  letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--cp-brand-700);
  text-decoration: none;
}
.cp-cs-card__cta:hover { color: var(--cp-brand-800); text-decoration: underline; }
.cp-cs-card__btn {
  display: block; text-align: center;
  background: var(--cp-brand-700); color: #fff;
  font-family: var(--cp-font-display);
  font-size: 11px; font-weight: 700;
  letter-spacing: 0.08em; text-transform: uppercase;
  padding: 12px; border-radius: var(--cp-radius-md);
  text-decoration: none;
}
.cp-cs-card__btn:hover { background: var(--cp-brand-800); color: #fff; }

/* Hero split editoriale pagina download */
.cp-cs-hero {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 36px; align-items: center;
  padding-left: 24px;
  border-left: 4px solid var(--cp-brand-700);
  margin-bottom: 40px;
}
.cp-cs-hero__eyebrow {
  font-size: 11px; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--cp-brand-700);
}
.cp-cs-hero__title {
  font-family: var(--cp-font-display);
  font-weight: 900; font-size: 38px;
  line-height: 1.02; letter-spacing: -0.025em;
  color: var(--cp-ink);
  margin: 10px 0 0;
}
.cp-cs-hero__title em { font-style: normal; color: var(--cp-brand-700); }
.cp-cs-hero__intro { font-size: 14px; line-height: 1.6; color: var(--cp-gray-800); margin: 0; }
.cp-cs-hero__intro b { color: var(--cp-ink); }
.cp-cs-hero__note { font-size: 11px; color: var(--cp-gray-500); margin-top: 10px; }

/* ---------- Pill ---------- */
.cp-pill {
  font-family: var(--cp-font-display); font-weight: 700; font-size: 10.5px;
  letter-spacing: 0.1em; padding: 5px 10px; background: var(--cp-brand-100);
  color: var(--cp-brand-700); border-radius: 999px;
}

/* ---------- Certification strip ---------- */
.cp-certs {
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  gap: 8px;
}
.cp-certs__cell {
  background: #fff;
  border: 1px solid var(--cp-border);
  height: 84px;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--cp-font-display); font-weight: 800;
  font-size: 12px; letter-spacing: 0.04em;
  color: var(--cp-fg-2);
  text-align: center; line-height: 1.1; padding: 6px;
}

/* ---------- Method steps ---------- */
.cp-method { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px 36px; }
.cp-step {
  display: flex; flex-direction: column; gap: 12px;
  padding: 24px 0;
  border-top: 3px solid var(--cp-brand-700);
}
.cp-step__num {
  font-family: var(--cp-font-display); font-weight: 900;
  font-size: 14px; letter-spacing: 0.18em; color: var(--cp-brand-700);
}
.cp-step__h {
  font-family: var(--cp-font-display); font-weight: 800;
  font-size: 22px; letter-spacing: -0.005em; color: var(--cp-ink); margin: 0;
}
.cp-step__p { font-size: 14px; line-height: 1.55; color: var(--cp-fg-2); margin: 0; }

/* ---------- Team grid ---------- */
.cp-team { display: grid; grid-template-columns: repeat(4, 1fr); gap: 36px 24px; }
.cp-member { text-align: center; }
.cp-member__photo {
  width: 100%; aspect-ratio: 1/1; border-radius: 50%;
  background-color: var(--cp-brand-100);
  background-size: cover; background-position: center top;
  margin-bottom: 14px;
}
.cp-member__name {
  font-family: var(--cp-font-display); font-weight: 800;
  font-size: 17px; letter-spacing: -0.005em; color: var(--cp-ink); margin: 0;
}
.cp-member__role {
  font-family: var(--cp-font-display); font-weight: 700;
  font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--cp-brand-700); margin-top: 4px;
}

/* ---------- Contact CTA ---------- */
.cp-cta {
  background: var(--cp-brand-900);
  color: #fff;
  padding: 80px 0;
  width: 100%;
  max-width: none;
}
.cp-cta__inner { display: grid; grid-template-columns: 1.4fr 1fr; gap: 56px; align-items: center; }
.cp-cta__title {
  font-family: var(--cp-font-display); font-weight: 900;
  font-size: clamp(32px, 4vw, 48px); line-height: 1.05;
  letter-spacing: -0.015em; margin: 0 0 12px;
  color: #fff;
}
.cp-cta__sub { font-size: 17px; line-height: 1.6; opacity: 0.8; margin: 0; color: rgba(255,255,255,0.85); }
.cp-cta__form {
  display: flex; flex-direction: column; gap: 12px;
}
.cp-cta__form input {
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.2);
  padding: 14px 16px;
  color: #fff;
  font-family: var(--cp-font-body);
  font-size: 14px;
}
.cp-cta__form input::placeholder { color: rgba(255,255,255,0.55); }

/* ---------- Footer ---------- */
.cp-ftr {
  background: var(--cp-brand-900);
  color: #fff;
  padding: 64px 0 32px;
}
.cp-ftr--separated { border-top: 1px solid rgba(255,255,255,0.08); }
.cp-ftr__grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 48px; }
.cp-ftr__logo { height: 64px; width: auto; filter: brightness(0) invert(1); margin-bottom: 18px; }
.cp-ftr__h {
  font-family: var(--cp-font-display); font-weight: 700;
  font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase;
  margin: 0 0 14px;
  color: #fff;
}
.cp-ftr__col p, .cp-ftr__col a {
  display: block; font-size: 13px; line-height: 1.7;
  color: rgba(255,255,255,0.75); margin: 0;
}
.cp-ftr__col a:hover { color: #fff; text-decoration: underline; }
.cp-ftr__legal {
  margin-top: 56px; padding-top: 28px;
  border-top: 1px solid rgba(255,255,255,0.1);
  font-size: 11px; color: rgba(255,255,255,0.65); line-height: 1.6;
}
/* link legali (Privacy/Cookie): senza questa regola ereditavano il global
   a{color:brand-700} → blu su navy del footer, contrasto 1.82, illeggibili. */
.cp-ftr__legal a { color: rgba(255,255,255,0.85); text-decoration: underline; text-underline-offset: 2px; }
.cp-ftr__legal a:hover { color: #fff; }

/* ---------- Modal ---------- */
.cp-modal-bg {
  position: fixed; inset: 0;
  background: rgba(11,11,12,0.6);
  display: flex; align-items: center; justify-content: center;
  z-index: 1000;
  padding: 32px;
  animation: cpFadeIn 200ms var(--cp-ease-out);
}
@keyframes cpFadeIn { from { opacity: 0; } to { opacity: 1; } }
.cp-modal {
  background: #fff;
  padding: 40px 44px;
  max-width: 540px;
  width: 100%;
  border-radius: 4px;
  box-shadow: var(--cp-shadow-3);
}
.cp-modal__close {
  float: right; background: none; border: none; cursor: pointer;
  font-size: 22px; color: var(--cp-fg-3); line-height: 1;
}
.cp-modal__h {
  font-family: var(--cp-font-display); font-weight: 800;
  font-size: 28px; letter-spacing: -0.01em; line-height: 1.15;
  color: var(--cp-ink); margin: 0 0 8px;
}
.cp-modal__sub { font-size: 14px; color: var(--cp-fg-2); margin: 0 0 24px; }
.cp-modal__field {
  display: flex; flex-direction: column; gap: 6px; margin-bottom: 14px;
}
.cp-modal__field label {
  font-family: var(--cp-font-body); font-size: 12px; font-weight: 600;
  color: var(--cp-ink); letter-spacing: 0.02em;
}
.cp-modal__field input, .cp-modal__field textarea {
  font-family: var(--cp-font-body); font-size: 14px;
  padding: 11px 14px;
  border: 1px solid var(--cp-gray-300);
  border-radius: 2px;
  outline: none;
  background: #fff;
  color: var(--cp-ink);
  transition: border-color var(--cp-dur-fast) var(--cp-ease-out), box-shadow var(--cp-dur-fast) var(--cp-ease-out);
}
.cp-modal__field input:focus, .cp-modal__field textarea:focus {
  border-color: var(--cp-brand-700);
  box-shadow: var(--cp-shadow-focus);
}
.cp-modal__success {
  background: var(--cp-brand-100);
  border-left: 4px solid var(--cp-brand-700);
  padding: 16px 18px;
  font-size: 14px;
  color: var(--cp-brand-900);
  margin-bottom: 18px;
}
