/* ==========================================================================
   Design System Showcase - Override CIFA
   Solo layout e struttura. Atomi (btn, link, input) usati dal design system.
   Token: var(--semantic-*), var(--baseline-*)
   ========================================================================== */

.design-system-showcase {
  background-color: var(--semantic-background);
  color: var(--typography-body);
  padding: var(--baseline-6) var(--baseline-4);
  min-height: 100vh;
}

.design-system-section {
  display: flex;
  flex-direction: column;
  gap: var(--baseline-4);
  margin-bottom: var(--baseline-8);
}

.design-system-section:last-child {
  margin-bottom: 0;
}

.section-title-block {
  display: flex;
  flex-direction: column;
  gap: var(--baseline-3);
  padding-bottom: var(--baseline-3);
  border-bottom: 1px solid var(--semantic-border);
}

.section-title {
  font-family: var(--font-body-settings);
  font-size: var(--h3-size);
  line-height: var(--h3-line);
  color: var(--typography-heading);
  margin: 0;
}

.typography-block {
  display: flex;
  flex-direction: column;
  gap: var(--baseline-2);
  padding-top: var(--baseline-2);
}

.typography-item {
  display: flex;
  flex-direction: column;
  gap: var(--baseline-2);
  padding-top: var(--baseline-2);
  padding-bottom: var(--baseline-2);
  border-bottom: 1px solid var(--semantic-border);
}

.typography-item:first-child {
  padding-top: 0;
}

.typography-item:last-child {
  padding-bottom: 0;
  border-bottom: none;
}

.typography-body-block {
  display: flex;
  flex-direction: column;
  gap: var(--baseline-2);
  justify-content: center;
}

.body-large {
  color: var(--typography-body);
  line-height: var(--line-height-body);
  margin: 0;
}

.body-small {
  color: var(--typography-body-light);
  line-height: var(--line-height-body);
  margin: 0;
}

.buttons-row {
  align-items: flex-start;
}

.buttons-group {
  display: flex;
  flex-wrap: wrap;
  gap: var(--baseline);
  align-items: center;
}

.links-content {
  display: flex;
  flex-wrap: wrap;
  gap: var(--baseline-8);
}

.links-block {
  display: flex;
  flex-wrap: wrap;
  gap: var(--baseline-5);
  align-items: center;
}

.icons-grid {
  display: flex;
  flex-wrap: wrap;
  gap: var(--baseline-8);
  align-items: center;
}


.components-row {
  align-items: stretch;
}

.component-card {
  display: flex;
  flex-direction: column;
  gap: var(--baseline-2);
  padding: var(--baseline-5);
  border-radius: var(--rounded-large);
  min-height: 100%;
}

.component-card-surface {
  background-color: var(--semantic-surface);
}

.component-card-primary {
  background-color: var(--semantic-surface-primary);
  border: 1px solid var(--semantic-border);
}

.component-label {
  font-family: var(--font-body-settings);
  color: var(--typography-heading-pre);
  margin: 0;
}

.ui-accordion-list {
  display: flex;
  flex-direction: column;
  gap: var(--baseline);
}

.ui-accordion-item {
  display: flex;
  flex-direction: column;
  gap: var(--baseline);
  padding-bottom: var(--baseline);
  border-bottom: 1px solid var(--semantic-border);
}

.ui-accordion-item:last-child {
  padding-bottom: 0;
  border-bottom: none;
}

.ui-accordion-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
}


.component-body {
  font-family: var(--font-body-settings);
  color: var(--typography-body);
  line-height: var(--line-height-body);
  margin: 0;
}

.component-buttons-row {
  display: flex;
  gap: var(--baseline-2);
  align-items: center;
  flex-wrap: wrap;
}

.pagination-dots {
  display: flex;
  gap: var(--baseline-2);
  align-items: center;
}

.pagination-dot {
  width: var(--baseline-2);
  height: var(--baseline-2);
  border-radius: 50%;
  background-color: var(--semantic-surface);
  border: 1px solid var(--semantic-border);
  flex-shrink: 0;
}

.pagination-dot-active {
  background-color: var(--semantic-primary);
  border-color: var(--semantic-primary);
}

.form-content {
  display: flex;
  flex-direction: column;
  gap: var(--baseline-3);
}

<<<<<<< HEAD
.form-fields-row {
  align-items: flex-start;
}

.form-fieldset {
  border: none;
=======
.ds-icon-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--baseline-3);
  align-items: center;
}

/* Dimensioni icone: layout only, colore da token — MAI font-size raw */
.ds-icon {
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--semantic-icon-clr);
}

/* ── 5. Components ── */
.ds-comp-row {
  gap: var(--baseline-4);
}

.ds-comp-card {
  border-radius: var(--rounded-large);
  padding: var(--baseline-4);
  display: flex;
  flex-direction: column;
  gap: var(--baseline-3);
  height: 100%;
  color: var(--typography-body);
}

.ds-comp-card-dark {
  background-color: var(--semantic-surface-medium);
  border: 1px solid var(--semantic-border);
}

.ds-comp-card-primary {
  background-color: var(--semantic-surface-primary-strong);
  border: 1px solid var(--semantic-primary);
}

/* Lista accordion */
.ds-acc-list {
  list-style: none;
>>>>>>> 08f2774701128d721a271e27205890b72be3cd07
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
<<<<<<< HEAD
  gap: var(--baseline);
}

/* Stato focus (estetica con token design system) */
.form-fieldset-focus input {
  border-color: var(--form-input-border-clr-focus);
}

.form-label {
  color: var(--form-fieldset-label-clr);
  font-size: var(--label-form-font-size);
  line-height: inherit;
}

.form-fieldset-inline {
  flex-direction: row;
  flex-wrap: wrap;
  gap: var(--baseline-2);
}

.form-radio-label,
.form-checkbox-label {
  display: inline-flex;
  align-items: center;
  gap: var(--baseline-2);
  cursor: pointer;
  color: var(--form-input-clr);
}

.form-radios,
.form-checkboxes {
  display: flex;
  flex-wrap: wrap;
  gap: var(--baseline-2);
}
=======
}

.ds-acc-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--baseline) 0;
  border-bottom: 1px solid var(--semantic-border);
}

/* Accordion label: tipografia via classi HTML (.upper .bold), qui solo colore + spacing */
.ds-acc-label {
  color: var(--typography-heading);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.ds-acc-icon {
  color: var(--semantic-icon-clr);
}

/* Card preheading: tipografia via classi HTML (.upper .bold), qui solo colore */
.ds-card-preheading {
  display: block;
  color: var(--semantic-primary);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.ds-card-heading {
  margin-bottom: 0;
}

/* Bottoni dentro la card */
.ds-comp-btn-group {
  display: flex;
  flex-wrap: wrap;
  gap: var(--baseline);
  align-items: center;
}

/* Navigation dots */
.ds-dots {
  display: flex;
  gap: var(--baseline);
  align-items: center;
  margin-top: auto;
}

.ds-dot {
  display: block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background-color: var(--semantic-border-medium);
}

.ds-dot-active {
  background-color: var(--semantic-primary);
  width: 8px;
  height: 8px;
}

/* ── 6. Forms ── */
/* Usa i tag nativi: input, select, label, checkbox, radio
   — già stilati da style.css. NON ricreare componenti custom. */

.ds-form-section {
  display: flex;
  flex-direction: column;
  gap: var(--baseline-3);
}

.ds-form-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--baseline-3);
}

.ds-field-group {
  display: flex;
  flex-direction: column;
  gap: var(--baseline);
  flex: 1;
  min-width: 0;
}

/* Label form: usa token definiti — MAI font-size/weight raw */
.ds-field-label {
  color: var(--form-fieldset-label-clr);
  font-size: var(--label-form-font-size);
  font-weight: var(--font-headings-weight-settings);
}

/* Stato focused esplicito (demo statico — mostra come appare l'input in focus) */
.ds-input-demo-focus {
  border-width: 2px;
  border-color: var(--form-input-border-clr-focus);
  box-shadow: 0 0 0 2px var(--semantic-primary-light);
}

.ds-radio-group {
  display: flex;
  flex-direction: column;
  gap: var(--baseline);
}

/* ── Responsive ── */
@media (max-width: 767px) {
  .ds-form-row {
    flex-direction: column;
  }

  .ds-comp-card {
    margin-bottom: var(--baseline-3);
  }

  .ds-btn-group {
    padding: var(--baseline-2);
  }
}

/* ==========================================================================
   Sezione CTA — Figma node 4320:7584
   Background full-bleed: immagine + overlay dark + gradiente inferiore.
   Contenuto: heading con barra arancione, descrizione, bottone.
   ========================================================================== */

/* Sezione principale — flex per centratura verticale */
.cta-section {
  position: relative;
  min-height: 465px;
  display: flex;
  align-items: center;
  overflow: hidden;
  padding: var(--baseline-6) 0;
}

/* Background image wrapper — position:absolute consentito (elemento decorativo) */
.cta-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.cta-bg-img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
}

/* Overlay scuro semi-trasparente (decorativo) */
.cta-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.4);
  z-index: 1;
}

/* Gradiente inferiore — sfuma verso il colore di sfondo scuro (decorativo) */
.cta-section::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 76%;
  background: linear-gradient(to bottom, transparent, var(--semantic-background));
  z-index: 2;
}

/* Contenuto sopra gli overlay */
.cta-content {
  position: relative;
  z-index: 3;
  display: flex;
  flex-direction: column;
  gap: var(--baseline-4);
  max-width: 550px;
}

/* Header con barra arancione + titolo */
.cta-header {
  display: flex;
  align-items: stretch;
  gap: var(--baseline-2);
}

.cta-accent-bar {
  width: 6px;
  min-height: 4rem;
  background-color: var(--semantic-primary);
  border-radius: var(--rounded-small);
  flex-shrink: 0;
}

.cta-header .h2 {
  margin: 0;
}

/* Testo descrittivo — dimensione 18px */
.cta-description {
  font-size: 1.125rem;
  line-height: 1.5;
  margin: 0;
}

/* Responsive — testo a larghezza piena su mobile */
@media (max-width: 767px) {
  .cta-content {
    max-width: 100%;
  }
}
>>>>>>> 08f2774701128d721a271e27205890b72be3cd07