/* ═══════════════════════════════════════════════════════════════
   INCIPIT – Società Agricola
   style.css  ·  versione 4.0 (production)
   Path hero-bg corretto per struttura website/ (no ../img/)
   ═══════════════════════════════════════════════════════════════ */

:root {
  --green-deep:   #3E5C36;
  --green-mid:    #4A6741;
  --green-soft:   #7A9E72;
  --green-pale:   #C8DABC;
  --green-wash:   #EDF2E8;
  --cream:        #F7F4EE;
  --cream-dark:   #EDE8DF;
  --gold:         #B8924A;
  --gold-light:   #D4AE6E;
  --text-dark:    #1C2318;
  --text-mid:     #3A4A35;
  --text-light:   #6B7E64;
  --white:        #FFFFFF;
  --font-display: 'Cormorant Garamond', Georgia, serif;
  --font-body:    'Inter', system-ui, sans-serif;
  --radius-sm:    4px;
  --radius-md:    12px;
  --radius-lg:    24px;
  --section-pad:  clamp(64px, 10vw, 120px);
  --container:    1140px;
  --gap:          clamp(24px, 4vw, 56px);
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: var(--font-body); font-size: 16px; line-height: 1.7; color: var(--text-dark); background: var(--cream); -webkit-font-smoothing: antialiased; }
img { display: block; max-width: 100%; height: auto; }
a   { color: inherit; text-decoration: none; }
.container { width: min(var(--container), 100% - 48px); margin-inline: auto; }

.reveal { opacity: 0; transform: translateY(24px); transition: opacity 0.7s ease, transform 0.7s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }
.reveal-delay-1 { transition-delay: 0.10s; }
.reveal-delay-2 { transition-delay: 0.20s; }
.reveal-delay-3 { transition-delay: 0.30s; }
.reveal-delay-4 { transition-delay: 0.40s; }
.d1 { transition-delay: 0.10s; }
.d2 { transition-delay: 0.20s; }

.divider { display: flex; align-items: center; justify-content: center; gap: 20px; margin-block: clamp(28px, 5vw, 52px); opacity: 0; transform: translateY(12px); transition: opacity 0.7s ease, transform 0.7s ease; }
.divider.visible { opacity: 1; transform: translateY(0); }
.divider::before, .divider::after { content: ''; flex: 1; height: 1px; background: linear-gradient(to right, transparent, var(--green-pale)); }
.divider::after { background: linear-gradient(to left, transparent, var(--green-pale)); }
.divider svg { flex-shrink: 0; width: 34px; height: 34px; color: var(--green-soft); animation: spin-slow 14s linear infinite; }
@keyframes spin-slow { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }

.section-label { display: inline-flex; align-items: center; gap: 10px; font-size: 0.7rem; font-weight: 600; letter-spacing: 0.22em; text-transform: uppercase; color: var(--green-soft); margin-bottom: 12px; }
.section-label::before { content: ''; width: 20px; height: 1px; background: currentColor; }
.section-title { font-family: var(--font-display); font-size: clamp(2rem, 4vw, 3.2rem); font-weight: 400; line-height: 1.15; color: var(--green-deep); }
.section-title em { font-style: italic; font-weight: 600; }
.section-body { font-size: 0.95rem; color: var(--text-mid); line-height: 1.85; max-width: 600px; }

.btn-primary { display: inline-flex; align-items: center; gap: 8px; padding: 14px 32px; background: var(--green-mid); color: var(--white); font-family: var(--font-body); font-size: 0.78rem; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; border-radius: var(--radius-sm); transition: background 0.25s, transform 0.2s; }
.btn-primary:hover { background: var(--green-deep); transform: translateY(-1px); }
.btn-ghost { display: inline-flex; align-items: center; gap: 8px; padding: 13px 28px; border: 1.5px solid var(--green-pale); color: var(--cream); font-family: var(--font-body); font-size: 0.78rem; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; border-radius: var(--radius-sm); transition: border-color 0.25s, background 0.25s; }
.btn-ghost:hover { border-color: var(--green-mid); background: var(--green-wash); color: var(--green-mid); }

/* NAV */
.nav { position: fixed; top: 0; left: 0; right: 0; z-index: 100; height: 68px; padding: 0 clamp(20px, 4vw, 40px); display: flex; align-items: center; justify-content: space-between; background: rgba(247,244,238,0.94); backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px); border-bottom: 1px solid transparent; transition: border-color 0.3s, box-shadow 0.3s; }
.nav.scrolled { border-color: var(--cream-dark); box-shadow: 0 2px 20px rgba(62,92,54,0.09); }
.nav-logo { display: flex; align-items: center; gap: 12px; flex-shrink: 0; }
.nav-logo img { height: 40px; width: auto; }
.nav-links { display: flex; align-items: center; gap: 32px; list-style: none; }
.nav-links a { font-size: 0.76rem; font-weight: 500; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-mid); position: relative; padding-bottom: 2px; transition: color 0.2s; }
.nav-links a::after { content: ''; position: absolute; bottom: 0; left: 0; right: 100%; height: 1px; background: var(--green-mid); transition: right 0.3s ease; }
.nav-links a:hover { color: var(--green-mid); }
.nav-links a:hover::after { right: 0; }
.nav-toggle { display: none; flex-direction: column; gap: 5px; cursor: pointer; background: none; border: none; padding: 4px; }
.nav-toggle span { display: block; width: 24px; height: 2px; background: var(--green-mid); border-radius: 2px; transition: transform 0.3s, opacity 0.3s; }
.nav-toggle.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle.open span:nth-child(2) { opacity: 0; }
.nav-toggle.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
.nav-mobile { display: none; position: fixed; inset: 68px 0 0; background: var(--cream); z-index: 99; flex-direction: column; align-items: center; justify-content: center; gap: 40px; }
.nav-mobile.open { display: flex; }
.nav-mobile a { font-family: var(--font-display); font-size: 2.2rem; font-weight: 500; color: var(--green-deep); transition: color 0.2s; }
.nav-mobile a:hover { color: var(--green-mid); }
@media (max-width: 820px) { .nav-links { display: none; } .nav-toggle { display: flex; } }

/* HERO – path img assoluto */
.hero { position: relative; min-height: 100svh; padding-top: 68px; display: grid; place-items: center; overflow: hidden; }
.hero-bg { position: absolute; inset: 0; background-image: url('/img/slide-1.jpg'); background-size: cover; background-position: center 30%; z-index: 0; }
.hero-bg::after { content: ''; position: absolute; inset: 0; background: linear-gradient(to bottom, rgba(30,46,26,0.55) 0%, rgba(30,46,26,0.30) 40%, rgba(30,46,26,0.72) 100%); }
.hero-inner { position: relative; z-index: 1; width: min(var(--container), 100% - 48px); margin-inline: auto; display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: center; padding-block: clamp(48px, 8vw, 96px); }
.hero-eyebrow { display: inline-flex; align-items: center; gap: 10px; font-size: 0.72rem; font-weight: 600; letter-spacing: 0.2em; text-transform: uppercase; color: var(--green-pale); margin-bottom: 20px; }
.hero-eyebrow::before { content: ''; width: 28px; height: 1px; background: var(--green-pale); }
.hero-headline { font-family: var(--font-display); font-size: clamp(3.2rem, 6.5vw, 6rem); font-weight: 300; line-height: 1.05; color: var(--white); margin-bottom: 12px; text-shadow: 0 2px 20px rgba(0,0,0,0.25); }
.hero-headline em { font-style: italic; font-weight: 600; color: var(--green-pale); }
.hero-sub { font-family: var(--font-display); font-size: clamp(1.1rem, 2vw, 1.45rem); font-style: italic; color: rgba(255,255,255,0.8); margin-bottom: 24px; }
.hero-desc { font-size: 0.95rem; color: rgba(255,255,255,0.78); max-width: 440px; line-height: 1.8; margin-bottom: 40px; }
.hero-ctas { display: flex; flex-wrap: wrap; gap: 14px; }
.hero-visual { display: flex; align-items: center; justify-content: center; }
.hero-logo-wrap { position: relative; display: inline-flex; align-items: center; justify-content: center; }
.hero-logo-ring { position: absolute; width: 300px; height: 300px; border: 1px solid rgba(255,255,255,0.2); border-radius: 50%; animation: pulse-ring 4.5s ease-in-out infinite; }
.hero-logo-ring-outer { width: 380px; height: 380px; border-color: rgba(255,255,255,0.08); animation-delay: 0.6s; }
@keyframes pulse-ring { 0%,100% { transform: scale(1); opacity: 0.6; } 50% { transform: scale(1.03); opacity: 1; } }
.hero-logo { width: clamp(160px, 22vw, 240px); position: relative; z-index: 1; filter: drop-shadow(0 4px 24px rgba(0,0,0,0.35)) brightness(0) invert(1); opacity: 0.92; animation: float 6s ease-in-out infinite; }
@keyframes float { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-10px); } }
.hero-badges { grid-column: 1 / -1; display: flex; justify-content: center; gap: clamp(32px, 6vw, 80px); padding-top: 32px; border-top: 1px solid rgba(255,255,255,0.12); margin-top: 16px; }
.hero-badge { text-align: center; }
.hero-badge-num { font-family: var(--font-display); font-size: 2rem; font-weight: 600; color: var(--white); line-height: 1; }
.hero-badge-label { font-size: 0.65rem; font-weight: 500; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(255,255,255,0.6); margin-top: 4px; }
.hero-scroll { position: absolute; bottom: 28px; left: 50%; transform: translateX(-50%); z-index: 2; display: flex; flex-direction: column; align-items: center; gap: 6px; color: rgba(255,255,255,0.5); font-size: 0.65rem; font-weight: 500; letter-spacing: 0.14em; text-transform: uppercase; animation: bounce 2.5s ease-in-out infinite; }
.hero-scroll i { font-size: 1rem; }
@keyframes bounce { 0%,100% { transform: translateX(-50%) translateY(0); } 50% { transform: translateX(-50%) translateY(6px); } }
@media (max-width: 820px) { .hero-inner { grid-template-columns: 1fr; text-align: center; } .hero-eyebrow { justify-content: center; } .hero-desc { margin-inline: auto; } .hero-ctas { justify-content: center; } .hero-visual { display: none; } .hero-badges { gap: 28px; } }

/* STORIA */
.storia { padding-block: var(--section-pad); background: var(--white); }
.storia-inner { display: grid; grid-template-columns: 1fr 1fr; gap: var(--gap); align-items: center; }
.storia-content .section-body { margin-top: 20px; }
.storia-quote { border-left: 3px solid var(--green-pale); padding: 4px 0 4px 20px; margin-top: 28px; font-family: var(--font-display); font-size: 1.25rem; font-style: italic; color: var(--green-mid); line-height: 1.5; }
.storia-visual { display: grid; grid-template-columns: 1fr 1fr; grid-template-rows: 220px 220px; gap: 12px; }
.storia-img { border-radius: var(--radius-md); overflow: hidden; }
.storia-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; }
.storia-img:hover img { transform: scale(1.04); }
.storia-img--wide { grid-column: 1 / -1; }
.storia-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin-top: 40px; }
.storia-card { background: var(--green-wash); border-radius: var(--radius-md); padding: 24px 18px; text-align: center; transition: transform 0.3s, box-shadow 0.3s; }
.storia-card:hover { transform: translateY(-3px); box-shadow: 0 8px 24px rgba(62,92,54,0.1); }
.storia-card i { font-size: 1.6rem; color: var(--green-mid); margin-bottom: 10px; display: block; }
.storia-card-title { font-family: var(--font-display); font-size: 1.3rem; font-weight: 600; color: var(--green-deep); margin-bottom: 6px; }
.storia-card-text { font-size: 0.8rem; color: var(--text-light); line-height: 1.6; }
@media (max-width: 820px) { .storia-inner { grid-template-columns: 1fr; } .storia-visual { grid-template-rows: 180px 180px; margin-top: 32px; } .storia-cards { grid-template-columns: 1fr; } }

/* PRODOTTI */
.prodotti { padding-block: var(--section-pad); background: var(--cream); }
.prodotti-header { text-align: center; margin-bottom: clamp(36px, 6vw, 60px); }
.prodotti-header .section-label { justify-content: center; }
.prodotti-header .section-body { margin-inline: auto; margin-top: 16px; }
.prodotti-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.prodotto-card { background: var(--white); border-radius: var(--radius-md); overflow: hidden; border: 1px solid var(--cream-dark); transition: transform 0.3s, box-shadow 0.3s; }
.prodotto-card:hover { transform: translateY(-5px); box-shadow: 0 16px 40px rgba(62,92,54,0.13); }
.prodotto-img-wrap { width: 100%; aspect-ratio: 4/3; overflow: hidden; background: var(--green-wash); }
.prodotto-img-wrap img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; }
.prodotto-card:hover .prodotto-img-wrap img { transform: scale(1.06); }
.prodotto-body { padding: 22px 18px 26px; }
.prodotto-tag { display: inline-flex; align-items: center; gap: 5px; font-size: 0.63rem; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: var(--green-soft); background: var(--green-wash); padding: 3px 10px; border-radius: 20px; margin-bottom: 10px; }
.prodotto-title { font-family: var(--font-display); font-size: 1.3rem; font-weight: 600; color: var(--green-deep); margin-bottom: 8px; line-height: 1.25; }
.prodotto-desc { font-size: 0.83rem; color: var(--text-light); line-height: 1.7; }
@media (max-width: 1024px) { .prodotti-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px)  { .prodotti-grid { grid-template-columns: 1fr; } }

/* FILIERA */
.filiera { padding-block: var(--section-pad); background: var(--green-deep); color: var(--white); position: relative; overflow: hidden; }
.filiera::before { content: ''; position: absolute; top: -80px; right: -80px; width: 500px; height: 500px; border-radius: 50%; border: 1px solid rgba(255,255,255,0.05); pointer-events: none; }
.filiera-inner { display: grid; grid-template-columns: 1fr 1fr; gap: var(--gap); align-items: center; }
.filiera .section-label { color: var(--green-pale); }
.filiera .section-title { color: var(--cream); }
.filiera .section-body { color: rgba(255,255,255,0.72); margin-top: 16px; }
.filiera-steps { display: flex; flex-direction: column; margin-top: 36px; }
.filiera-step { display: flex; gap: 18px; padding-bottom: 28px; }
.filiera-step:last-child { padding-bottom: 0; }
.filiera-step-line { display: flex; flex-direction: column; align-items: center; flex-shrink: 0; }
.filiera-step-dot { width: 38px; height: 38px; border-radius: 50%; background: var(--green-mid); border: 2px solid var(--green-pale); display: flex; align-items: center; justify-content: center; z-index: 1; }
.filiera-step-dot i { color: var(--white); font-size: 0.95rem; }
.filiera-step-connector { flex: 1; width: 1px; background: rgba(255,255,255,0.12); margin-top: 4px; }
.filiera-step:last-child .filiera-step-connector { display: none; }
.filiera-step-content { padding-top: 0; }
.filiera-step-title { font-family: var(--font-display); font-size: 1.3rem; font-weight: 600; color: var(--cream); margin-bottom: 4px; }
.filiera-step-desc { font-size: 0.84rem; color: rgba(255,255,255,0.62); line-height: 1.65; }
.filiera-cert { background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.1); border-radius: var(--radius-md); overflow: hidden; }
.filiera-cert img { aspect-ratio: 4/2; object-fit: cover; width: 100%; }
.filiera-cert-body { padding: 32px 28px; text-align: center; }
.filiera-cert-title { font-family: var(--font-display); font-size: 1.35rem; font-weight: 600; color: var(--cream); margin-bottom: 10px; }
.filiera-cert-text { font-size: 0.84rem; color: rgba(255,255,255,0.62); line-height: 1.7; }
.filiera-cert-badge { display: inline-block; margin-top: 14px; padding: 7px 18px; background: var(--gold); color: var(--white); font-size: 0.68rem; font-weight: 700; letter-spacing: 0.15em; text-transform: uppercase; border-radius: 20px; }
@media (max-width: 820px) { .filiera-inner { grid-template-columns: 1fr; } }

/* TERRITORIO */
.territorio { padding-block: var(--section-pad); background: var(--white); }
.territorio-inner { display: grid; grid-template-columns: 1fr 1fr; gap: var(--gap); align-items: center; }
.territorio-content .section-body { margin-top: 16px; }
.territorio-highlights { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 28px; }
.territorio-hl { background: var(--cream); border-radius: var(--radius-sm); padding: 18px 16px; border-left: 3px solid var(--green-soft); }
.territorio-hl-title { font-family: var(--font-display); font-size: 1.3rem; font-weight: 600; color: var(--green-deep); margin-bottom: 4px; display: flex; align-items: center; gap: 6px; }
.territorio-hl-title i { font-size: 0.9rem; color: var(--green-soft); flex-shrink: 0; }
.territorio-hl-text { font-size: 0.8rem; color: var(--text-light); line-height: 1.55; }
.territorio-media { display: flex; flex-direction: column; gap: 12px; }
.territorio-photo { border-radius: var(--radius-md); overflow: hidden; }
.territorio-photo img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.5s ease; }
.territorio-photo:hover img { transform: scale(1.03); }
.territorio-photo--tall { aspect-ratio: 16/9; }
.territorio-photo-pair { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.territorio-photo-pair .territorio-photo { aspect-ratio: 4/3; }
.territorio-panorama { margin-top: 40px; border-radius: var(--radius-md); overflow: hidden; height: 260px; }
.territorio-panorama img { width: 100%; height: 100%; object-fit: cover; object-position: center 40%; }
@media (max-width: 820px) { .territorio-inner { grid-template-columns: 1fr; } .territorio-media { margin-top: 32px; } .territorio-highlights { grid-template-columns: 1fr; } .territorio-photo-pair { grid-template-columns: 1fr 1fr; } .territorio-panorama { margin-top: 12px; } }

/* SOSTENIBILITA' */
.sostenibilita { padding-block: var(--section-pad); background: var(--cream); }
.sostenibilita-inner { display: grid; grid-template-columns: 1fr 1.4fr; gap: var(--gap); align-items: center; }
.sostenibilita-content .section-body { margin-top: 16px; margin-bottom: 28px; }
.eco-pills { display: flex; flex-wrap: wrap; gap: 10px; }
.eco-pill { display: inline-flex; align-items: center; gap: 7px; padding: 9px 16px; background: var(--white); border: 1.5px solid var(--green-pale); border-radius: 30px; font-size: 0.8rem; font-weight: 500; color: var(--green-mid); transition: background 0.2s, border-color 0.2s; }
.eco-pill:hover { background: var(--green-wash); border-color: var(--green-soft); }
.eco-pill i { color: var(--green-soft); font-size: 0.85rem; }
.sostenibilita-visual { background: var(--green-wash); border-radius: var(--radius-lg); padding: 36px 28px 32px; text-align: center; border: 1.5px solid var(--green-pale); }
.circular-title { font-family: var(--font-display); font-size: 1.55rem; font-weight: 600; color: var(--green-deep); margin-bottom: 4px; }
.circular-sub { font-size: 0.82rem; color: var(--text-light); margin-bottom: 16px; font-style: italic; }
.ciclo-wrap { display: flex; justify-content: center; }
.ciclo-svg { width: 100%; max-width: 460px; height: auto; overflow: visible; }
.ciclo-orbit { transform-origin: 280px 280px; animation: orbit-spin 50s linear infinite; }
@keyframes orbit-spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
.ciclo-arc { transform-origin: 280px 280px; stroke-dashoffset: 1320; animation: arc-draw 2.8s ease-out forwards, arc-spin 22s linear infinite 3s; }
@keyframes arc-draw { to { stroke-dashoffset: 0; } }
@keyframes arc-spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
.ciclo-node circle { transition: fill 0.3s ease, filter 0.3s ease; }
.ciclo-node:hover circle { fill: var(--green-mid); filter: drop-shadow(0 4px 14px rgba(62,92,54,0.28)); }
.ciclo-node text, .ciclo-node g { transition: stroke 0.3s ease, fill 0.3s ease; }
.ciclo-node:hover text { fill: white !important; }
.ciclo-node:hover > g { stroke: white !important; }
@media (max-width: 820px) { .sostenibilita-inner { grid-template-columns: 1fr; } .sostenibilita-visual { margin-top: 32px; } .ciclo-svg { max-width: 340px; } }

/* CONTATTI */
.contatti { padding-block: var(--section-pad); background: var(--green-deep); position: relative; overflow: hidden; }
.contatti::before { content: 'INCIPIT'; position: absolute; bottom: -24px; right: -16px; font-family: var(--font-display); font-size: 18vw; font-weight: 700; color: rgba(255,255,255,0.025); line-height: 1; pointer-events: none; user-select: none; letter-spacing: 0.06em; }
.contatti-header { margin-bottom: 40px; }
.contatti .section-label { color: var(--green-pale); }
.contatti .section-title { color: var(--cream); margin-bottom: 12px; }
.contatti .section-body { color: rgba(255,255,255,0.68); }
.contatti-layout { display: grid; grid-template-columns: 1fr 1fr; gap: var(--gap); margin-top: 48px; align-items: start; }
.contatti-info { display: flex; flex-direction: column; gap: 20px; }
.contact-items { display: flex; flex-direction: column; gap: 0; }
.contact-item { display: flex; gap: 16px; align-items: flex-start; padding: 20px 0; border-bottom: 1px solid rgba(255,255,255,.07); }
.contact-item:first-child { padding-top: 0; }
.contact-item:last-child { border-bottom: none; padding-bottom: 0; }
.contact-item-icon { width: 46px; height: 46px; border-radius: 10px; background: rgba(255,255,255,.07); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.contact-item-icon i { font-size: 1.1rem; color: var(--green-pale); }
.contact-item-label { font-size: .64rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--green-pale); margin-bottom: 3px; }
.contact-item-value { font-size: .9rem; color: rgba(255,255,255,.78); line-height: 1.55; }
.contact-item-value a { color: rgba(255,255,255,.78); transition: color .2s; }
.contact-item-value a:hover { color: var(--white); }
.contatti-pec { margin-top: 32px; padding: 24px 28px; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.1); border-radius: var(--radius-md); display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.contatti-pec i { font-size: 1.8rem; color: var(--green-pale); flex-shrink: 0; }
.contatti-pec-copy { flex: 1; min-width: 140px; }
.contatti-pec-copy strong { font-family: var(--font-display); font-size: 1.1rem; color: var(--cream); display: block; }
.contatti-pec-copy span { font-size: .8rem; color: rgba(255,255,255,.5); }
.contatti-map { border-radius: var(--radius-lg); overflow: hidden; border: 2px solid rgba(255,255,255,.08); height: 100%; min-height: 420px; }
.contatti-map iframe { width: 100%; height: 100%; min-height: 420px; display: block; border: 0; }
@media (max-width: 900px) { .contatti-layout { grid-template-columns: 1fr; } .contatti-map { margin-top: 32px; min-height: 340px; } .contatti-map iframe { min-height: 340px; } }

/* FOOTER */
.footer { background: var(--text-dark); padding: 48px 0 28px; }
.footer-inner {
	display: grid;
    grid-template-columns: 1fr auto;
    gap: 32px 64px;
    align-items: center;
}
.footer-logo { display: flex; align-items: center; gap: 14px; margin-bottom: 10px;}

.footer-logo img {
	height: 150px;
	filter: drop-shadow(0 4px 24px rgba(0, 0, 0, 0.35)) brightness(0) invert(1);
	opacity: 0.65;
}

.footer-logo-text {
  font-family: var(--font-display);
  font-size: 1.2rem; font-weight: 600;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: rgba(255,255,255,0.55);
}

.footer-psr img{
    border-radius: var(--radius-md);
    overflow: hidden;
    max-width: 180px;
}

.footer-divider { width: 40px; height: 1px; background: rgba(255,255,255,0.1); }
.footer-legal { font-size: 0.8rem; color: rgba(255,255,255,0.45); line-height: 1.9; }
.footer-legal strong { color: rgba(255,255,255,0.6); }
.footer-legal a { color: rgba(255,255,255,0.45); transition: color 0.2s; }
.footer-legal a:hover { color: rgba(255,255,255,0.8); }
.footer-bottom {
	margin-top: 32px;
    padding-top: 24px;
    border-top: 1px solid rgba(255, 255, 255, .06);
    font-size: 0.72rem;
    color: rgba(255, 255, 255, .2);
    text-align: center;
    grid-column: 1 / -1;
}

@media (max-width: 640px) {
    .footer-inner {
        grid-template-columns: 1fr;
		text-align: center;
    }
	
	.footer-brand {
		display: flex;
		flex-direction: column;
		align-items: center;
	}
	
	.footer-psr img {
		margin: auto;
	}

}

.footer-bottom { font-size: 0.72rem; color: rgba(255,255,255,0.25); }
.footer-bottom a { color: rgba(255,255,255,0.35); margin-inline: 4px; transition: color 0.2s; }
.footer-bottom a:hover { color: rgba(255,255,255,0.7); }

@media (prefers-reduced-motion: reduce) { *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; } }
