/*
Theme Name: Boost4Biz ITA
Theme URI: https://boost4biz.it
Author: Sergio De Carolis
Description: Tema custom Boost4Biz — consulenza operativa per PMI italiane
Version: 2.0.0
Text Domain: boost4biz
*/

/* ============================================================
   RESET & BASE
   ============================================================ */

*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

:root {
  /* COLORI */
  --color-primary:       #1E4A38;
  --color-primary-dark:  #163529;
  --color-primary-light: #2A6150;
  --color-primary-soft:  #E8F2F0;

  --color-accent:        #C0392B;
  --color-accent-hover:  #A93226;
  --color-accent-dark:   #A93226;
  --color-accent-soft:   #FBEAEA;

  --color-btn-primary:       #F36C21;
  --color-btn-primary-hover: var(--color-accent);
  --color-heading-accent:    #F36C21;

  --color-navy:          #1D3D6B;
  --color-navy-dark:     #0F2647;

  --color-bg-page:       #FFFFFF;
  --color-bg-section:    #F5F7FA;
  --color-bg-dark:       #0F2647;
  --color-bg-footer:     #1D3D6B;

  --color-text-headline: var(--color-primary);
  --color-text-body:     #1C1C1E;
  --color-text-muted:    #4B5563;
  --color-text-light:    #B7C0CC;

  --color-border:        #E2E8EF;
  --color-border-dark:   #D4D9E0;

  /* FONT */
  --font-display: 'Poppins', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --font-body:    'Poppins', system-ui, -apple-system, 'Segoe UI', sans-serif;

  /* RAGGI */
  --radius-xs:   4px;
  --radius-sm:   10px;
  --radius-md:   12px;
  --radius-lg:   20px;
  --radius-xl:   24px;
  --radius-pill: 9999px;

  /* SPACING */
  --s1: 4px;
  --s2: 8px;
  --s3: 12px;
  --s4: 16px;
  --s5: 24px;
  --s6: 32px;
  --s7: 48px;
  --s8: 64px;

  /* OMBRE */
  --shadow-xs:         0 1px 2px rgba(0,0,0,0.06);
  --shadow-sm:         0 1px 3px rgba(0,0,0,0.06);
  --shadow-md:         0 4px 12px rgba(0,0,0,0.07);
  --shadow-lg:         0 12px 32px rgba(0,0,0,0.10);
  --shadow-card-hover: 0 8px 28px rgba(0,0,0,0.12);
  --shadow-card:       0 2px 8px rgba(0,0,0,0.06), 0 1px 2px rgba(0,0,0,0.04);
  --shadow-float:      0 8px 24px rgba(0,0,0,0.13), 0 3px 8px rgba(0,0,0,0.06);
  --shadow-overlay:    0 16px 40px rgba(0,0,0,0.14), 0 4px 12px rgba(0,0,0,0.07);

  /* TRANSIZIONI */
  --transition-fast: 150ms ease;
  --transition:      200ms ease;
  --transition-slow: 300ms ease;

  /* COLORE BIANCO */
  --color-white: #ffffff;

  /* LAYOUT */
  --container-max:  1240px;
  --section-py:     80px;
  --section-py-mob: 56px;
  --header-h:       88px;
  --header-h-mob:   64px;
}

html {
  scroll-behavior: smooth;
  scroll-padding-top: var(--header-h);
  -webkit-text-size-adjust: 100%;
}
@media (max-width: 768px) {
  html { scroll-padding-top: var(--header-h-mob); }
}

body {
  font-family: var(--font-body);
  font-size: 1rem;
  line-height: 1.72;
  color: var(--color-text-body);
  background: var(--color-bg-page);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

img, video { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }

/* ============================================================
   TIPOGRAFIA
   ============================================================ */

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-display);
  color: var(--color-text-headline);
  line-height: 1.2;
  font-weight: 700;
  text-wrap: balance;
}

h1 { font-size: clamp(2.2rem, 5vw, 3.5rem);  font-weight: 800; line-height: 1.15; letter-spacing: -0.02em; }
h2 { font-size: clamp(1.6rem, 3.5vw, 2.4rem); font-weight: 700; line-height: 1.2;  letter-spacing: -0.015em; }
h3 { font-size: clamp(1.1rem, 2vw, 1.4rem);   font-weight: 600; line-height: 1.3; }
p  { color: var(--color-text-body); line-height: 1.7; text-wrap: pretty; }

.text-large { font-size: 1.125rem; line-height: 1.65; }
.text-small  { font-size: 0.875rem; color: var(--color-text-muted); }

.eyebrow {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-heading-accent);
  margin-bottom: 12px;
}

.section-label {
  font-family: var(--font-display);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-primary);
  margin-bottom: var(--s3);
}

/* ============================================================
   CONTAINER
   ============================================================ */

.container {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 80px;
}

@media (max-width: 1280px) { .container { padding: 0 40px; } }
@media (max-width: 768px)  { .container { padding: 0 24px; } }

/* ============================================================
   PULSANTI
   ============================================================ */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 14px 28px;
  min-height: 48px;
  border-radius: var(--radius-pill);
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  border: none;
  cursor: pointer;
  transition: background var(--transition), color var(--transition),
              transform var(--transition), box-shadow var(--transition);
  text-decoration: none;
  white-space: nowrap;
}

.btn--primary {
  background: var(--color-btn-primary);
  color: #ffffff;
  box-shadow: 0 4px 16px rgba(243,108,33,0.35);
}
.btn--primary:hover,
.btn--primary:focus-visible {
  background: var(--color-btn-primary-hover);
  transform: translateY(-2px);
  box-shadow: 0 6px 28px rgba(192,57,43,0.50);
  color: #ffffff;
}
.btn--primary:active  { transform: translateY(0); }
.btn--primary:disabled,
.btn--primary[aria-disabled="true"] { opacity: 0.5; pointer-events: none; }

.btn--lg { padding: 16px 36px; font-size: 1.0625rem; }
.btn--sm { padding: 8px 18px; font-size: 0.875rem; min-height: 36px; }

.btn--secondary {
  background: transparent;
  color: var(--color-primary);
  border: 2px solid var(--color-primary);
}
.btn--secondary:hover {
  background: var(--color-primary);
  color: #ffffff;
  transform: translateY(-1px);
}
.btn--secondary:active { background: var(--color-primary-dark); color: #ffffff; transform: translateY(0); }

.btn--ghost {
  background: transparent;
  color: var(--color-primary);
  border: 1px solid var(--color-border-dark);
}
.btn--ghost:hover {
  background: var(--color-primary-soft);
  border-color: var(--color-primary);
  color: var(--color-primary-dark);
  transform: translateY(-1px);
}

.btn--outline {
  background: transparent;
  color: #ffffff;
  border: 2px solid rgba(255,255,255,0.85);
}
.btn--outline:hover {
  border-color: #ffffff;
  background: rgba(255,255,255,0.10);
  color: #ffffff;
}

.btn--outline-white {
  background: transparent;
  color: #ffffff;
  border: 2px solid rgba(255,255,255,0.6);
}
.btn--outline-white:hover {
  border-color: #ffffff;
  background: rgba(255,255,255,0.08);
  color: #ffffff;
}

/* ============================================================
   SEZIONI BASE
   ============================================================ */

.section         { padding: var(--section-py) 0; }
.section--alt    { background: var(--color-bg-section); }
.section--dark   { background: var(--color-bg-dark); color: #ffffff; }
.section--dark h1,
.section--dark h2,
.section--dark h3 { color: #ffffff; }
.section--dark p   { color: rgba(255,255,255,0.82); }

/* ============================================================
   ACCESSIBILITÀ
   ============================================================ */

.skip-link {
  position: absolute;
  top: -100%;
  left: 1rem;
  z-index: 9999;
  padding: 0.5rem 1rem;
  background: var(--color-primary);
  color: #ffffff;
  border-radius: var(--radius-sm);
  font-weight: 600;
  transition: top var(--transition-fast);
}
.skip-link:focus-visible { top: 1rem; }

a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible,
[tabindex]:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 3px;
  border-radius: 2px;
}

/* ============================================================
   HEADER / NAVBAR
   ============================================================ */

.site-header {
  position: sticky;
  top: 0;
  height: var(--header-h);
  background: #ffffff;
  border-bottom: 1px solid var(--color-border);
  box-shadow: 0 2px 8px rgba(0,0,0,0.05);
  z-index: 1000;
  transition: box-shadow var(--transition);
  display: flex;
  align-items: center;
}
.site-header.is-scrolled { box-shadow: 0 4px 16px rgba(0,0,0,0.10); }

.navbar-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 100%;
  gap: 2rem;
}

.navbar-logo       { flex-shrink: 0; margin-left: 1.5rem; }
.navbar-logo-img   { height: 70px; width: auto; }
.custom-logo       { height: 70px; width: auto; display: block; }
.navbar-nav        { flex: 1; }

.nav-list {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.25rem;
}

.nav-link {
  display: block;
  font-size: 0.9375rem;
  font-weight: 500;
  color: var(--color-navy);
  padding: 6px 12px;
  border-radius: var(--radius-sm);
  position: relative;
  transition: color var(--transition-fast), background var(--transition-fast);
}
.nav-link::after {
  content: '';
  position: absolute;
  bottom: 2px;
  left: 12px;
  right: 12px;
  height: 2px;
  background: var(--color-accent);
  border-radius: 2px;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--transition-fast);
}
.nav-link:hover { color: var(--color-primary); }
.nav-link:hover::after { transform: scaleX(1); }

.navbar-actions {
  display: flex;
  align-items: center;
  gap: var(--s3);
  flex-shrink: 0;
}
.navbar-cta { padding: 10px 20px; font-size: 0.875rem; }

.hamburger {
  display: none;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  background: none;
  border: none;
  border-radius: var(--radius-sm);
  color: var(--color-navy);
  cursor: pointer;
  transition: background var(--transition-fast);
}
.hamburger:hover { background: var(--color-bg-section); }

/* MOBILE MENU */
.mobile-menu {
  position: fixed;
  inset: 0;
  background: var(--color-navy-dark);
  z-index: 2000;
  transform: translateX(100%);
  transition: transform var(--transition-slow) cubic-bezier(0.4,0,0.2,1);
  display: flex;
  flex-direction: column;
  padding: var(--s5);
}
.mobile-menu.is-open { transform: translateX(0); }

.mobile-menu-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--s7);
}
.mobile-menu-brand {
  font-size: 1.25rem;
  font-weight: 700;
  color: #ffffff;
}
.mobile-menu-close {
  width: 44px;
  height: 44px;
  background: rgba(255,255,255,0.08);
  border: none;
  border-radius: var(--radius-sm);
  color: #ffffff;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}

.mobile-nav-list { flex: 1; overflow-y: auto; }
.mobile-nav-list li { border-bottom: 1px solid rgba(255,255,255,0.08); }
.mobile-nav-link {
  display: block;
  font-size: 1.125rem;
  font-weight: 600;
  color: rgba(255,255,255,0.85);
  padding: 0.875rem 0;
  transition: color var(--transition-fast);
}
.mobile-nav-link:hover { color: #ffffff; }
.mobile-menu-cta { margin-top: var(--s5); flex-shrink: 0; display: flex; justify-content: center; }

.mobile-menu-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.5);
  z-index: 1999;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--transition-slow);
}
.mobile-menu-overlay.is-visible { opacity: 1; pointer-events: all; }

@media (max-width: 480px) {
  .mobile-menu { padding: var(--s4); }
  .mobile-menu-header { margin-bottom: var(--s5); }
}

@media (max-width: 1024px) {
  .navbar-nav      { display: none; }
  .navbar-cta      { display: none; }
  .hamburger       { display: flex; }
  .navbar-logo-img { height: 48px; }
  .custom-logo     { height: 48px; }
  .navbar-logo     { margin-left: 0; }
  .navbar-inner    { gap: 0.5rem; }
  html             { scroll-padding-top: var(--header-h-mob); }
  :root            { --section-py: var(--section-py-mob); }
  .site-header     { height: var(--header-h-mob); }
}

/* ============================================================
   SEZIONE HEADER COMUNE
   ============================================================ */

.section-header { margin-bottom: var(--s8); max-width: 680px; }
.section-header--centered { margin-left: auto; margin-right: auto; text-align: center; }
.section-header h2 { margin-bottom: var(--s4); }
.section-header p  { color: var(--color-text-muted); font-size: 1.0625rem; }

/* ============================================================
   ANIMAZIONE ENTRANCE HERO
   ============================================================ */

@keyframes heroFadeUp {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}

@media (prefers-reduced-motion: no-preference) {
  .hero__content > * {
    animation: heroFadeUp 0.55s ease-out both;
  }
  .hero__content > *:nth-child(1) { animation-delay: 0.05s; }
  .hero__content > *:nth-child(2) { animation-delay: 0.15s; }
  .hero__content > *:nth-child(3) { animation-delay: 0.25s; }
  .hero__content > *:nth-child(4) { animation-delay: 0.35s; }
  .hero__content > *:nth-child(5) { animation-delay: 0.42s; }
}

/* ============================================================
   HERO PRINCIPALE (homepage)
   ============================================================ */

.hero {
  background-color: var(--color-primary);
  color: #ffffff;
  padding: clamp(4rem, 10vw, 8rem) 0;
  overflow: hidden;
}

.hero__inner {
  display: grid;
  grid-template-columns: 3fr 2fr;
  gap: 3rem;
  align-items: center;
}

.hero__content { max-width: 640px; }

.hero__label {
  display: block;
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.65);
  margin-bottom: 1rem;
}

.hero__title { color: #ffffff; margin-bottom: 1.25rem; max-width: 14ch; }
.hero__title-secondary { opacity: 0.85; }
.hero__lead  { color: rgba(255,255,255,0.85); margin-bottom: 2rem; max-width: 52ch; }

.hero__cta-group {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  align-items: center;
  margin-bottom: 1rem;
}

.hero__cta-note { font-size: 0.8rem; color: rgba(255,255,255,0.5); margin-top: 0.75rem; }

.trust-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: rgba(255,255,255,0.10);
  border: 1px solid rgba(255,255,255,0.20);
  border-radius: 100px;
  padding: 0.35rem 0.85rem;
  font-size: 0.78rem;
  color: rgba(255,255,255,0.85);
  margin-bottom: 1.25rem;
  max-width: 100%;
  white-space: normal;
  line-height: 1.5;
}
.trust-pill__icon { color: var(--color-accent); font-size: 0.7rem; flex-shrink: 0; }

.hero__visual {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 320px;
}

.kpi-stack { position: relative; width: 100%; max-width: 300px; height: 320px; }

.kpi-card {
  background: #ffffff;
  border-radius: var(--radius-md);
  padding: 16px 20px;
  box-shadow: var(--shadow-float);
  position: absolute;
  min-width: 180px;
}
.kpi-card--top    { top: 0; right: 0; }
.kpi-card--middle { top: 50%; left: 0; transform: translateY(-50%); }
.kpi-card--bottom { bottom: 0; right: 20px; }

.kpi-card__number {
  display: block;
  font-size: 1.8rem;
  font-weight: 800;
  color: var(--color-primary);
  line-height: 1;
  margin-bottom: 0.25rem;
}
.kpi-card__label { font-size: 0.78rem; color: var(--color-text-muted); line-height: 1.4; }
.kpi-card__icon  { display: block; font-size: 1.4rem; margin-bottom: 0.25rem; }

/* Hero mobile KPI strip — nascosta su desktop, visibile su mobile */
.hero__mobile-stats {
  display: none;
}

@media (max-width: 768px) {
  .hero__inner { grid-template-columns: 1fr; gap: 2rem; }
  .hero__visual { display: none; }
  .hero__title  { max-width: none; }
  .hero__cta-group { flex-direction: column; align-items: center; }

  .hero__mobile-stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1px;
    background: rgba(255,255,255,0.15);
    border: 1px solid rgba(255,255,255,0.18);
    border-radius: var(--radius-md);
    overflow: hidden;
    margin-top: 1.5rem;
  }

  .hero__mobile-stat {
    background: rgba(255,255,255,0.07);
    padding: 14px 10px;
    text-align: center;
    display: flex;
    flex-direction: column;
    gap: 4px;
  }

  .hero__mobile-stat__value {
    font-size: 1.25rem;
    font-weight: 800;
    color: #ffffff;
    line-height: 1;
  }

  .hero__mobile-stat__label {
    font-size: 0.6875rem;
    color: rgba(255,255,255,0.65);
    line-height: 1.3;
  }
}

/* ============================================================
   PAGE HERO — inner pages
   ============================================================ */

.page-hero {
  background: var(--color-bg-dark);
  padding: calc(var(--header-h) + 24px) 0 56px;
}

.page-hero__inner { max-width: var(--container-max); }

.page-hero__title {
  font-size: clamp(2rem, 4vw, 2.75rem);
  color: #ffffff;
  line-height: 1.25;
  max-width: 720px;
  margin-bottom: 16px;
}

.page-hero__lead {
  font-size: 1.0625rem;
  color: var(--color-text-light);
  max-width: 560px;
  margin-bottom: 0;
}

.page-hero__lead--wide { max-width: 680px; }

.page-hero__actions {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  margin-top: 28px;
}

.page-hero--center { text-align: center; }
.page-hero--center .page-hero__title,
.page-hero--center .page-hero__lead { margin-left: auto; margin-right: auto; }

@media (max-width: 768px) {
  .page-hero { padding: calc(var(--header-h-mob) + 20px) 0 36px; }
  .page-hero__actions { flex-direction: column; align-items: center; }
}

/* ============================================================
   INTRO BAR — coloured banner (metodo page)
   ============================================================ */

.intro-bar {
  background: var(--color-primary);
  padding: 24px 0;
}
.intro-bar__inner { max-width: 860px; margin: 0 auto; text-align: center; }
.intro-bar__text  { font-size: 1.0625rem; color: #ffffff; margin: 0; }
.intro-bar__text strong { color: rgba(255,255,255,0.95); }

/* ============================================================
   PHASE TIMELINE — numbered phases (metodo page)
   ============================================================ */

.phase-timeline {
  max-width: 880px;
  margin: 0 auto;
  border-top: 1px solid var(--color-border);
}

.phase-item {
  display: flex;
  gap: 0;
  align-items: stretch;
  border-bottom: 1px solid var(--color-border);
  padding: 40px 0;
}

.phase-item__num-col {
  flex-shrink: 0;
  width: 80px;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-top: 4px;
}

.phase-item__num {
  font-family: var(--font-display);
  font-size: 2.5rem;
  font-weight: 800;
  color: var(--color-heading-accent);
  line-height: 1;
}

.phase-item__connector {
  flex: 1;
  width: 2px;
  background: var(--color-border);
  margin-top: 12px;
}

.phase-item:last-child .phase-item__connector { display: none; }

.phase-item__body { flex: 1; padding-left: 32px; }

.phase-item__tag {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-primary);
  display: block;
  margin-bottom: 8px;
}

.phase-item__title {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--color-text-headline);
  margin-bottom: 12px;
}

.phase-item__text {
  font-size: 1rem;
  color: var(--color-text-muted);
  line-height: 1.7;
  margin: 0;
}

@media (max-width: 640px) {
  .phase-item { flex-direction: column; gap: 12px; padding: 28px 0; }
  .phase-item__num-col { flex-direction: row; width: auto; align-items: center; gap: 12px; }
  .phase-item__connector { display: none; }
  .phase-item__body { padding-left: 0; }
}

/* ============================================================
   STAGE MINI CARDS — 4-col (metodo + soluzioni)
   ============================================================ */

.stage-mini-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 12px;
  max-width: 900px;
  margin: 0 auto 32px;
}

.stage-mini-card {
  background: #ffffff;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 20px 16px;
}

.stage-mini-card__num {
  font-family: var(--font-display);
  font-size: 1.75rem;
  font-weight: 800;
  color: var(--color-accent);
  display: block;
  line-height: 1;
  margin-bottom: 8px;
}

.stage-mini-card__title {
  font-size: 0.9375rem;
  font-weight: 700;
  color: var(--color-text-headline);
  display: block;
  margin-bottom: 6px;
}

.stage-mini-card__text {
  font-size: 0.875rem;
  color: var(--color-text-muted);
  line-height: 1.5;
  margin: 0;
}

/* ============================================================
   DIFF CARDS — "cosa non siamo" (metodo page)
   ============================================================ */

.diff-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 20px;
  max-width: 960px;
  margin: 0 auto;
}

.diff-card {
  background: var(--color-bg-section);
  border-radius: var(--radius-lg);
  padding: 28px 24px;
  border-left: 4px solid var(--color-primary);
}

.diff-card__negative {
  font-size: 0.9375rem;
  font-weight: 700;
  color: var(--color-text-body);
  margin-bottom: 12px;
  display: flex;
  align-items: baseline;
  gap: 6px;
}

.diff-card__negative-marker { color: var(--color-accent); }

.diff-card__positive {
  font-size: 0.9375rem;
  color: var(--color-text-muted);
  line-height: 1.6;
  margin: 0;
  padding-left: 18px;
  border-left: 2px solid var(--color-primary-light);
}

/* ============================================================
   METRIC SHOWCASE — big KPI numbers (risultati page)
   ============================================================ */

.metric-showcase {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 24px;
  margin-bottom: 64px;
}

@media (max-width: 640px) {
  .metric-showcase { margin-bottom: 40px; }
  .outcome-grid    { margin-bottom: 40px; }
  .quote-grid      { margin-bottom: 32px; }
}

.metric-showcase__item {
  text-align: center;
  padding: 28px 16px;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-lg);
}

.metric-showcase__value {
  display: block;
  font-family: var(--font-display);
  font-size: 2.25rem;
  font-weight: 800;
  color: var(--color-accent);
  margin-bottom: 8px;
}

.metric-showcase__label {
  font-size: 0.9rem;
  color: var(--color-text-muted);
  line-height: 1.4;
}

/* ============================================================
   OUTCOME CARDS (risultati page)
   ============================================================ */

.outcome-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 20px;
  margin-bottom: 64px;
}

.outcome-card {
  background: var(--color-bg-section);
  border-radius: var(--radius-lg);
  padding: 28px 24px;
}

.outcome-card__title {
  font-family: var(--font-display);
  font-size: 0.875rem;
  font-weight: 700;
  color: var(--color-primary);
  margin-bottom: 16px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.outcome-card__list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.outcome-card__item {
  font-size: 0.9375rem;
  color: var(--color-text-body);
  line-height: 1.55;
  padding-left: 20px;
  position: relative;
}
.outcome-card__item::before {
  content: '→';
  position: absolute;
  left: 0;
  color: var(--color-primary);
  font-weight: 700;
}

/* ============================================================
   QUOTE CARDS — testimonianze (risultati page)
   ============================================================ */

.quote-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 20px;
  margin-bottom: 48px;
}

.quote-card {
  background: #ffffff;
  border-radius: var(--radius-lg);
  padding: 28px 24px;
  border-top: 3px solid var(--color-primary);
}

.quote-card__tags {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 12px;
}

.tag {
  font-size: 10px;
  font-weight: 600;
  padding: 3px 10px;
  border-radius: var(--radius-pill);
}
.tag--primary { background: var(--color-primary-soft); color: var(--color-primary); }
.tag--accent  { background: var(--color-accent-soft);  color: var(--color-accent-dark); }

.quote-card__text {
  font-size: 0.9375rem;
  color: var(--color-text-body);
  line-height: 1.65;
  font-style: italic;
  margin-bottom: 20px;
}

.quote-card__name { font-size: 0.9375rem; font-weight: 700; color: var(--color-text-headline); display: block; }
.quote-card__role { font-size: 0.8125rem; color: var(--color-text-muted); }

/* ============================================================
   CTA SECTION — dark band CTA (riutilizzabile)
   ============================================================ */

.cta-section {
  background: var(--color-bg-dark);
  padding: 64px 0;
}

.cta-section__inner {
  max-width: 720px;
  margin: 0 auto;
  text-align: center;
  padding: 0 24px;
}

.cta-section__title {
  font-size: clamp(1.5rem, 3vw, 2rem);
  color: #ffffff;
  margin-bottom: 16px;
}

.cta-section__text {
  font-size: 1.0625rem;
  color: var(--color-text-light);
  margin-bottom: 32px;
}

.cta-section__note {
  font-size: 0.875rem;
  color: var(--color-text-muted);
  margin-top: 16px;
}

.cta-section__actions {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  justify-content: center;
}

@media (max-width: 768px) {
  .cta-section { padding: 48px 0; }
  .cta-section__actions { flex-direction: column; align-items: center; }
}

/* ============================================================
   SELECTION CARDS — per chi è section (homepage)
   ============================================================ */

.selection-section {
  background: var(--color-bg-section);
  padding: var(--section-py) 0;
}

.selection-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 16px;
}

.selection-card {
  display: block;
  background: #ffffff;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 24px;
  text-decoration: none;
  transition: box-shadow var(--transition), border-color var(--transition);
}
.selection-card:hover {
  box-shadow: var(--shadow-card-hover);
  border-color: var(--color-primary);
}

.selection-card__num {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: var(--color-accent);
  text-transform: uppercase;
  margin-bottom: 12px;
}

.selection-card__question {
  font-family: var(--font-display);
  font-size: 1.0625rem;
  font-weight: 600;
  color: var(--color-text-headline);
  line-height: 1.45;
  margin: 0 0 14px;
}

.selection-card__solution {
  font-size: 0.8125rem;
  color: var(--color-primary);
  font-weight: 500;
}

/* ============================================================
   CONTACT PAGE — contatti page section
   ============================================================ */

.contact-page-section {
  padding: calc(var(--header-h) + var(--section-py)) 0 var(--section-py);
}

.contact-page-header { margin-bottom: 48px; }

.contact-page-title {
  font-size: clamp(2rem, 4vw, 2.75rem);
  color: var(--color-text-headline);
  line-height: 1.2;
  margin-bottom: 16px;
}

.contact-page-lead {
  font-size: 1.125rem;
  color: var(--color-text-muted);
  max-width: 560px;
}

.contact-page-note {
  font-size: 0.9375rem;
  color: var(--color-text-muted);
  max-width: 600px;
  margin-top: 12px;
}

.contact-page-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 56px;
  align-items: start;
}

.contact-info-col__title {
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--color-text-headline);
  margin-bottom: 20px;
}

.contact-steps {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-bottom: 36px;
}

.contact-step {
  display: flex;
  gap: 14px;
  align-items: flex-start;
}

.contact-step__num {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--color-primary);
  color: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.8125rem;
  font-weight: 700;
}

.contact-step__text {
  font-size: 0.9375rem;
  color: var(--color-text-body);
  line-height: 1.5;
  padding-top: 4px;
}

.contact-direct {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.contact-direct__link {
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--color-text-body);
  text-decoration: none;
  font-size: 0.9375rem;
  transition: color var(--transition-fast);
}
.contact-direct__link:hover { color: var(--color-primary); }
.contact-direct__link svg { flex-shrink: 0; opacity: 0.7; }

.form-card {
  background: var(--color-bg-section);
  border-radius: var(--radius-lg);
  padding: 36px 32px;
  box-shadow: var(--shadow-card);
}

@media (max-width: 640px) {
  .form-card { padding: 28px 20px; }
  .contact-page-grid { gap: 36px; }
}

/* ============================================================
   FORM COMPONENTS
   ============================================================ */

#contact-form { display: flex; flex-direction: column; }
.contact-form__submit { align-self: center; }

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-bottom: 16px;
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 16px;
}
.form-row .form-group { margin-bottom: 0; }

.form-label {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--color-text-body);
  letter-spacing: 0.02em;
}

.form-input,
.form-textarea {
  width: 100%;
  background: #ffffff;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding: 11px 14px;
  font-family: var(--font-body);
  font-size: 0.9375rem;
  color: var(--color-text-body);
  outline: none;
  transition: border-color var(--transition), box-shadow var(--transition);
}
.form-input::placeholder,
.form-textarea::placeholder { color: var(--color-text-muted); }

.form-input:focus-visible,
.form-textarea:focus-visible {
  border-color: var(--color-accent);
  box-shadow: 0 0 0 3px rgba(192,57,43,0.12);
}

.form-textarea { resize: vertical; min-height: 120px; }

.form-privacy {
  margin-top: 12px;
  font-size: 0.8125rem;
  color: var(--color-text-muted);
  text-align: center;
}
.form-privacy a { color: var(--color-accent); text-decoration: underline; text-underline-offset: 2px; }

.form-feedback {
  margin-top: 16px;
  padding: 14px 16px;
  border-radius: var(--radius-sm);
  font-size: 0.9375rem;
  text-align: center;
}
.form-feedback.is-success {
  background: rgba(192,57,43,0.08);
  color: var(--color-accent-hover);
  border: 1px solid rgba(192,57,43,0.25);
}
.form-feedback.is-error {
  background: rgba(220,50,50,0.08);
  color: #c0392b;
  border: 1px solid rgba(220,50,50,0.25);
}

@media (max-width: 640px) {
  .form-row { grid-template-columns: 1fr; }
}

/* ============================================================
   SETTORI + CASI PAGE
   ============================================================ */

.settori-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 20px;
  margin-bottom: 64px;
}

.settore-card {
  background: var(--color-bg-section);
  border-radius: var(--radius-lg);
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.settore-card__icon  { font-size: 2rem; }
.settore-card__title { font-size: 1.0625rem; font-weight: 700; color: var(--color-text-headline); margin: 0; }
.settore-card__desc  { font-size: 0.9375rem; color: var(--color-text-muted); line-height: 1.6; margin: 0; flex: 1; }

.settore-card__problem {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-text-body);
  padding: 10px 14px;
  background: #ffffff;
  border-left: 3px solid var(--color-accent);
  border-radius: 0 var(--radius-xs) var(--radius-xs) 0;
  margin: 0;
}

.settore-card__link {
  font-size: 0.875rem;
  color: var(--color-primary);
  font-weight: 600;
}
.settore-card__link:hover { text-decoration: underline; }

.casi-list {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.caso-card {
  background: #ffffff;
  border-radius: var(--radius-lg);
  padding: 24px 28px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 24px;
  align-items: start;
}

.caso-card__col-label {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  display: block;
  margin-bottom: 8px;
}
.caso-card__col-label--primary { color: var(--color-primary); }
.caso-card__col-label--accent  { color: var(--color-accent); }

.caso-card__heading { font-size: 0.9375rem; font-weight: 700; color: var(--color-text-headline); }
.caso-card__text    { font-size: 0.875rem; color: var(--color-text-muted); margin-top: 8px; line-height: 1.5; }
.caso-card__result  { font-size: 0.9375rem; font-weight: 600; color: var(--color-text-headline); margin: 0; line-height: 1.5; }

@media (max-width: 640px) {
  .caso-card { padding: 20px 16px; }
}

/* ============================================================
   CHI SIAMO PAGE
   ============================================================ */

.bio-section { padding: var(--section-py) 0; }
.bio-section--alt { background: var(--color-bg-section); }

.bio-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 56px;
  align-items: start;
  max-width: 900px;
}

@media (max-width: 768px) {
  .bio-grid { gap: 32px; }
  .contact-page-header { margin-bottom: 32px; }
  .contact-page-section { padding-top: calc(var(--header-h-mob) + var(--section-py-mob)); }
}

.bio-content {
  display: flex;
  flex-direction: column;
  gap: 14px;
  font-size: 1rem;
  color: var(--color-text-muted);
  line-height: 1.75;
}

.bio-ext-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.credentials-list {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.credential-item { display: flex; gap: 16px; align-items: flex-start; }

.credential-item__value {
  font-size: 0.9375rem;
  font-weight: 700;
  color: var(--color-accent);
  white-space: nowrap;
  min-width: 120px;
}

.credential-item__desc {
  font-size: 0.9rem;
  color: var(--color-text-muted);
  line-height: 1.5;
}

.values-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 16px;
}

.value-card {
  background: var(--color-bg-section);
  border-radius: var(--radius-lg);
  padding: 24px 20px;
  border-left: 3px solid var(--color-primary);
}

.value-card__title { font-size: 1rem; font-weight: 700; color: var(--color-text-headline); margin-bottom: 8px; }
.value-card__text  { font-size: 0.9rem; color: var(--color-text-muted); line-height: 1.6; margin: 0; }

/* ============================================================
   FOOTER
   ============================================================ */

.site-footer {
  background: var(--color-bg-footer);
  padding: 64px 0 0;
  color: #ffffff;
}

.footer-grid {
  display: grid;
  grid-template-columns: 40fr 30fr 30fr;
  gap: 3rem;
  padding-bottom: 3rem;
}

.footer-logo       { height: 64px; width: auto; max-width: 220px; }
.footer-tagline    { font-size: 0.9375rem; color: rgba(255,255,255,0.6); margin: var(--s4) 0 var(--s4); }

.footer-linkedin {
  display: inline-flex;
  align-items: center;
  gap: var(--s2);
  font-size: 0.875rem;
  font-weight: 600;
  color: rgba(255,255,255,0.7);
  transition: color var(--transition-fast);
}
.footer-linkedin:hover { color: #ffffff; }

.footer-col-title {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: rgba(255,255,255,0.45);
  margin-bottom: var(--s5);
}

.footer-nav-list { display: flex; flex-direction: column; gap: 0.75rem; }
.footer-nav-list a { font-size: 0.9375rem; color: rgba(255,255,255,0.7); transition: color var(--transition-fast); }
.footer-nav-list a:hover { color: #ffffff; }
.footer-cta-link { color: var(--color-accent) !important; font-weight: 600; }
.footer-cta-link:hover { color: #ffffff !important; }

.footer-contact-list { display: flex; flex-direction: column; gap: 0.875rem; }
.footer-contact-list li {
  display: flex;
  align-items: flex-start;
  gap: 0.625rem;
  font-size: 0.875rem;
  color: rgba(255,255,255,0.7);
}
.footer-contact-list svg { flex-shrink: 0; margin-top: 2px; opacity: 0.6; }
.footer-contact-list a   { color: rgba(255,255,255,0.7); transition: color var(--transition-fast); }
.footer-contact-list a:hover { color: #ffffff; }

.footer-piva { margin-top: var(--s5); font-size: 0.75rem; color: rgba(255,255,255,0.35); }

.footer-bottom {
  border-top: 1px solid rgba(255,255,255,0.1);
  padding: 1.5rem 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s4);
}
.footer-copyright { font-size: 0.75rem; color: rgba(255,255,255,0.45); }
.footer-legal { display: flex; gap: var(--s4); }
.footer-legal-link {
  font-size: 0.75rem;
  color: rgba(255,255,255,0.45);
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: color var(--transition-fast);
}
.footer-legal-link:hover { color: #ffffff; }

@media (max-width: 768px) {
  .footer-grid   { grid-template-columns: 1fr; gap: 2.5rem; }
  .footer-bottom { flex-direction: column; align-items: flex-start; }
}

/* ============================================================
   UTILITY
   ============================================================ */

.text-accent { color: var(--color-heading-accent); }

/* ============================================================

/* ============================================================
   SR-ONLY (accessibilità)
   ============================================================ */

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}

/* ============================================================
   FAQ ACCORDION — homepage e pagine interne
   ============================================================ */

.hp-faq {
  padding: var(--section-py) 0;
  background: var(--color-bg-section);
}

.faq-list { max-width: 760px; margin: 0 auto var(--s7); }

.faq-item { border-bottom: 1px solid var(--color-border); }

.faq-question {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s4);
  padding: 20px 0;
  font-weight: 600;
  font-size: 1rem;
  color: var(--color-text-headline);
  cursor: pointer;
  list-style: none;
  min-width: 0;
}
.faq-question::-webkit-details-marker { display: none; }

.faq-chevron { flex-shrink: 0; transition: transform var(--transition); }
details[open] .faq-chevron { transform: rotate(180deg); }

.faq-answer {
  padding: 0 0 20px;
  font-size: 0.9375rem;
  color: var(--color-text-muted);
  line-height: 1.65;
  max-width: 680px;
}

.faq-bottom-cta {
  text-align: center;
  margin-top: 8px;
}

/* ============================================================
   ANIMAZIONI SCROLL
   ============================================================ */

.fade-in {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}
.fade-in.is-visible { opacity: 1; transform: translateY(0); }

.fade-in:nth-child(2) { transition-delay: 0.10s; }
.fade-in:nth-child(3) { transition-delay: 0.20s; }
.fade-in:nth-child(4) { transition-delay: 0.30s; }
.fade-in:nth-child(5) { transition-delay: 0.40s; }

@media (prefers-reduced-motion: reduce) {
  .fade-in { animation: none !important; transition: none !important; opacity: 1 !important; transform: none !important; }
}
