/* ============================================================
   FERRANOVA — home.css  (homepage only)
   ============================================================ */

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;background:var(--navy);color:#fff;overflow:hidden}
.hero-media{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
}
.hero-media::after{content:"";position:absolute;inset:24px;border:1px solid rgba(255,255,255,.07)}
.hero-inner{position:relative;padding-top:96px;padding-bottom:96px;min-height:100dvh;display:flex;flex-direction:column;justify-content:center}
.hero h1{
  font-family:"Barlow Condensed",sans-serif;font-weight:800;
  font-size:clamp(56px,7.2vw,108px);line-height:.92;letter-spacing:-0.025em;
  margin:0 0 28px;max-width:1000px;text-transform:uppercase;text-wrap:balance;
}
.hero h1 .rame{color:var(--rame-2)}
.hero p.lead{font-size:19px;line-height:1.55;color:rgba(255,255,255,.78);max-width:560px;margin:0 0 44px}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap}
@media(max-width:720px){
  .hero-inner{padding-top:80px;padding-bottom:80px;min-height:100dvh}
}

/* ============================================================
   STRIP
   ============================================================ */
.strip{background:#fff;border-bottom:1px solid var(--line)}
.strip-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.strip-cell{padding:48px 36px;border-left:1px solid var(--line)}
.strip-cell:first-child{border-left:0;padding-left:0}
.strip-cell .k{font:500 11px/1 "Inter";text-transform:uppercase;letter-spacing:.14em;color:var(--rame);margin-bottom:18px;display:flex;align-items:center;gap:8px}
.strip-cell .k::before{content:"";width:6px;height:6px;background:var(--rame);display:inline-block}
.strip-cell .v{font-family:"Barlow Condensed";font-weight:700;font-size:42px;line-height:1;color:var(--navy);letter-spacing:-0.01em;margin-bottom:10px}
.strip-cell .d{font-size:14px;line-height:1.5;color:var(--steel)}
@media(max-width:960px){
  .strip-grid{grid-template-columns:repeat(2,1fr)}
  .strip-cell{padding:36px 24px}
  .strip-cell:nth-child(2n+1){border-left:0;padding-left:0}
  .strip-cell:nth-child(3),.strip-cell:nth-child(4){border-top:1px solid var(--line)}
}
@media(max-width:560px){
  .strip-grid{grid-template-columns:1fr}
  .strip-cell{padding:28px 0;border-left:0}
  .strip-cell:nth-child(n+2){border-top:1px solid var(--line)}
}

/* ============================================================
   SECTION INTRO (stacked header — no split)
   ============================================================ */
.section-intro{margin-bottom:64px}
.section-intro h2{
  font-family:"Barlow Condensed";font-weight:700;
  font-size:clamp(42px,4.6vw,64px);line-height:1;
  letter-spacing:-0.015em;color:var(--navy);text-transform:uppercase;
  margin:0 0 20px;text-wrap:balance;
}
.section-intro p{font-size:16px;line-height:1.65;color:var(--steel);max-width:62ch;margin:0}
@media(max-width:720px){.section-intro{margin-bottom:40px}}

/* ============================================================
   PRODOTTI — horizontal rows (no 3-equal cards)
   ============================================================ */
.prod-list{border-top:1px solid var(--line)}
.prod-row{
  display:grid;
  grid-template-columns:80px 1fr 420px;
  border-bottom:1px solid var(--line);
  transition:background .2s ease;
}
@media(hover:hover){.prod-row:hover{background:rgba(13,27,42,.025)}}
.prod-row-num{
  font-family:"Barlow Condensed";font-weight:700;font-size:80px;
  line-height:1;color:var(--stone-2);letter-spacing:-0.02em;
  padding:48px 0 0;align-self:start;
}
.prod-row-content{
  padding:48px 56px 48px 0;
  display:flex;flex-direction:column;
}
.prod-row-tag{
  font-family:"JetBrains Mono";font-size:10px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--rame);margin-bottom:16px;
}
.prod-row-content h3{
  font-family:"Barlow Condensed";font-weight:700;font-size:34px;
  letter-spacing:-.01em;color:var(--navy);margin:0 0 14px;
  line-height:1.04;text-transform:uppercase;
}
.prod-row-content p{
  color:var(--steel);font-size:15px;line-height:1.65;
  margin:0 0 24px;max-width:56ch;flex:1;
}
.prod-row-content ul{list-style:none;margin:0 0 32px;padding:0}
.prod-row-content ul li{
  font-size:13.5px;color:var(--ink);padding:9px 0;
  border-bottom:1px solid var(--line);
  display:flex;align-items:center;gap:10px;
}
.prod-row-content ul li::before{content:"";width:5px;height:5px;background:var(--rame);flex:none}
.prod-row-link{
  display:inline-flex;align-items:center;gap:10px;
  color:var(--navy);font-weight:600;font-size:14px;
  transition:color .2s;margin-top:auto;
}
@media(hover:hover){.prod-row-link:hover{color:var(--rame)}}
.prod-row-link svg{transition:transform .2s ease}
@media(hover:hover){.prod-row:hover .prod-row-link svg{transform:translateX(4px)}}
.prod-row-link:focus-visible{outline:2px solid var(--rame);outline-offset:3px;border-radius:1px}
.prod-row-media{width:100%;height:100%;object-fit:cover;display:block}
.prod-row-ph{width:100%;height:100%}
@media(max-width:960px){
  .prod-row{grid-template-columns:56px 1fr;grid-template-rows:auto auto}
  .prod-row-num{padding:32px 0 0;font-size:52px}
  .prod-row-content{padding:12px 0 32px}
  .prod-row-media,.prod-row-ph{grid-column:1/-1;aspect-ratio:16/9;width:100%;height:auto}
}

/* ============================================================
   CHI SIAMO
   ============================================================ */
.about{background:var(--ice);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.about-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:80px;align-items:center}
@media(max-width:960px){.about-grid{grid-template-columns:1fr;gap:48px}}
.about-img{aspect-ratio:5/6;width:100%}
.about-img .ph,.about-img img{width:100%;height:100%;object-fit:cover}
.about h2{font-family:"Barlow Condensed";font-weight:700;font-size:clamp(40px,4.4vw,58px);line-height:1.02;letter-spacing:-0.015em;color:var(--navy);margin:0 0 28px;text-transform:uppercase;text-wrap:balance}
.about .lede{font-size:20px;line-height:1.5;color:var(--ink);margin:0 0 24px;font-weight:500}
.about p{font-size:16px;line-height:1.7;color:var(--steel);margin:0 0 18px}
.about-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:0;margin-top:40px;border-top:1px solid var(--line)}
.about-stats div{padding:24px 0;border-bottom:1px solid var(--line)}
.about-stats div:nth-child(2n){padding-left:24px;border-left:1px solid var(--line)}
.about-stats .k{font:500 11px/1 "Inter";letter-spacing:.12em;text-transform:uppercase;color:var(--rame);margin-bottom:10px}
.about-stats .v{font-family:"Barlow Condensed";font-weight:700;font-size:28px;color:var(--navy);line-height:1}

/* ============================================================
   COME LAVORIAMO (homepage)
   ============================================================ */
.proc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin-top:24px}
.proc-step{padding:48px 32px 56px;border-left:1px solid var(--line);position:relative;display:flex;flex-direction:column;gap:18px}
.proc-step:first-child{border-left:0}
.proc-num{font-family:"Barlow Condensed";font-weight:700;font-size:64px;line-height:1;color:var(--stone-2);letter-spacing:-0.02em}
.proc-step h3{font-family:"Barlow Condensed";font-weight:700;font-size:26px;text-transform:uppercase;letter-spacing:-.005em;color:var(--navy);margin:0;line-height:1.08;text-wrap:balance}
.proc-step p{margin:0;color:var(--steel);font-size:14.5px;line-height:1.65}
.proc-step .tag{margin-top:auto;font-family:"JetBrains Mono";font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--rame);display:flex;align-items:center;gap:8px}
.proc-step .tag::before{content:"";width:6px;height:6px;background:var(--rame)}
@media(max-width:960px){
  .proc-grid{grid-template-columns:repeat(2,1fr)}
  .proc-step{border-left:0;border-top:1px solid var(--line)}
  .proc-step:first-child{border-top:0}
  .proc-step:nth-child(2){border-top:0}
  .proc-step:nth-child(2n){border-left:1px solid var(--line)}
}
@media(max-width:560px){
  .proc-grid{grid-template-columns:1fr}
  .proc-step:nth-child(2n){border-left:0}
  .proc-step:nth-child(n+2){border-top:1px solid var(--line)}
}

/* ============================================================
   CTA BANNER homepage (2 colonne)
   ============================================================ */
.hero ~ .cta-banner .cta-inner{
  text-align:left;
  display:grid;
  grid-template-columns:1.3fr 1fr;
  align-items:center;
  padding-top:110px;
  padding-bottom:110px;
  gap:64px;
}
@media(max-width:960px){
  .hero ~ .cta-banner .cta-inner{
    grid-template-columns:1fr;
    padding-top:80px;
    padding-bottom:80px;
    gap:40px;
    text-align:left;
  }
}
.hero ~ .cta-banner .cta-inner h2{
  margin:18px 0 22px;
  font-size:clamp(44px,5.4vw,76px);
  line-height:.98;
}
.cta-actions{display:flex;flex-direction:column;gap:14px;border-left:1px solid rgba(255,255,255,.12);padding-left:48px}
@media(max-width:960px){.cta-actions{border-left:0;padding-left:0;border-top:1px solid rgba(255,255,255,.12);padding-top:32px}}
.cta-action{
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 24px;border:1px solid rgba(255,255,255,.14);
  transition:background .2s ease,border-color .2s ease;
}
@media(hover:hover){.cta-action:hover{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.3)}}
.cta-action:focus-visible{outline:2px solid var(--rame);outline-offset:2px}
.cta-action .k{font:500 11px/1 "Inter";letter-spacing:.12em;text-transform:uppercase;color:var(--rame-2);margin-bottom:8px}
.cta-action .v{font-family:"Barlow Condensed";font-weight:600;font-size:20px;color:#fff;letter-spacing:.01em}
.cta-action svg{flex:none;color:rgba(255,255,255,.6)}

/* ============================================================
   CONTATTI (homepage)
   ============================================================ */
.contacts-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:80px}
@media(max-width:960px){.contacts-grid{grid-template-columns:1fr;gap:48px}}
.contacts-grid h2{font-family:"Barlow Condensed";font-weight:700;font-size:clamp(40px,4.4vw,58px);line-height:1.02;letter-spacing:-0.015em;color:var(--navy);margin:0 0 24px;text-transform:uppercase;text-wrap:balance}
.contacts-grid .lede{font-size:17px;line-height:1.6;color:var(--steel);margin:0 0 36px;max-width:380px}
.contacts-info{border-top:1px solid var(--line)}
.contacts-info > div{padding:24px 0;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;gap:24px}
.contacts-info .k{font:500 11px/1 "Inter";letter-spacing:.12em;text-transform:uppercase;color:var(--rame)}
.contacts-info .v{font-family:"Inter";font-weight:500;font-size:17px;color:var(--ink)}
.contacts-info .v.mono{font-family:"JetBrains Mono";font-size:15px}
.contacts-info a:focus-visible{outline:2px solid var(--rame);outline-offset:2px;border-radius:1px}

.home-form{background:var(--ice);border:1px solid var(--line);padding:48px;display:flex;flex-direction:column;gap:18px}
@media(max-width:720px){.home-form{padding:32px 24px}}
.form-foot{display:flex;justify-content:space-between;align-items:center;gap:20px;margin-top:6px;padding-top:24px;border-top:1px solid var(--line)}
.form-foot .small{font-size:12px;color:var(--steel);line-height:1.5;max-width:280px}
@media(max-width:720px){.form-foot{flex-direction:column-reverse;align-items:stretch}}
