/* =========================================================
   B2B Area — landing rivenditori / tecnici pro.
   Registro: product. Strategia colore: restrained.
   Superficie: paper caldo, border-only, un solo rosso sul
   badge hero e sul CTA. Mono IBM Plex su P.IVA e indici.
   ========================================================= */


/* ---------- 1. Hero ------------------------------------------------- */
.mz-b2b-hero {
  border-bottom: 1px solid var(--border);
  padding: var(--s-7) 0 var(--s-7);
}
.mz-b2b-hero .mz-eyebrow { margin-bottom: var(--s-7); }

.mz-b2b-hero__grid {
  display: grid;
  grid-template-columns: minmax(0, 3fr) minmax(0, 7fr);
  gap: clamp(var(--s-7), 6vw, var(--s-10));
  align-items: center;
}

/* Badge "B2B PRO" — colonna sinistra come "timbro di magazzino" */
.mz-b2b-hero__badge {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0;
  line-height: 1;
  user-select: none;
}
.mz-b2b-hero__badge-text {
  font-family: var(--ff-mono);
  font-feature-settings: 'tnum', 'zero';
  font-weight: 700;
  /* Cap a 128px (era 148) per non sopraffare la headline nel range 860-1100px. */
  font-size: clamp(72px, 9vw, 128px);
  letter-spacing: -0.06em;
  color: var(--brand);
  line-height: 0.85;
}
.mz-b2b-hero__badge-sub {
  font: 600 var(--t-xs)/1 var(--ff-mono);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-top: var(--s-3);
}

/* Copy hero */
.mz-b2b-hero__title {
  /* Floor da 28→32 e slope da 3.8→4.4: la headline cresce più del badge nel
   * range intermedio (860-1100px) mantenendo il cap a 44. */
  font: 700 clamp(32px, 4.4vw, 44px)/1.1 var(--ff-ui);
  letter-spacing: -0.02em;
  color: var(--ink-1);
  margin: 0 0 var(--s-6);
  max-width: 22ch;
}
.mz-b2b-hero__lede {
  font-size: var(--t-base);
  line-height: var(--lh-base);
  color: var(--ink-2);
  max-width: 54ch;
  margin: 0 0 var(--s-7);
}

@media (max-width: 860px) {
  .mz-b2b-hero { padding: var(--s-6) 0; }
  .mz-b2b-hero__grid {
    grid-template-columns: 1fr;
    gap: var(--s-6);
  }
  .mz-b2b-hero__badge { flex-direction: row; align-items: baseline; gap: var(--s-3); }
  .mz-b2b-hero__badge-text { font-size: clamp(56px, 16vw, 96px); }
  .mz-b2b-hero__badge-sub { margin-top: 0; }
  .mz-b2b-hero__title { font-size: clamp(24px, 6vw, 32px); max-width: none; }
}


/* ---------- 2. Vantaggi -------------------------------------------- */
.mz-b2b-vantaggi {
  padding: var(--s-10) 0;
  border-bottom: 1px solid var(--border);
}

.mz-b2b-vantaggi__head {
  margin-bottom: var(--s-8);
}
.mz-b2b-vantaggi__title {
  font: 700 clamp(22px, 3vw, 32px)/1.2 var(--ff-ui);
  letter-spacing: -0.02em;
  color: var(--ink-1);
  margin: var(--s-4) 0 0;
  max-width: 42ch;
}

/* Hairline-gridded 2×2: gap di 1px su sfondo --border, celle su --paper.
 * Niente per-cell border — la grid disegna la matrice (DESIGN.md §7.5). */
.mz-b2b-vantaggi__grid {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
}

.mz-b2b-vantaggio {
  background: var(--paper);
  padding: var(--s-7) var(--s-7) var(--s-8);
}

.mz-b2b-vantaggio__num {
  display: block;
  font: 600 var(--t-xs)/1 var(--ff-mono);
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--brand);
  margin-bottom: var(--s-5);
}
.mz-b2b-vantaggio__title {
  font: 600 var(--t-md)/1.25 var(--ff-ui);
  letter-spacing: -0.01em;
  color: var(--ink-1);
  margin: 0 0 var(--s-3);
}
.mz-b2b-vantaggio__text {
  font-size: var(--t-base);
  line-height: var(--lh-base);
  color: var(--ink-2);
  margin: 0;
}

@media (max-width: 640px) {
  .mz-b2b-vantaggi { padding: var(--s-8) 0; }
  .mz-b2b-vantaggi__grid { grid-template-columns: 1fr; }
}


/* ---------- 3. Steps ----------------------------------------------- */
.mz-b2b-steps {
  padding: var(--s-10) 0;
  border-bottom: 1px solid var(--border);
  background: var(--paper-2);
}

.mz-b2b-steps__head { margin-bottom: var(--s-8); }
.mz-b2b-steps__title {
  font: 700 clamp(20px, 2.6vw, 28px)/1.2 var(--ff-ui);
  letter-spacing: -0.02em;
  color: var(--ink-1);
  margin: var(--s-4) 0 0;
  max-width: 38ch;
}

/* Stesso pattern hairline-gap. Celle su --paper-2 per restare a filo con
 * lo sfondo della sezione (steps live su --paper-2). */
.mz-b2b-steps__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
}

.mz-b2b-step {
  background: var(--paper-2);
  padding: var(--s-7) var(--s-7) var(--s-8);
}

.mz-b2b-step__num {
  display: block;
  font: 600 var(--t-xs)/1 var(--ff-mono);
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: var(--s-5);
}
.mz-b2b-step__title {
  font: 600 var(--t-md)/1.25 var(--ff-ui);
  letter-spacing: -0.01em;
  color: var(--ink-1);
  margin: 0 0 var(--s-3);
}
.mz-b2b-step__text {
  font-size: var(--t-base);
  line-height: var(--lh-base);
  color: var(--ink-2);
  margin: 0;
}

@media (max-width: 860px) {
  .mz-b2b-steps { padding: var(--s-8) 0; }
  .mz-b2b-steps__list { grid-template-columns: 1fr; }
}


/* ---------- 4. Form section ---------------------------------------- */
.mz-b2b-form-section {
  padding: var(--s-10) 0;
  border-bottom: 1px solid var(--border);
}

.mz-b2b-form-section__head { margin-bottom: var(--s-8); }
.mz-b2b-form-section__title {
  font: 700 clamp(20px, 2.6vw, 28px)/1.2 var(--ff-ui);
  letter-spacing: -0.02em;
  color: var(--ink-1);
  margin: var(--s-4) 0 0;
  max-width: 44ch;
}
.mz-b2b-form-section__hint {
  font: 400 var(--t-sm)/1.4 var(--ff-ui);
  color: var(--ink-2);
  margin: var(--s-4) 0 0;
}

.mz-b2b-form-wrap {
  display: grid;
  grid-template-columns: minmax(0, 7fr) minmax(0, 4fr);
  gap: clamp(var(--s-7), 5vw, var(--s-10));
  align-items: start;
}

/* Feedback — successo / errore */
.mz-b2b-feedback {
  display: flex;
  gap: var(--s-5);
  align-items: flex-start;
  padding: var(--s-6);
  border: 1px solid var(--border);
  border-radius: var(--r-2);
}
.mz-b2b-feedback svg {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  margin-top: 2px;
}
.mz-b2b-feedback--ok {
  background: color-mix(in oklch, var(--success) 8%, var(--paper));
  border-color: color-mix(in oklch, var(--success) 30%, transparent);
  color: var(--success);
}
.mz-b2b-feedback--ok strong {
  display: block;
  font-weight: 600;
  margin-bottom: var(--s-2);
}
.mz-b2b-feedback--ok p {
  margin: 0;
  font-size: var(--t-base);
  line-height: var(--lh-base);
  color: var(--ink-2);
}
.mz-b2b-feedback--err {
  /* Errori sempre in rosso a prescindere dal mode (in ecom --brand è arancio). */
  background: color-mix(in oklch, var(--danger) 8%, var(--paper));
  border-color: color-mix(in oklch, var(--danger) 30%, transparent);
  color: var(--danger);
}
.mz-b2b-feedback--err p { margin: 0; font-size: var(--t-base); }

/* Form */
.mz-b2b-form {
  display: flex;
  flex-direction: column;
  gap: var(--s-6);
}

.mz-b2b-form__row { display: grid; }
.mz-b2b-form__row--2col { grid-template-columns: 1fr 1fr; gap: var(--s-5); }

/* Field */
.mz-b2b-field {
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
  position: relative;
}
.mz-b2b-field__label {
  font: 600 var(--t-sm)/1 var(--ff-ui);
  color: var(--ink-2);
}
.mz-b2b-field__label span { color: var(--brand); }

.mz-b2b-field__input,
.mz-b2b-field__select,
.mz-b2b-field__textarea {
  font: 400 var(--t-base)/1 var(--ff-ui);
  color: var(--ink-1);
  background: var(--paper);
  border: 1px solid var(--border-strong);
  border-radius: var(--r-2);
  padding: 0 var(--s-4);
  height: 44px;
  width: 100%;
  transition: border-color var(--d-1) var(--ease);
  appearance: none;
  box-sizing: border-box;
}
.mz-b2b-field__textarea {
  height: auto;
  padding: var(--s-3) var(--s-4);
  resize: vertical;
  min-height: 100px;
  line-height: var(--lh-base);
}
.mz-b2b-field__select {
  padding-right: var(--s-8);
  cursor: pointer;
}
.mz-b2b-field:has(> .mz-b2b-field__select)::after {
  content: "";
  position: absolute;
  right: var(--s-3);
  bottom: 14px;
  width: 16px;
  height: 16px;
  background-color: var(--ink-3);
  -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'><path d='m6 9 6 6 6-6'/></svg>") no-repeat center / contain;
          mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'><path d='m6 9 6 6 6-6'/></svg>") no-repeat center / contain;
  pointer-events: none;
}
.mz-b2b-field__input--mono {
  font-family: var(--ff-mono);
  font-feature-settings: 'tnum';
  letter-spacing: 0.03em;
}

.mz-b2b-field__input:focus,
.mz-b2b-field__select:focus,
.mz-b2b-field__textarea:focus {
  outline: none;
  border-color: var(--ink-1);
}

/* Form footer */
.mz-b2b-form__footer {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--s-5);
  padding-top: var(--s-2);
}

/* Aside contatti diretti */
.mz-b2b-form-aside {
  padding: var(--s-7);
  border: 1px solid var(--border);
  border-radius: var(--r-2);
  background: var(--paper-2);
  display: flex;
  flex-direction: column;
  gap: var(--s-4);
}
.mz-b2b-form-aside__label {
  font: 600 var(--t-sm)/1.3 var(--ff-ui);
  color: var(--ink-1);
  margin: 0 0 var(--s-2);
}
.mz-b2b-form-aside__link {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  font: 500 var(--t-base)/1 var(--ff-ui);
  color: var(--ink-2);
  text-decoration: none;
  transition: color var(--d-1) var(--ease);
}
.mz-b2b-form-aside__link:hover { color: var(--brand); }
.mz-b2b-form-aside__link svg {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  color: var(--ink-3);
  transition: color var(--d-1) var(--ease);
}
.mz-b2b-form-aside__link:hover svg { color: var(--brand); }

@media (max-width: 860px) {
  .mz-b2b-form-section { padding: var(--s-8) 0; }
  .mz-b2b-form-wrap {
    grid-template-columns: 1fr;
  }
  .mz-b2b-form__row--2col { grid-template-columns: 1fr; }
  .mz-b2b-form-aside { order: -1; }
  .mz-b2b-form__footer { flex-direction: column; align-items: stretch; }
}
