/* home.css — Stili specifici homepage Boost4Biz */

/* ============================================================
   HERO
   ============================================================ */

.hero {
  position: relative;
  background:
    linear-gradient(to right, rgba(255,255,255,0.96) 0%, rgba(255,255,255,0.80) 100%),
    url('../img/business.webp') center / cover no-repeat;
  padding: 96px 0 80px;
  overflow: hidden;
  border-top: 4px solid var(--color-border-dark);
}

.hero__inner {
  max-width: 860px;
  margin: 0 auto;
  text-align: center;
}

.hero__badge {
  display: inline-block;
  background: var(--color-primary-soft);
  border: 1px solid rgba(15,128,96,0.25);
  border-radius: var(--radius-pill);
  padding: 6px 18px;
  margin-bottom: var(--s5);
}
.hero__badge span {
  font-family: var(--font-display);
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--color-primary);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.hero__title {
  font-size: clamp(2.25rem, 5vw, 3.25rem);
  font-weight: 800;
  color: var(--color-primary-dark);
  margin-bottom: var(--s5);
  line-height: 1.15;
}

.hero__headline {
  font-family: var(--font-display);
  font-size: clamp(1.125rem, 2.5vw, 1.375rem);
  font-weight: 500;
  color: var(--color-text-muted);
  margin-bottom: var(--s5);
  font-style: italic;
}

.hero__body {
  font-size: 1.0625rem;
  color: var(--color-text-muted);
  max-width: 680px;
  margin: 0 auto var(--s7);
  line-height: 1.8;
}

.hero__cta-group {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: var(--s4);
  margin-bottom: var(--s4);
}

.hero__cta-primary  { height: 52px; padding: 0 32px; font-size: 1rem; }
.hero__cta-secondary { height: 52px; padding: 0 28px; font-size: 1rem; color: var(--color-primary); border-color: var(--color-primary); }
.hero__cta-secondary:hover { color: #ffffff; background: var(--color-primary); border-color: var(--color-primary); }

.hero__microcopy {
  font-size: 0.875rem;
  color: var(--color-text-muted);
  margin-bottom: var(--s8);
}

.hero__metrics {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--s6);
  flex-wrap: wrap;
  padding-top: var(--s6);
  border-top: 1px solid var(--color-border-dark);
}

.hero__metric {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}
.hero__metric-value {
  font-family: var(--font-display);
  font-size: 1.75rem;
  font-weight: 800;
  color: var(--color-accent);
}
.hero__metric-label {
  font-size: 0.8125rem;
  color: var(--color-text-muted);
  max-width: 140px;
  text-align: center;
  line-height: 1.4;
}
.hero__metric-divider {
  width: 1px;
  height: 40px;
  background: var(--color-border-dark);
}

.hero__scroll-hint {
  position: absolute;
  bottom: 28px;
  left: 50%;
  transform: translateX(-50%);
  color: var(--color-text-muted);
  animation: scroll-bounce 2s ease-in-out infinite;
  pointer-events: none;
}
@keyframes scroll-bounce {
  0%, 100% { transform: translateX(-50%) translateY(0); }
  50%       { transform: translateX(-50%) translateY(6px); }
}

@media (max-width: 768px) {
  .hero { padding: 72px 0 64px; }
  .hero__metrics { gap: var(--s5); }
  .hero__metric-divider { display: none; }
  .hero__cta-group { flex-direction: column; align-items: stretch; }
  .hero__cta-primary,
  .hero__cta-secondary { width: 100%; justify-content: center; }
}

/* ============================================================
   SEZIONE PROBLEMA
   ============================================================ */

.section-problema {
  background:
    linear-gradient(to right, rgba(255,255,255,0.88) 0%, rgba(255,255,255,0.72) 100%),
    url('../img/Margini migliori.webp') center / cover no-repeat;
  border-top: 4px solid var(--color-border-dark);
}

.section-problema__intro { color: var(--color-text-body); }

.section-problema__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s6);
  margin-bottom: var(--s7);
}

.problema-card {
  background: var(--color-bg-section);
  border: 1px solid var(--color-border-dark);
  border-radius: var(--radius-lg);
  padding: var(--s6);
  transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition);
}
.problema-card:hover {
  border-color: var(--color-primary);
  box-shadow: var(--shadow-card-hover);
  transform: translateY(-3px);
}

.problema-card__icon {
  width: 52px;
  height: 52px;
  background: var(--color-primary-soft);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-primary);
  margin-bottom: var(--s4);
}
.problema-card__title { margin-bottom: var(--s3); }
.problema-card__body  { color: var(--color-text-muted); font-size: 0.9375rem; }

.section-problema__cta-wrap { text-align: center; }

/* 5 goal cards */
.section-problema__goals {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--s4);
  margin-bottom: var(--s7);
  align-items: start;
}

.goal-card {
  background: rgba(255,255,255,0.82);
  border: 1px solid var(--color-border-dark);
  border-top: 3px solid var(--color-accent);
  border-radius: var(--radius-md);
  padding: var(--s5) var(--s4);
  display: flex;
  flex-direction: column;
  gap: var(--s3);
  backdrop-filter: blur(4px);
}

.goal-card__num {
  font-family: var(--font-display);
  font-size: 0.6875rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  color: var(--color-accent);
}

.goal-card__text {
  font-size: 0.875rem;
  line-height: 1.6;
  color: var(--color-text-body);
}

@media (max-width: 1100px) {
  .section-problema__goals { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 768px) {
  .section-problema__grid  { grid-template-columns: 1fr; }
  .section-problema__goals { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 480px) {
  .section-problema__goals { grid-template-columns: 1fr; }
}

/* ============================================================
   SEZIONE SOLUZIONE
   ============================================================ */

.section-soluzione {
  background:
    linear-gradient(to right, rgba(255,255,255,0.30) 0%, rgba(255,255,255,0.10) 100%),
    url('../img/Azienda funziona.webp') center / cover no-repeat;
  border-top: 4px solid var(--color-border-dark);
}

.section-soluzione__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s5);
  margin-bottom: var(--s7);
}

.servizio-card {
  background: var(--color-bg-page);
  border: 1px solid var(--color-border-dark);
  border-radius: var(--radius-lg);
  padding: var(--s6);
  display: flex;
  flex-direction: column;
  gap: var(--s4);
  transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition);
}
.servizio-card:hover {
  border-color: var(--color-primary);
  box-shadow: var(--shadow-card-hover);
  transform: translateY(-4px);
}

.servizio-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.servizio-card__icon {
  width: 48px;
  height: 48px;
  background: var(--color-primary-soft);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-primary);
  flex-shrink: 0;
}
.servizio-card__tag {
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  background: var(--color-bg-section);
  border-radius: var(--radius-pill);
  padding: 4px 12px;
}
.servizio-card__title { font-size: 1.0625rem; }
.servizio-card__body  { color: var(--color-text-muted); font-size: 0.9375rem; flex: 1; }
.servizio-card__link  {
  font-family: var(--font-display);
  font-size: 0.875rem;
  font-weight: 700;
  color: var(--color-primary);
  transition: color var(--transition-fast);
  align-self: flex-start;
}
.servizio-card__link:hover { color: var(--color-primary-dark); }

.section-soluzione__cta-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--s4);
  flex-wrap: wrap;
}

@media (max-width: 768px) {
  .section-soluzione__grid { grid-template-columns: 1fr; }
  .section-soluzione__cta-wrap { flex-direction: column; align-items: stretch; }
  .section-soluzione__cta-wrap .btn { text-align: center; justify-content: center; }
}

/* ============================================================
   SEZIONE RISULTATI
   ============================================================ */

.section-risultati {
  background:
    linear-gradient(to right, rgba(255,255,255,0.30) 0%, rgba(255,255,255,0.10) 100%),
    url('../img/Marketig funziona.webp') center / cover no-repeat;
  border-top: 4px solid var(--color-border-dark);
}
.section-risultati__title  { color: var(--color-text-headline); }
.section-risultati__intro  { color: var(--color-text-muted); font-size: 1.0625rem; }

.section-risultati__metriche {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s5);
  margin-bottom: var(--s8);
}

.metrica-card {
  background: #ffffff;
  border: 1px solid var(--color-border-dark);
  border-radius: var(--radius-lg);
  padding: var(--s6) var(--s5);
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: var(--s2);
  transition: background var(--transition), border-color var(--transition), transform var(--transition);
}
.metrica-card:hover {
  background: var(--color-primary-soft);
  border-color: var(--color-primary);
  transform: translateY(-3px);
}
.metrica-card__valore {
  font-family: var(--font-display);
  font-size: 2.25rem;
  font-weight: 800;
  color: var(--color-accent);
  display: block;
}
.metrica-card__label {
  font-size: 0.875rem;
  color: var(--color-text-muted);
  line-height: 1.4;
}

.section-risultati__casi-title {
  color: var(--color-text-headline);
  text-align: center;
  margin-bottom: var(--s6);
}

.casi-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s5);
}

.caso-card {
  background: #ffffff;
  border: 1px solid var(--color-border-dark);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition);
}
.caso-card:hover {
  border-color: var(--color-primary);
  box-shadow: var(--shadow-card-hover);
  transform: translateY(-3px);
}
.caso-card__placeholder {
  padding: var(--s7) var(--s5);
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: var(--s3);
  min-height: 200px;
  align-items: center;
  justify-content: center;
}
.caso-card__placeholder span {
  font-family: var(--font-display);
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-primary);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.caso-card__placeholder p {
  font-size: 0.875rem;
  color: var(--color-text-muted);
}

@media (max-width: 1024px) {
  .section-risultati__metriche { grid-template-columns: repeat(2, 1fr); }
  .casi-grid { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
  .section-risultati__metriche { grid-template-columns: 1fr 1fr; }
}

/* ============================================================
   SEZIONE CHI SIAMO
   ============================================================ */

.section-chi-siamo {
  background: linear-gradient(160deg, #F7F9FC 0%, #EEF3FA 100%);
  border-top: 4px solid var(--color-border-dark);
}

.section-chi-siamo__grid {
  display: grid;
  grid-template-columns: 55fr 45fr;
  gap: 5rem;
  align-items: center;
}

.section-chi-siamo__content .section-label { margin-bottom: var(--s3); }
.section-chi-siamo__title { margin-bottom: var(--s6); }
.section-chi-siamo__items {
  display: flex;
  flex-direction: column;
  gap: var(--s5);
  margin-bottom: var(--s6);
}
.chi-siamo-item { padding-left: var(--s5); border-left: 3px solid var(--color-primary); }
.chi-siamo-item__title { margin-bottom: var(--s2); }
.chi-siamo-item__body  { color: var(--color-text-muted); font-size: 0.9375rem; }

.section-chi-siamo__visual { position: relative; }

.chi-siamo-img-wrap {
  position: relative;
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
}
.chi-siamo-img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: var(--radius-xl);
}

/* Badge sovrapposti all'immagine */
.chi-siamo-badge {
  position: absolute;
  background: rgba(255,255,255,0.96);
  border: 1px solid var(--color-border-dark);
  border-radius: var(--radius-md);
  padding: 12px 16px;
  display: flex;
  align-items: center;
  gap: 12px;
  box-shadow: var(--shadow-md);
  backdrop-filter: blur(6px);
  max-width: 210px;
}
.chi-siamo-badge--tl { top: 20px;    left: -20px;  }
.chi-siamo-badge--br { bottom: 20px; right: -20px; }

.chi-siamo-badge__icon {
  width: 38px;
  height: 38px;
  background: var(--color-primary-soft);
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-primary);
  flex-shrink: 0;
}
.chi-siamo-badge strong {
  display: block;
  font-family: var(--font-display);
  font-size: 0.8125rem;
  font-weight: 700;
  color: var(--color-text-headline);
  margin-bottom: 2px;
  white-space: nowrap;
}
.chi-siamo-badge span {
  font-size: 0.75rem;
  color: var(--color-text-muted);
  line-height: 1.3;
  white-space: nowrap;
}

@media (max-width: 1024px) {
  .section-chi-siamo__grid { grid-template-columns: 1fr; gap: 3rem; }
  .chi-siamo-badge--tl { left: 10px; }
  .chi-siamo-badge--br { right: 10px; }
}
@media (max-width: 640px) {
  .chi-siamo-badge { display: none; }
}

/* ============================================================
   SEZIONE CTA FINALE
   ============================================================ */

.section-cta {
  background:
    linear-gradient(to right, rgba(255,255,255,0.96) 0%, rgba(255,255,255,0.80) 100%),
    url('../img/business.webp') center / cover no-repeat;
  border-top: 4px solid var(--color-border-dark);
}

.section-cta__grid {
  display: grid;
  grid-template-columns: 45fr 55fr;
  gap: 5rem;
  align-items: start;
}

.section-cta__title  { margin-bottom: var(--s4); }
.section-cta__subtitle {
  font-size: 1.0625rem;
  font-weight: 600;
  color: var(--color-primary);
  margin-bottom: var(--s4);
}
.section-cta__body { color: var(--color-text-muted); margin-bottom: var(--s5); }
.section-cta__benefits {
  display: flex;
  flex-direction: column;
  gap: var(--s3);
}
.section-cta__benefits li {
  display: flex;
  align-items: center;
  gap: var(--s3);
  font-size: 0.9375rem;
  color: var(--color-text-body);
}
.section-cta__benefits svg { color: var(--color-primary); flex-shrink: 0; }

/* FORM */
.contact-form {
  background: var(--color-bg-page);
  border: 1px solid var(--color-border-dark);
  border-radius: var(--radius-xl);
  padding: var(--s7);
  box-shadow: var(--shadow-md);
}

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s4);
}
.form-group { display: flex; flex-direction: column; gap: 6px; margin-bottom: var(--s4); }
.form-label {
  font-family: var(--font-display);
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-text-headline);
}
.form-input,
.form-textarea {
  width: 100%;
  border: 1.5px solid var(--color-border-dark);
  border-radius: var(--radius-sm);
  padding: 10px 14px;
  font-family: var(--font-body);
  font-size: 0.9375rem;
  color: var(--color-text-body);
  background: var(--color-bg-page);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
  outline: none;
}
.form-input:focus,
.form-textarea:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(15,128,96,0.12);
}
.form-textarea { resize: vertical; min-height: 120px; }

.contact-form__submit { width: 100%; margin-top: var(--s2); margin-bottom: var(--s4); }

.contact-form__privacy {
  font-size: 0.8125rem;
  color: var(--color-text-muted);
  text-align: center;
}
.contact-form__privacy a {
  color: var(--color-primary);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.contact-form__feedback {
  margin-top: var(--s4);
  padding: var(--s4);
  border-radius: var(--radius-sm);
  font-size: 0.9375rem;
  text-align: center;
}
.contact-form__feedback.is-success {
  background: var(--color-primary-soft);
  color: var(--color-primary-dark);
  border: 1px solid rgba(15,128,96,0.25);
}
.contact-form__feedback.is-error {
  background: #FEF2F2;
  color: #B91C1C;
  border: 1px solid #FECACA;
}

@media (max-width: 1024px) {
  .section-cta__grid { grid-template-columns: 1fr; gap: 3rem; }
}
@media (max-width: 640px) {
  .form-row { grid-template-columns: 1fr; }
  .contact-form { padding: var(--s6) var(--s5); }
}

