/* ===========================================================
   ESSENZIALE SRL — design tokens (versione dark)
   =========================================================== */

:root{
  --ink: #2C2E2D;        /* sfondo principale, grigio Nardo scuro */
  --surface: #383A39;    /* sfondo sezioni alternate / card */
  --surface-2: #454746;  /* card più chiare, hover */
  --paper: #F5F1EA;      /* testo principale chiaro */
  --graphite: #B3B5B3;   /* testo secondario chiaro/muto */
  --mist: rgba(245,241,234,0.10);  /* linee/divider su scuro */
  --line: rgba(245,241,234,0.14);
  --accent: #F07D00;     /* arancio del brand */
  --accent-2: #FFA94D;   /* arancio chiaro, hover/glow */
  --accent-deep: #C2660A;

  --nardo: #8C8E8C;       /* grigio Nardo chiaro, sezioni tecniche/di processo */
  --nardo-light: #B7B9B7;
  --nardo-deep: #1E1F1F;

  --display: 'Fraunces', 'Georgia', serif;
  --body: 'Jost', 'Helvetica Neue', Arial, sans-serif;
  --mono: 'Space Mono', 'Courier New', monospace;

  --max: 1280px;
  --pad: clamp(24px, 5vw, 64px);
}

*{ box-sizing: border-box; }
html{ scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior: auto; }
  *{ animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; }
}

body{
  margin: 0;
  background: var(--ink);
  color: var(--paper);
  font-family: var(--body);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

img{ max-width: 100%; display: block; }
a{ color: inherit; text-decoration: none; }

::selection{ background: var(--accent); color: var(--ink); }

:focus-visible{
  outline: 2px solid var(--accent);
  outline-offset: 3px;
}

.wrap{
  max-width: var(--max);
  margin: 0 auto;
  padding: 0 var(--pad);
  position: relative;
  z-index: 2;
}

.eyebrow{
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent-2);
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.eyebrow::before{
  content: '';
  width: 18px;
  height: 1px;
  background: var(--accent);
  display: inline-block;
}
.eyebrow.nardo{ color: var(--nardo-light); }
.eyebrow.nardo::before{ background: var(--nardo); }

h1, h2, h3{
  font-family: var(--display);
  font-weight: 600;
  letter-spacing: -0.01em;
  margin: 0;
  color: var(--paper);
}

h1{ font-size: clamp(40px, 7vw, 84px); line-height: 1.04; font-weight: 600; font-style: normal; }
h2{ font-size: clamp(28px, 4vw, 46px); line-height: 1.1; font-weight: 600; }
h3{ font-size: clamp(18px, 2vw, 22px); font-weight: 500; }

p{ margin: 0; color: var(--graphite); }
p.lede{ font-size: clamp(17px, 2vw, 20px); color: var(--paper); max-width: 46ch; }

.mono-num{
  font-family: var(--mono);
  font-size: 13px;
  color: var(--accent);
}

/* ---------- background ambience (blobs + grain) ---------- */
.ambient{
  position: fixed;
  inset: 0;
  z-index: 0;
  overflow: hidden;
  pointer-events: none;
}
.blob{
  position: absolute;
  border-radius: 50%;
  filter: blur(70px);
  opacity: 0.35;
  will-change: transform;
}
.blob.b1{
  width: 520px; height: 520px;
  background: radial-gradient(circle, var(--nardo) 0%, transparent 70%);
  top: -120px; left: -120px;
  animation: float1 22s ease-in-out infinite;
}
.blob.b2{
  width: 420px; height: 420px;
  background: radial-gradient(circle, var(--nardo-light) 0%, transparent 70%);
  top: 40%; right: -160px;
  animation: float2 26s ease-in-out infinite;
}
.blob.b3{
  width: 380px; height: 380px;
  background: radial-gradient(circle, var(--surface-2) 0%, transparent 70%);
  bottom: -140px; left: 30%;
  animation: float3 30s ease-in-out infinite;
}
@keyframes float1{
  0%,100%{ transform: translate(0,0) scale(1); }
  50%{ transform: translate(80px,60px) scale(1.15); }
}
@keyframes float2{
  0%,100%{ transform: translate(0,0) scale(1); }
  50%{ transform: translate(-70px,40px) scale(1.1); }
}
@keyframes float3{
  0%,100%{ transform: translate(0,0) scale(1); }
  50%{ transform: translate(50px,-50px) scale(1.2); }
}

/* ---------- header ---------- */
header.site{
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(44,46,45,0.82);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line);
}
.nav{
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px var(--pad);
  max-width: var(--max);
  margin: 0 auto;
}
.logo{
  font-family: var(--display);
  font-weight: 800;
  font-size: 18px;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  display: flex;
  align-items: center;
}
.logo img{ height: 26px; width: auto; display: block; }
.logo span{ color: var(--accent); }

.footer-logo img{ height: 24px; width: auto; display: block; margin-bottom: 4px; }

.nav-links{
  display: flex;
  gap: 36px;
  align-items: center;
  font-size: 14px;
}
.nav-links a{
  position: relative;
  padding: 4px 0;
  color: var(--paper);
}
.nav-links a.active{ color: var(--accent-2); }
.nav-links a::after{
  content:'';
  position:absolute;
  left:0; bottom:-2px;
  width:0; height:1px;
  background: var(--accent);
  transition: width 0.25s ease;
}
.nav-links a:hover::after, .nav-links a.active::after{ width: 100%; }

.nav-cta{
  font-family: var(--mono);
  font-size: 13px;
  border: 1px solid var(--accent);
  color: var(--paper);
  padding: 9px 18px;
  border-radius: 999px;
  transition: background 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
  white-space: nowrap;
  box-shadow: 0 0 0 0 rgba(240,125,0,0.5);
}
.nav-cta:hover{ background: var(--accent); color: var(--ink); box-shadow: 0 0 22px rgba(240,125,0,0.45); }

.nav-toggle{
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  width: 28px; height: 20px;
  position: relative;
}
.nav-toggle span{
  position: absolute;
  left: 0; right: 0;
  height: 1px;
  background: var(--paper);
  transition: transform 0.25s ease, opacity 0.25s ease;
}
.nav-toggle span:nth-child(1){ top: 0; }
.nav-toggle span:nth-child(2){ top: 9px; }
.nav-toggle span:nth-child(3){ top: 18px; }
.nav-toggle.open span:nth-child(1){ transform: translateY(9px) rotate(45deg); }
.nav-toggle.open span:nth-child(2){ opacity: 0; }
.nav-toggle.open span:nth-child(3){ transform: translateY(-9px) rotate(-45deg); }

.nav-links .nav-cta-mobile{ display: none; }

@media (max-width: 860px){
  .nav-links{
    position: fixed;
    top: 69px; left: 0; right: 0;
    background: var(--ink);
    border-bottom: 1px solid var(--line);
    flex-direction: column;
    align-items: flex-start;
    gap: 22px;
    padding: 28px var(--pad) 32px;
    transform: translateY(-12px);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: transform 0.25s ease, opacity 0.2s ease, visibility 0.25s;
  }
  .nav-links.open{
    transform: translateY(0);
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }
  .nav-cta{ display: none; }
  .nav-links .nav-cta-mobile{
    display: inline-block;
    font-family: var(--mono);
    border: 1px solid var(--accent);
    padding: 9px 18px;
    border-radius: 999px;
  }
  .nav-toggle{ display: block; }
}

/* ---------- sections / layout helpers ---------- */
section{ padding: clamp(64px, 10vw, 120px) 0; position: relative; }
.section-tight{ padding: clamp(40px, 6vw, 72px) 0; }
.rule{ border: none; border-top: 1px solid var(--line); margin: 0; position: relative; z-index: 2; }

.surface{ background: var(--surface); }

.grid-2{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(32px, 6vw, 96px);
  align-items: center;
}
@media (max-width: 860px){
  .grid-2{ grid-template-columns: 1fr; gap: 40px; }
}

.btn{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--mono);
  font-size: 13px;
  letter-spacing: 0.02em;
  padding: 14px 26px;
  border-radius: 999px;
  border: 1px solid var(--accent);
  background: var(--accent);
  color: var(--ink);
  transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
  box-shadow: 0 0 0 0 rgba(240,125,0,0.5);
  cursor: pointer;
}
.btn:hover{ background: var(--accent-2); box-shadow: 0 6px 28px rgba(240,125,0,0.4); transform: translateY(-2px); }
.btn.ghost{ background: transparent; border-color: var(--line); color: var(--paper); }
.btn.ghost:hover{ border-color: var(--accent); color: var(--accent-2); background: transparent; box-shadow: none; transform: translateY(-2px); }
.btn.pulse{ animation: pulseGlow 2.6s ease-in-out infinite; }
@keyframes pulseGlow{
  0%,100%{ box-shadow: 0 0 0 0 rgba(240,125,0,0.45); }
  50%{ box-shadow: 0 0 0 10px rgba(240,125,0,0); }
}
.btn-row{ display: flex; gap: 16px; flex-wrap: wrap; }

/* reveal on scroll */
.reveal{ opacity: 1; }
.js .reveal{
  opacity: 0;
  transform: translateY(46px) scale(0.97);
  transition: opacity 0.8s cubic-bezier(.16,.84,.44,1), transform 0.8s cubic-bezier(.16,.84,.44,1);
}
.js .reveal.is-visible{ opacity: 1; transform: translateY(0) scale(1); }

/* ---------- tilt wrapper (3D hover) ---------- */
.tilt{
  perspective: 900px;
}
.tilt-inner{
  transition: transform 0.15s ease-out;
  transform-style: preserve-3d;
  will-change: transform;
}

/* ---------- hero ---------- */
.hero-bg{
  position: relative;
  min-height: 88vh;
  display: flex;
  align-items: center;
  padding-top: clamp(48px, 8vw, 90px);
  padding-bottom: clamp(40px, 6vw, 70px);
  overflow: hidden;
}
.hero-photo{
  position: absolute;
  inset: -15% -10% -25% -10%;
  z-index: 0;
}
.hero-photo img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.22);
  animation: heroZoomIn 2.2s cubic-bezier(.16,.84,.44,1) forwards;
}
@keyframes heroZoomIn{
  from{ transform: scale(1.32); }
  to{ transform: scale(1.1); }
}
.hero-overlay{
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    radial-gradient(circle at 22% 30%, rgba(240,125,0,0.22), transparent 55%),
    linear-gradient(180deg, rgba(18,16,16,0.45) 0%, rgba(18,16,16,0.72) 60%, var(--ink) 100%);
}
.hero-content{
  position: relative;
  z-index: 2;
  max-width: 680px;
  display: flex;
  flex-direction: column;
  gap: 22px;
}
.hero-content .lede{ color: var(--paper); }
.hero-credit{
  position: absolute;
  bottom: 14px;
  right: var(--pad);
  z-index: 2;
  font-family: var(--mono);
  font-size: 10.5px;
  color: rgba(245,241,234,0.45);
}
.hero-credit a{ color: rgba(245,241,234,0.6); border-bottom: 1px solid rgba(245,241,234,0.25); }

/* entrata animata del testo hero al caricamento */
.hero-anim-1, .hero-anim-2, .hero-anim-3, .hero-anim-4{
  opacity: 0;
  transform: translateY(34px);
}
.js .hero-anim-1{ animation: heroTextIn 0.9s cubic-bezier(.16,.84,.44,1) 1.05s forwards; }
.js .hero-anim-3{ animation: heroTextIn 1s cubic-bezier(.16,.84,.44,1) 1.7s forwards; }
.js .hero-anim-4{ animation: heroTextIn 1s cubic-bezier(.16,.84,.44,1) 1.95s forwards; }
@keyframes heroTextIn{
  from{ opacity: 0; transform: translateY(34px); }
  to{ opacity: 1; transform: translateY(0); }
}

.hero{
  padding-top: clamp(48px, 8vw, 90px);
  padding-bottom: clamp(40px, 6vw, 70px);
}
.hero-grid{
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: clamp(32px, 5vw, 64px);
  align-items: end;
}
@media (max-width: 860px){
  .hero-grid{ grid-template-columns: 1fr; }
}
.hero-media{
  aspect-ratio: 4/5;
  overflow: hidden;
  background: var(--surface);
  border-radius: 6px;
  box-shadow: 0 30px 80px -20px rgba(0,0,0,0.6);
  border: 1px solid var(--line);
}
.hero-media img{ width: 100%; height: 100%; object-fit: cover; }
.hero-text{ display: flex; flex-direction: column; gap: 22px; }
.hero-text .lede{ color: var(--graphite); }

/* ---------- wireframe cube (vera animazione 3D) ---------- */
.cube-scene{
  width: 140px; height: 140px;
  perspective: 600px;
  position: absolute;
  pointer-events: none;
  opacity: 0.55;
}
.cube{
  width: 100%; height: 100%;
  position: relative;
  transform-style: preserve-3d;
  animation: spin3d 16s linear infinite;
}
.cube .face{
  position: absolute;
  width: 140px; height: 140px;
  border: 1px solid var(--accent-2);
  background: rgba(240,125,0,0.04);
}
.cube .f1{ transform: translateZ(70px); }
.cube .f2{ transform: rotateY(180deg) translateZ(70px); }
.cube .f3{ transform: rotateY(90deg) translateZ(70px); }
.cube .f4{ transform: rotateY(-90deg) translateZ(70px); }
.cube .f5{ transform: rotateX(90deg) translateZ(70px); }
.cube .f6{ transform: rotateX(-90deg) translateZ(70px); }
@keyframes spin3d{
  from{ transform: rotateX(0deg) rotateY(0deg); }
  to{ transform: rotateX(360deg) rotateY(360deg); }
}

/* ---------- processo ---------- */
.steps{ border-top: 1px solid var(--line); }
.step{
  display: grid;
  grid-template-columns: 80px 1fr 1.4fr;
  gap: 24px;
  padding: 28px 0;
  border-bottom: 1px solid var(--line);
  align-items: baseline;
  transition: background 0.2s ease, padding-left 0.2s ease;
}
.step:hover{ background: rgba(107,109,108,0.08); padding-left: 10px; }
@media (max-width: 700px){
  .step{ grid-template-columns: 50px 1fr; }
  .step .step-desc{ grid-column: 2 / 3; }
}
.step-num{ font-family: var(--mono); color: var(--nardo-light); font-size: 14px; }
.step-title{ font-family: var(--display); font-weight: 700; font-size: clamp(18px,2vw,22px); color: var(--paper); }
.step-desc{ color: var(--graphite); max-width: 52ch; }

/* ---------- comparator (signature) ---------- */
.compare{
  position: relative;
  width: 100%;
  aspect-ratio: 16/10;
  overflow: hidden;
  background: var(--surface);
  cursor: ew-resize;
  user-select: none;
  border-radius: 6px;
  border: 1px solid var(--line);
  box-shadow: 0 30px 80px -20px rgba(0,0,0,0.6);
}
.compare img{
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
}
.compare .after{ clip-path: inset(0 0 0 var(--pos,50%)); }
.compare .handle{
  position: absolute;
  top: 0; bottom: 0;
  left: var(--pos,50%);
  width: 1px;
  background: var(--paper);
  transform: translateX(-0.5px);
}
.compare .handle::after{
  content:'';
  position: absolute;
  top: 50%; left: 50%;
  width: 40px; height: 40px;
  border-radius: 50%;
  background: var(--nardo-light);
  transform: translate(-50%,-50%);
  box-shadow: 0 2px 20px rgba(160,162,160,0.45);
}
.compare .handle::before{
  content: '\2194';
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%,-50%);
  font-size: 16px;
  z-index: 2;
  color: var(--ink);
}
.compare .tag{
  position: absolute;
  bottom: 16px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  background: rgba(44,46,45,0.82);
  color: var(--paper);
  padding: 6px 10px;
  border: 1px solid var(--line);
}
.compare .tag.left{ left: 16px; }
.compare .tag.right{ right: 16px; }
.compare-range{
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  opacity: 0;
  cursor: ew-resize;
  margin: 0;
}
.compare-caption{
  font-family: var(--mono);
  font-size: 12px;
  color: var(--graphite);
  margin-top: 14px;
  text-align: center;
}

/* ---------- inverted / accent panel (lamborghini) ---------- */
.inverted{
  background:
    radial-gradient(circle at 15% 20%, rgba(240,125,0,0.16), transparent 55%),
    radial-gradient(circle at 85% 80%, rgba(240,125,0,0.10), transparent 55%),
    var(--surface);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  overflow: hidden;
}
.lamb-grid{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--line);
  margin-top: 40px;
  border-radius: 6px;
  overflow: hidden;
}
.lamb-grid img{ width: 100%; height: 100%; object-fit: cover; aspect-ratio: 1/1; transition: transform 0.4s ease, filter 0.4s ease; filter: grayscale(0.15); }
.lamb-grid img:hover{ transform: scale(1.05); filter: grayscale(0); }
@media (max-width: 700px){
  .lamb-grid{ grid-template-columns: repeat(2, 1fr); }
}
.lamb-fine{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.05em;
  color: var(--graphite);
  margin-top: 28px;
}

/* ---------- render gallery ---------- */
.render-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
@media (max-width: 860px){
  .render-grid{ grid-template-columns: 1fr; }
}
.render-item{
  aspect-ratio: 4/3;
  overflow: hidden;
  border-radius: 6px;
  border: 1px solid var(--line);
  box-shadow: 0 20px 50px -20px rgba(0,0,0,0.5);
}
.render-item img{ width: 100%; height: 100%; object-fit: cover; }

/* ---------- reviews ---------- */
.review-banner{
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 24px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 28px 32px;
  margin-top: 40px;
}
.stars{ color: var(--accent); font-size: 20px; letter-spacing: 3px; }
.review-grid{
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 24px;
  margin-top: 32px;
}
@media (max-width: 860px){ .review-grid{ grid-template-columns: 1fr; } }
.review-card{
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 26px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: transform 0.25s ease, border-color 0.25s ease;
}
.review-card:hover{ transform: translateY(-4px); border-color: var(--accent); }
.review-card .stars{ font-size: 16px; }
.review-card p{ color: var(--paper); font-size: 15px; }
.review-card .reviewer{ font-family: var(--mono); font-size: 12px; color: var(--graphite); }

/* ---------- lead form (persuasione / cattura contatto) ---------- */
.lead{
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: clamp(28px, 5vw, 48px);
  position: relative;
  overflow: hidden;
}
.lead::before{
  content:'';
  position: absolute;
  top: -80px; right: -80px;
  width: 260px; height: 260px;
  background: radial-gradient(circle, var(--accent) 0%, transparent 70%);
  opacity: 0.18;
  filter: blur(10px);
}
.lead-grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(28px,5vw,56px);
  align-items: start;
}
@media (max-width: 860px){ .lead-grid{ grid-template-columns: 1fr; } }
.lead-points{ display:flex; flex-direction:column; gap:16px; margin-top: 18px; }
.lead-point{ display:flex; gap:12px; align-items:flex-start; color: var(--paper); font-size: 15px; }
.lead-point .dot{ width:7px; height:7px; border-radius:50%; background:var(--accent); margin-top:7px; flex-shrink:0; box-shadow: 0 0 8px var(--accent); }

.field{ display:flex; flex-direction:column; gap:8px; margin-bottom:18px; }
.field label{ font-family: var(--mono); font-size: 12px; color: var(--graphite); text-transform: uppercase; letter-spacing: 0.06em; }
.field input, .field textarea{
  background: var(--ink);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 13px 14px;
  color: var(--paper);
  font-family: var(--body);
  font-size: 15px;
  resize: vertical;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.field input:focus, .field textarea:focus{
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(240,125,0,0.18);
}
.lead-disclaimer{ font-family: var(--mono); font-size: 11.5px; color: var(--graphite); margin-top: 14px; }

/* ---------- cards (sedi) ---------- */
.location{
  border-top: 1px solid var(--line);
  padding: 36px 0;
  display: grid;
  grid-template-columns: 0.5fr 1fr 1fr auto;
  gap: 24px;
  align-items: baseline;
  transition: background 0.2s ease;
}
.location:hover{ background: rgba(240,125,0,0.04); }
@media (max-width: 860px){
  .location{ grid-template-columns: 1fr; gap: 10px; }
}
.location:last-child{ border-bottom: 1px solid var(--line); }
.location .loc-tag{ font-family: var(--mono); font-size: 12px; color: var(--accent); text-transform: uppercase; letter-spacing: 0.08em; }
.location .loc-name{ font-family: var(--display); font-weight: 700; font-size: 20px; color: var(--paper); }
.location .loc-addr{ color: var(--graphite); }
.location .loc-link{ font-family: var(--mono); font-size: 13px; color: var(--accent-2); border-bottom: 1px solid var(--accent); white-space: nowrap; }

/* ---------- contact ---------- */
.contact-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--line);
  margin-top: 48px;
  border-radius: 8px;
  overflow: hidden;
}
.contact-card{
  background: var(--surface);
  padding: 36px 28px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: background 0.2s ease;
}
.contact-card:hover{ background: var(--surface-2); }
.contact-card .eyebrow{ font-size: 11px; }
.contact-card a{ font-family: var(--mono); font-size: 14px; color: var(--accent-2); border-bottom: 1px solid var(--line); padding-bottom: 4px; width: fit-content; }
.contact-card a:hover{ border-color: var(--accent); }
@media (max-width: 860px){
  .contact-grid{ grid-template-columns: 1fr; }
}

/* ---------- footer ---------- */
footer.site{
  border-top: 1px solid var(--line);
  padding: 56px 0 40px;
  background: var(--surface);
}
.footer-grid{
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 32px;
}
.footer-col{ display: flex; flex-direction: column; gap: 10px; }
.footer-col .eyebrow{ margin-bottom: 6px; }
.footer-col a{ font-size: 14px; color: var(--graphite); }
.footer-col a:hover{ color: var(--accent-2); }
.footer-bottom{
  margin-top: 48px;
  padding-top: 24px;
  border-top: 1px solid var(--line);
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  font-family: var(--mono);
  font-size: 12px;
  color: var(--graphite);
}

/* page header (chi siamo / sedi / contatti) */
.page-head{
  padding: clamp(56px,8vw,100px) 0 clamp(32px,5vw,56px);
}
.page-head .lede{ margin-top: 18px; }

.values{
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 40px;
  margin-top: 48px;
}
@media (max-width: 860px){ .values{ grid-template-columns: 1fr; } }
.value-item{ border-top: 1px solid var(--line); padding-top: 20px; }

/* ---------- intro reveal: tendina di apertura ---------- */
.page-intro{
  position: fixed;
  inset: 0;
  z-index: 999;
  background: var(--ink);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  transition: transform 0.9s cubic-bezier(.76,0,.24,1);
}
.page-intro img{
  width: 46px;
  opacity: 0;
  animation: introLogoIn 0.6s ease 0.1s forwards;
}
.page-intro-line{
  width: 0;
  height: 1px;
  background: var(--accent);
  margin-top: 20px;
  animation: introLineIn 0.6s cubic-bezier(.4,0,.2,1) 0.45s forwards;
}
.page-intro.hide{
  transform: translateY(-100%);
}
@keyframes introLogoIn{
  from{ opacity: 0; transform: scale(0.85); }
  to{ opacity: 1; transform: scale(1); }
}
@keyframes introLineIn{ to{ width: 100px; } }
@media (prefers-reduced-motion: reduce){
  .page-intro{ display: none; }
}
html.intro-lock{ overflow: hidden; }

/* ---------- giant editorial headline (stile primopiano) ---------- */
.giant{
  font-family: 'Archivo', sans-serif;
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 0.92;
  font-size: clamp(56px, 11vw, 150px);
  color: var(--paper);
  text-align: center;
}
.hero-tagline{
  font-family: var(--display);
  font-style: italic;
  font-size: clamp(15px, 1.6vw, 18px);
  color: var(--graphite);
  text-align: center;
  margin-top: 10px;
}

/* ---------- reveal a tendina per i titoli (clip + slide) ---------- */
.line-mask{ display: block; overflow: hidden; }
.line-inner{ display: block; transform: translateY(0); }
.js .line-inner{
  transform: translateY(112%);
  animation: lineUp 0.95s cubic-bezier(.16,.84,.44,1) forwards;
}
.js .line-d1{ animation-delay: 1.3s; }
.js .line-d2{ animation-delay: 1.45s; }
@keyframes lineUp{ to{ transform: translateY(0); } }

/* ---------- manifesto a scroll (testo che si illumina) ---------- */
.manifesto{
  max-width: 880px;
  margin: 0 auto;
  text-align: center;
}
.manifesto p{
  font-family: var(--display);
  font-size: clamp(22px, 3.4vw, 36px);
  line-height: 1.45;
  font-weight: 400;
  color: var(--paper);
}
.manifesto .word{
  color: rgba(245,241,234,0.18);
  transition: color 0.25s ease;
}
.manifesto .word.lit{ color: var(--paper); }
.manifesto-link{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-top: 28px;
  font-family: var(--mono);
  font-size: 13px;
  color: var(--accent-2);
  border-bottom: 1px solid var(--accent);
  padding-bottom: 4px;
}
.manifesto-wrap{ text-align: center; }

/* ---------- moodboard scattered collage ---------- */
.moodboard{
  position: relative;
  height: clamp(420px, 60vw, 620px);
  max-width: 1000px;
  margin: 0 auto;
}
.moodboard .mb-main{
  position: absolute;
  left: 50%; top: 50%;
  transform: translate(-50%, calc(-50% + var(--py, 0px))) rotate(var(--pr, 0deg));
  width: 46%;
  aspect-ratio: 4/5;
  z-index: 3;
  background: var(--surface);
  box-shadow: 0 30px 70px -20px rgba(0,0,0,0.7);
  will-change: transform;
}
.moodboard .mb-item{
  position: absolute;
  overflow: hidden;
  background: var(--surface);
  border: 1px solid var(--line);
  box-shadow: 0 20px 50px -20px rgba(0,0,0,0.6);
  transform: translateY(var(--py, 0px)) rotate(var(--pr, 0deg));
  will-change: transform;
}
.moodboard img{ width:100%; height:100%; object-fit:cover; display:block; }
.mb-1{ width: 20%; aspect-ratio:1/1; left:2%; top:12%; z-index:2; }
.mb-2{ width: 16%; aspect-ratio:1/1; left:0%; bottom:6%; z-index:2; }
.mb-3{ width: 19%; aspect-ratio:1/1; right:1%; top:6%; z-index:2; }
.mb-4{ width: 17%; aspect-ratio:1/1; right:3%; bottom:10%; z-index:2; }
@media (max-width: 700px){
  .moodboard{ height: 520px; }
  .mb-1,.mb-2,.mb-3,.mb-4{ display: none; }
  .moodboard .mb-main{ width: 78%; }
}

/* ---------- masonry gallery ---------- */
.masonry{
  column-count: 3;
  column-gap: 18px;
}
.masonry .m-item{
  margin-bottom: 18px;
  overflow: hidden;
  break-inside: avoid;
  transform: translateY(var(--py, 0px));
  will-change: transform;
}
.masonry img{ width:100%; display:block; }
@media (max-width: 860px){
  .masonry{ column-count: 2; }
}
@media (max-width: 560px){
  .masonry{ column-count: 1; }
}

/* ---------- showroom strip ---------- */
.showroom-strip{
  border: 1px solid var(--line);
  border-radius: 4px;
  display: grid;
  grid-template-columns: repeat(3,1fr);
  margin-top: 36px;
}
.showroom-strip a{
  padding: 36px 0;
  text-align: center;
  font-family: var(--display);
  font-size: clamp(18px,2.4vw,24px);
  color: var(--paper);
  border-right: 1px solid var(--line);
  transition: color 0.2s ease, background 0.2s ease;
}
.showroom-strip a:last-child{ border-right: none; }
.showroom-strip a:hover{ color: var(--nardo-light); background: rgba(107,109,108,0.08); }
@media (max-width: 700px){
  .showroom-strip{ grid-template-columns: 1fr; }
  .showroom-strip a{ border-right: none; border-bottom: 1px solid var(--line); }
  .showroom-strip a:last-child{ border-bottom: none; }
}
.floating-cta{
  position: fixed;
  bottom: 22px;
  right: 22px;
  z-index: 60;
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--accent);
  color: var(--ink);
  font-family: var(--mono);
  font-size: 13px;
  padding: 14px 20px;
  border-radius: 999px;
  box-shadow: 0 10px 30px rgba(240,125,0,0.4);
  transform: translateY(20px);
  opacity: 0;
  pointer-events: none;
  transition: transform 0.35s ease, opacity 0.35s ease;
}
.floating-cta.show{ transform: translateY(0); opacity: 1; pointer-events: auto; }
.floating-cta:hover{ background: var(--accent-2); }
@media (max-width: 600px){
  .floating-cta{ left: 16px; right: 16px; justify-content: center; bottom: 16px; }
}
