/* youareupbenefit – rebuilt static site (desktop + mobile) */
:root{
  --bg: #fafaf7;
  --text: #494848;
  --muted: rgba(0,0,0,.62);
  --card: #ffffff;
  --border: rgba(0,0,0,.10);
  --shadow: 0 10px 30px rgba(0,0,0,.10);
  --brand: #c3e7b0;
  --max: 1100px;
  --radius: 14px;
  --header-h: 64px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family: "Montserrat", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  background: var(--bg);
  color: var(--text);
  line-height: 1.55;
  overflow-x:hidden;
}
/* subtle “film grain” overlay (premium, very light) */
body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:9999;
  opacity:.06;
  mix-blend-mode:multiply;
  background-image:
    radial-gradient(circle at 20% 10%, rgba(0,0,0,.18) 0 1px, transparent 2px),
    radial-gradient(circle at 80% 30%, rgba(0,0,0,.14) 0 1px, transparent 2px),
    radial-gradient(circle at 40% 70%, rgba(0,0,0,.12) 0 1px, transparent 2px),
    radial-gradient(circle at 60% 90%, rgba(0,0,0,.14) 0 1px, transparent 2px);
  background-size: 140px 140px, 160px 160px, 180px 180px, 200px 200px;
}
@media (prefers-reduced-motion: reduce){
  body::before{opacity:.03;}
}
img{max-width:100%;height:auto;display:block;}
a{color:inherit;}

.container{max-width:var(--max);margin:0 auto;padding:0 16px;}
.section{padding:56px 0;}
.section--tight{padding:34px 0;}
.section-title{
  text-align:left;
  font-size:32px;
  line-height:1.15;
  margin:0 0 18px;
  letter-spacing:.2px;
}
.lead{max-width:860px;margin:0 auto 18px;text-align:center;color:var(--muted);}

/* About (non centrato) */
.about .container{max-width:var(--max);}
.about__head{margin-bottom:12px;}
.about__title{
  margin:0;
  font-size:34px;
  line-height:1.15;
  letter-spacing:.2px;
  text-align:left;
}
.about__single{
  max-width: 980px;
  color: rgba(0,0,0,.72);
  font-size:16px;
  line-height:1.75;
}
.about__single p{
  margin:0 0 14px;
}

/* Variante A (default): 2 colonne “editoriali” su desktop */
.about[data-about-style="columns"] .about__single{
  column-count: 2;
  column-gap: 34px;
  column-rule: 1px solid rgba(0,0,0,.06);
}
.about[data-about-style="columns"] .about__single p{break-inside: avoid;}

/* Variante B: “classic” una colonna larga (più ariosa) */
.about[data-about-style="classic"] .about__single{
  max-width: 860px;
  font-size:17px;
}

/* Variante C: “blocks” (3 paragrafi come sezioni pulite, niente centrature) */
.about[data-about-style="blocks"] .about__single{
  max-width: 980px;
  font-size:16px;
  line-height:1.7;
}
.about[data-about-style="blocks"] .about__single p{
  margin:0 0 14px;
  padding:16px 16px;
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 16px;
  box-shadow: 0 10px 22px rgba(0,0,0,.06);
}
.about[data-about-style="blocks"] .about__single p strong{
  color: rgba(0,0,0,.86);
}
.about[data-about-style="blocks"] .about__single p:nth-child(1){
  border-left: 6px solid rgba(195,231,176,.95);
}
.about[data-about-style="blocks"] .about__single p:nth-child(2){
  border-left: 6px solid rgba(0,0,0,.10);
}
.about[data-about-style="blocks"] .about__single p:nth-child(3){
  border-left: 6px solid rgba(0,0,0,.10);
}
@media (max-width: 600px){
  .about__title{font-size:28px;}
}
@media (max-width: 900px){
  .about[data-about-style="columns"] .about__single{
    column-count: 1;
    column-rule: 0;
  }
  .about[data-about-style="blocks"] .about__single p{padding:14px 14px;}
}

/* Header */
.header{
  position:sticky;
  top:0;
  z-index:2000;
  background: linear-gradient(135deg, rgb(250,250,247) 0%, rgb(250,250,247) 100%);
  border-bottom:1px solid rgba(0,0,0,.06);
}
.header__inner{
  min-height:var(--header-h);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  position:relative;
}
.brand{
  display:flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
}
.brand__mark{display:none;}
.brand__text{font-weight:700;letter-spacing:.2px;}

/* Language dropdown (flags kept) */
.lang-menu{
  position:relative;
}
.lang-menu summary{
  list-style:none;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  gap:8px;
  height:36px;
  padding:0 12px;
  border-radius: 12px;
  border:1px solid rgba(0,0,0,.12);
  background:#fff;
  font-weight:600;
  font-size:13px;
  color: rgba(0,0,0,.78);
  user-select:none;
}
.lang-menu summary::-webkit-details-marker{display:none;}
.lang-menu summary::after{
  content:"▾";
  font-size:12px;
  color: rgba(0,0,0,.55);
}
.lang-menu[open] summary{
  border-color: rgba(0,0,0,.22);
  box-shadow: 0 10px 18px rgba(0,0,0,.10);
}
.lang-menu__list{
  position:absolute;
  right:0;
  top:calc(100% + 8px);
  min-width: 160px;
  background:#fff;
  border:1px solid rgba(0,0,0,.10);
  border-radius: 14px;
  box-shadow: var(--shadow);
  padding:8px;
  z-index:2100;
}
.lang-menu__item{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 10px;
  border-radius: 12px;
  text-decoration:none;
  color: rgba(0,0,0,.78);
  font-weight:600;
  font-size:13px;
}
.lang-menu__item:hover{background:rgba(0,0,0,.04);}
.lang-menu__flag{font-size:18px;line-height:1;}
.lang-menu__icon{
  display:block;
  flex-shrink:0;
  width:auto;
  height:14px;
  border-radius:2px;
  box-shadow:0 0 0 1px rgba(0,0,0,.08);
}
.lang-menu__code{
  font-weight:600;
  font-size:13px;
  letter-spacing:.02em;
}
.visually-hidden{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

.nav{
  display:flex;
  align-items:center;
  gap:18px;
}
.nav a{
  text-decoration:none;
  font-weight:500;
  font-size:14px;
  padding:10px 10px;
  border-radius:10px;
  position:relative;
}
.nav a::after{
  content:"";
  position:absolute;
  left:10px;
  right:10px;
  bottom:7px;
  height:1px;
  background:rgba(0,0,0,.45);
  transform: scaleX(0);
  transform-origin:left;
  transition: transform 220ms ease;
}
.nav a:hover{background:rgba(0,0,0,.04);text-decoration:none;}
.nav a:hover::after{transform:scaleX(1);}

.nav-toggle{
  display:none;
  height:40px;
  padding:0 12px;
  border:1px solid rgba(0,0,0,.16);
  border-radius:12px;
  background:#fff;
  font:inherit;
  cursor:pointer;
}
.nav-toggle__icon{
  display:inline-flex;
  flex-direction:column;
  justify-content:center;
  gap:4px;
  width:18px;
}
.nav-toggle__icon span{
  display:block;
  height:2px;
  width:18px;
  background: rgba(0,0,0,.70);
  border-radius:999px;
}

@media (max-width: 900px){
  .nav-toggle{display:inline-flex;align-items:center;gap:10px;}
  .nav{
    position:fixed;
    left:16px;
    right:16px;
    top:calc(var(--header-h) + 10px);
    background:#fff;
    border:1px solid rgba(0,0,0,.10);
    border-radius:16px;
    box-shadow: var(--shadow);
    padding:10px;
    display:none;
    flex-direction:column;
    gap:6px;
  }
  .nav.is-open{display:flex;}
  .nav a{width:100%;text-align:center;}
}

/* Desktop: menu centrato, logo resta a sinistra */
@media (min-width: 901px){
  .nav{
    position:absolute;
    left:50%;
    transform:translateX(-50%);
    flex-wrap:nowrap;
    white-space:nowrap;
    gap:14px;
  }
  .nav a{
    padding:10px 8px;
    font-size:13px;
  }
}

/* Hero */
.hero{
  background: linear-gradient(135deg, rgb(195,231,176) 0%, rgb(195,231,176) 100%);
  position:relative;
  overflow:hidden;
}
.hero::after{
  content:"";
  position:absolute;
  inset:-20%;
  background:
    radial-gradient(closest-side at 30% 35%, rgba(255,255,255,.28), transparent 60%),
    radial-gradient(closest-side at 70% 55%, rgba(0,0,0,.06), transparent 62%);
  transform: translate3d(0,0,0);
  pointer-events:none;
  opacity:.9;
}
.hero__wrap{
  padding:34px 0;
}
.hero__panel{
  background: transparent;
  border: 0;
  border-radius: var(--radius);
  overflow:hidden;
  box-shadow: none;
}
.hero__logo{
  width:100%;
  aspect-ratio: 16 / 6;
  background: transparent;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:22px 16px;
}
.hero__logo-inner{
  width:min(920px, 100%);
  border-radius: 18px;
  border: 0;
  background: transparent;
  box-shadow: none;
  padding: clamp(26px, 4vw, 44px) 16px;
  text-align:center;
  overflow:hidden;
  position:relative;
}
.hero__logo-inner{
  transform: translate3d(0, var(--hero-shift, 0px), 0);
  transition: transform 180ms ease;
  will-change: transform;
}
@media (prefers-reduced-motion: reduce){
  .hero__logo-inner{transition:none;transform:none;}
}

/* Cursor glow (desktop only) */
.cursor-glow{
  position:fixed;
  left:0;top:0;
  width:520px;height:520px;
  margin-left:-260px;margin-top:-260px;
  border-radius:999px;
  pointer-events:none;
  z-index:9998;
  background: radial-gradient(circle, rgba(195,231,176,.28), rgba(195,231,176,0) 60%);
  opacity:0;
  transition: opacity 240ms ease;
  mix-blend-mode:multiply;
}
body.has-cursor-glow .cursor-glow{opacity:.9;}
@media (max-width: 900px){
  .cursor-glow{display:none;}
}
.hero__logo-big{
  font-weight:800;
  letter-spacing:-0.02em;
  color: rgba(255,255,255,.95);
  font-size: clamp(44px, 6vw, 88px);
  line-height: 1;
  opacity:0;
}
.hero__logo-sub{
  margin-top: 10px;
  font-weight:400;
  letter-spacing: .38em;
  text-transform: lowercase;
  color: rgba(0,0,0,.46);
  font-size: clamp(12px, 1.5vw, 16px);
  opacity:0;
}

/* === HERO ANIMATIONS (scegli con body[data-hero-anim]) === */
body[data-hero-anim="wipe"] .hero__logo-big{
  opacity:1;
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 18%, #000 82%, transparent 100%);
  mask-image: linear-gradient(90deg, transparent 0%, #000 18%, #000 82%, transparent 100%);
  -webkit-mask-size: 220% 100%;
  mask-size: 220% 100%;
  -webkit-mask-position: 120% 0%;
  mask-position: 120% 0%;
  animation: heroWipe 1200ms cubic-bezier(.2,.9,.2,1) 80ms forwards;
}
body[data-hero-anim="wipe"] .hero__logo-sub{
  opacity:0;
  transform: translateY(10px);
  animation: heroFadeUp 700ms cubic-bezier(.2,.9,.2,1) 520ms forwards;
}
@keyframes heroWipe{
  0%{opacity:0;filter:blur(10px);transform:scale(1.03);-webkit-mask-position:120% 0%;mask-position:120% 0%;}
  55%{opacity:1;filter:blur(2px);transform:scale(1.0);}
  100%{opacity:1;filter:blur(0);transform:scale(1);-webkit-mask-position:-20% 0%;mask-position:-20% 0%;}
}
@keyframes heroFadeUp{to{opacity:1;transform:translateY(0);}}

/* 2) “Film burn” leggero (glow + grain + sweep) */
body[data-hero-anim="film"] .hero__logo-inner::before{
  content:"";
  position:absolute;
  inset:-40%;
  background: radial-gradient(closest-side, rgba(255,255,255,.18), rgba(255,255,255,0) 70%);
  transform: translateX(-35%) rotate(12deg);
  opacity:0;
  pointer-events:none;
  animation: heroLight 1400ms cubic-bezier(.2,.9,.2,1) 180ms forwards;
}
body[data-hero-anim="film"] .hero__logo-big{
  opacity:0;
  filter: blur(10px);
  transform: translateY(14px) scale(1.05);
  animation: heroCineTitle 1100ms cubic-bezier(.16,1,.3,1) 90ms forwards;
}
body[data-hero-anim="film"] .hero__logo-sub{
  opacity:0;
  filter: blur(8px);
  transform: translateY(12px) scale(1.02);
  animation: heroCineSub 1100ms cubic-bezier(.16,1,.3,1) 260ms forwards;
}
@keyframes heroCineTitle{
  0%{opacity:0;filter:blur(12px);transform:translateY(16px) scale(1.06);letter-spacing:.06em;}
  60%{opacity:1;filter:blur(2px);transform:translateY(-2px) scale(1.00);letter-spacing:-0.02em;}
  100%{opacity:1;filter:blur(0);transform:translateY(0) scale(1);letter-spacing:-0.02em;}
}
@keyframes heroCineSub{
  0%{opacity:0;filter:blur(10px);transform:translateY(14px) scale(1.03);letter-spacing:.55em;}
  70%{opacity:1;filter:blur(1px);transform:translateY(0) scale(1);letter-spacing:.40em;}
  100%{opacity:1;filter:blur(0);transform:translateY(0) scale(1);letter-spacing:.38em;}
}
@keyframes heroLight{
  0%{opacity:0;transform:translateX(-40%) rotate(12deg) scale(.9);}
  30%{opacity:.85;}
  100%{opacity:0;transform:translateX(40%) rotate(12deg) scale(1.05);}
}

/* 3) “Minimal” (solo fade + micro slide, super sobria) */
body[data-hero-anim="minimal"] .hero__logo-big{
  transform: translateY(8px);
  animation: heroMinimal 5200ms cubic-bezier(.2,.9,.2,1) 350ms forwards;
}
body[data-hero-anim="minimal"] .hero__logo-sub{
  transform: translateY(8px);
  animation: heroMinimal 5200ms cubic-bezier(.2,.9,.2,1) 1450ms forwards;
}
@keyframes heroMinimal{to{opacity:1;transform:translateY(0);}}

@media (prefers-reduced-motion: reduce){
  .hero__logo-inner::before{animation:none;display:none;}
  .hero__logo-big,.hero__logo-sub{
    animation:none !important;
    opacity:1 !important;
    transform:none !important;
    filter:none !important;
    -webkit-mask-image:none !important;
    mask-image:none !important;
  }
}
@media (max-width: 600px){
  .hero__logo{aspect-ratio: 16 / 10;}
  .hero__logo-sub{letter-spacing:.28em;}
}

/* Cards / grids */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:stretch;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
@media (max-width: 900px){
  .grid-2,.grid-3{grid-template-columns:1fr;}
}
.media-frame{
  border-radius: 16px;
  overflow:hidden;
  border:0;
  background: transparent;
  aspect-ratio: 4 / 5;
  display:flex;
  align-items:center;
  justify-content:center;
}
.media-frame video{
  width:100%;
  height:100%;
  max-width:100%;
  max-height:100%;
  object-fit:contain;
  background:transparent;
  padding:14px;
  display:block;
}
.media-frame img{
  width:auto;
  height:auto;
  max-width:100%;
  max-height:100%;
  object-fit:contain;
  background:transparent;
  padding:14px;
  display:block;
}
@media (max-width: 600px){
  .media-frame{aspect-ratio: 1 / 1;}
}
.trace__lead{
  max-width: 980px;
  margin: 0;
  color: rgba(0,0,0,.70);
}
.trace-step__kicker{
  display:flex;
  align-items:center;
  gap:10px;
  font-size:12px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:rgba(0,0,0,.50);
  margin-bottom:8px;
}
.trace-step__n{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:26px;height:26px;
  border-radius: 10px;
  border:1px solid rgba(0,0,0,.10);
  background: rgba(195,231,176,.60);
  color: rgba(0,0,0,.70);
  font-weight:800;
  letter-spacing:0;
}
.trace__cta{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:12px;
}
.card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: 0 12px 26px rgba(0,0,0,.08);
  overflow:hidden;
}
.card__body{padding:18px;}
.card__title{margin:0 0 8px;font-size:18px;line-height:1.25;}
.card__text{margin:0;color:var(--muted);}
.list{margin:10px 0 0;padding-left:18px;color:var(--muted);}
.list li{margin:6px 0;}

/* Projects carousel */
.carousel{
  position:relative;
  margin-top:16px;
}
.carousel__viewport{
  overflow:hidden;
  border-radius: var(--radius);
  border:1px solid var(--border);
  background:#fff;
  box-shadow: 0 12px 26px rgba(0,0,0,.08);
}
.carousel__track{
  display:flex;
  transition: transform 360ms ease;
  will-change: transform;
}
.slide{
  min-width:100%;
  padding:18px;
}
.slide__grid{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap:18px;
  align-items:center;
}
@media (max-width: 900px){
  .slide__grid{grid-template-columns:1fr;}
}
.slide__kicker{
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(0,0,0,.45);
  margin:0 0 8px;
}
.slide__title{margin:0 0 10px;font-size:28px;line-height:1.15;}
.slide__desc{margin:0;color:var(--muted);}
.slide__media{
  border-radius: 16px;
  overflow:hidden;
  border:0;
  background: transparent;
  aspect-ratio: 4 / 5;
  display:flex;
  align-items:center;
  justify-content:center;
}
.slide__media img{
  width:auto;
  height:auto;
  max-width:100%;
  max-height:100%;
  object-fit:contain;
  background:transparent;
  padding:14px;
}
.slide__media video{
  width:100%;
  height:100%;
  max-width:100%;
  max-height:100%;
  object-fit:contain;
  background:transparent;
  padding:6px;
  display:block;
}
@media (max-width: 600px){
  .slide__title{font-size:22px;}
  .slide__media{aspect-ratio: 1 / 1;}
}
.carousel__btn{
  position:absolute;
  top:50%;
  transform: translateY(-50%);
  width:44px;height:44px;
  border-radius: 14px;
  border:1px solid rgba(0,0,0,.14);
  background:#fff;
  box-shadow: 0 10px 20px rgba(0,0,0,.12);
  cursor:pointer;
  z-index:5;
}
.carousel__btn:active{transform:translateY(-50%) scale(.98);}
.carousel__btn--prev{left:12px;}
.carousel__btn--next{right:12px;}

/* evita che le frecce coprano troppo contenuto */
.slide{padding-left:62px;padding-right:62px;}
@media (max-width: 900px){
  .slide{padding-left:18px;padding-right:18px;}
  .carousel__btn{top:auto;transform:none;bottom:12px;}
  .carousel__btn--prev{left:12px;}
  .carousel__btn--next{right:12px;}
}
.dots{display:flex;justify-content:center;gap:8px;margin-top:14px;}
.dot{
  width:9px;height:9px;border-radius:999px;
  border:1px solid rgba(0,0,0,.20);
  background:transparent;
  cursor:pointer;
}
.dot.is-active{background:rgba(0,0,0,.55);}

.carousel__progress{
  height:2px;
  border-radius:999px;
  background: rgba(0,0,0,.10);
  overflow:hidden;
  margin:12px auto 0;
  max-width: 420px;
}
.carousel__progress-bar{
  display:block;
  height:100%;
  width: 0%;
  background: rgba(0,0,0,.55);
  transition: width 280ms ease;
}

/* Scroll reveal (minimal, premium) */
.reveal{
  opacity:0;
  transform: translateY(10px);
  transition: opacity 420ms ease, transform 520ms cubic-bezier(.2,.9,.2,1);
  will-change: opacity, transform;
}
.reveal.is-inview{
  opacity:1;
  transform: translateY(0);
}
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1;transform:none;transition:none;}
}

/* Contact */
.contact-box{
  background:#fff;
  border:1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: 0 12px 26px rgba(0,0,0,.08);
  padding:18px;
}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:start;}
@media (max-width: 900px){.contact-grid{grid-template-columns:1fr;}}
.kv{margin:0;color:var(--muted);}
.kv strong{color:var(--text);}

.contact-social{
  display:flex;
  gap:10px;
  margin-top:14px;
  flex-wrap:wrap;
}
.social-btn{
  width:40px;height:40px;
  border-radius: 14px;
  border:1px solid rgba(0,0,0,.14);
  background:#fff;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  box-shadow: 0 10px 20px rgba(0,0,0,.08);
  text-decoration:none;
}
.social-btn--sm{
  width:34px;
  height:34px;
  border-radius:12px;
  box-shadow:none;
}
.social-btn--sm svg{width:18px;height:18px;}
.social-btn svg{width:20px;height:20px;fill:rgba(0,0,0,.72);}
.social-btn:hover{transform:translateY(-1px);box-shadow:0 12px 26px rgba(0,0,0,.10);}

.footer-social{display:inline-flex;gap:8px;align-items:center;}

.contact-logos{
  display:flex;
  gap:14px;
  align-items:center;
  flex-wrap:wrap;
  margin-top:14px;
}
.contact-logos img{
  max-height:44px;
  width:auto;
  display:block;
  filter: saturate(.98);
}

.form{display:grid;gap:12px;}
.field{display:grid;gap:6px;}
.field label{font-size:13px;color:rgba(0,0,0,.68);}
.field input,.field textarea{
  font:inherit;
  padding:10px 12px;
  border-radius: 12px;
  border:1px solid rgba(0,0,0,.16);
  background:#fff;
}
.field textarea{min-height:110px;resize:vertical;}
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  height:42px;
  padding:0 14px;
  border-radius: 12px;
  border:2px solid var(--brand);
  background: var(--brand);
  color:#fff;
  font-weight:700;
  cursor:pointer;
  transition: transform 160ms ease, box-shadow 160ms ease, filter 160ms ease;
}
.btn:hover{filter:saturate(1.05);box-shadow:0 10px 18px rgba(0,0,0,.10);}
.btn:active{transform: translateY(1px);}
.btn--ghost{background:transparent;color:var(--text);}

/* FAQ (details/summary) */
.faq{margin-top: 12px;}
.faq__item{
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 16px;
  box-shadow: 0 10px 22px rgba(0,0,0,.06);
  overflow:hidden;
  margin: 12px 0;
}
.faq__item summary{
  cursor:pointer;
  list-style:none;
  padding: 14px 16px;
  font-weight:600;
  color: rgba(0,0,0,.78);
}
.faq__item summary::-webkit-details-marker{display:none;}
.faq__item summary::after{
  content:"+";
  float:right;
  color: rgba(0,0,0,.55);
  font-weight:800;
}
.faq__item[open] summary::after{content:"–";}
.faq__body{
  padding: 0 16px 14px;
  color: rgba(0,0,0,.66);
  line-height: 1.65;
}
.faq__body strong{color: rgba(0,0,0,.84);}

/* Footer */
.footer{
  border-top:1px solid rgba(0,0,0,.06);
  padding:14px 0 18px;
}
.footer__inner{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
  justify-content:space-between;
  color:rgba(0,0,0,.62);
  font-size:13px;
}
.footer a{color:inherit;text-decoration:underline;}

.footer__left{flex:0 0 auto;}
.footer__links{
  flex:1 1 auto;
  display:flex;
  gap:12px;
  flex-wrap:nowrap;
  justify-content:center;
  min-width: 420px;
}
.footer__right{flex:0 0 auto;}

.footer-logos{
  display:inline-flex;
  gap:12px;
  align-items:center;
}
.footer-logos img{
  max-height:36px;
  width:auto;
  display:block;
}
.footer-logos img[alt*="Confindustria"]{max-height:52px;}

@media (max-width: 900px){
  .footer__links{flex-wrap:wrap;min-width:unset;}
}

/* Cookie banner */
.cookie-banner{
  position:fixed;left:16px;right:16px;bottom:16px;z-index:99999;
  display:none;
  background:rgba(255,255,255,.98);
  border:1px solid rgba(0,0,0,.12);
  box-shadow: var(--shadow);
  border-radius: 14px;
  padding:14px 14px;
}
.cookie-banner.is-open{display:flex;gap:12px;align-items:flex-start;}
.cookie-banner p{margin:0;color:rgba(0,0,0,.72);font-size:13px;line-height:1.35;flex:1;}
.cookie-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end;}
.cookie-actions .btn{height:38px;border-radius:12px;font-weight:700;}
.cookie-actions .btn--ghost{border-color:rgba(0,0,0,.18);}

.modal{
  position:fixed;inset:0;z-index:100000;display:none;align-items:center;justify-content:center;
  background:rgba(0,0,0,.35);
  padding:16px;
}
.modal.is-open{display:flex;}
.modal__panel{
  width:min(560px, 100%);
  background:#fff;
  border-radius: 16px;
  border:1px solid rgba(0,0,0,.12);
  box-shadow: 0 20px 60px rgba(0,0,0,.22);
  overflow:hidden;
}
.modal__head{display:flex;align-items:center;justify-content:space-between;padding:14px 14px;border-bottom:1px solid rgba(0,0,0,.08);}
.modal__head strong{font-size:14px;}
.modal__body{padding:14px;}
.toggle{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:10px 0;border-bottom:1px solid rgba(0,0,0,.06);}
.toggle:last-child{border-bottom:0;}
.toggle small{display:block;color:rgba(0,0,0,.62);margin-top:2px;}
.modal__foot{display:flex;gap:10px;justify-content:flex-end;padding:14px;border-top:1px solid rgba(0,0,0,.08);}
