/* ============================================================
   CONTATTI
   ============================================================ */
.contact{background:var(--anthracite);position:relative;overflow:hidden}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,4vw,64px)}
.contact-info .lead{margin-bottom:30px}
.info-list{display:flex;flex-direction:column;gap:2px;border:1px solid var(--line);border-radius:3px;overflow:hidden}
.info-row{display:flex;gap:18px;padding:22px 24px;background:var(--surface);align-items:flex-start}
.info-row .ic{color:var(--orange);flex:none;margin-top:2px}
.info-row .k{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--fog-dim)}
.info-row .v{font-size:16px;color:var(--white);margin-top:4px;font-weight:500}
.info-row .v a:hover{color:var(--orange)}

/* stylized map */
.map{margin-top:24px;position:relative;height:230px;border:1px solid var(--line);border-radius:3px;overflow:hidden;background:
  radial-gradient(120% 140% at 70% 20%,#22272d,#15171a)}
.map svg{position:absolute;inset:0;width:100%;height:100%}
.map .pin{position:absolute;left:62%;top:46%;transform:translate(-50%,-100%)}
.map .pin .dot{width:18px;height:18px;background:var(--orange);border:3px solid #fff;border-radius:50% 50% 50% 0;transform:rotate(-45deg);box-shadow:0 6px 18px rgba(0,0,0,.5)}
.map .pin .pulse{position:absolute;left:50%;top:50%;width:18px;height:18px;border-radius:50%;background:var(--orange);transform:translate(-50%,-50%);animation:mappulse 2.2s var(--ease) infinite;z-index:-1}
@keyframes mappulse{0%{opacity:.6;transform:translate(-50%,-50%) scale(1)}100%{opacity:0;transform:translate(-50%,-50%) scale(4.5)}}
.map .tag{position:absolute;left:16px;bottom:14px;font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;color:var(--fog);text-transform:uppercase;background:rgba(14,15,17,.6);padding:6px 10px;border-radius:2px;border:1px solid var(--line)}

/* form */
.quote{background:var(--surface);border:1px solid var(--line);border-radius:4px;padding:clamp(26px,3vw,40px)}
.quote h3{font-family:var(--font-display);text-transform:uppercase;font-size:30px;margin:0 0 4px;letter-spacing:.01em}
.quote .sub{color:var(--fog);font-size:14px;margin-bottom:24px}
.field{margin-bottom:18px}
.field label{display:block;font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--fog);margin-bottom:9px}
.field label .req{color:var(--orange)}
.field input,.field select,.field textarea{
  width:100%;background:var(--ink);border:1px solid var(--line-strong);border-radius:2px;color:var(--white);
  font-family:var(--font-sans);font-size:15px;padding:14px 15px;transition:border-color .25s,box-shadow .25s;outline:none;
}
.field textarea{resize:vertical;min-height:110px}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--orange);box-shadow:0 0 0 3px var(--orange-soft)}
.field.bad input,.field.bad select,.field.bad textarea{border-color:#ff4d4d;box-shadow:0 0 0 3px rgba(255,77,77,.14)}
.field .err{display:none;color:#ff7676;font-family:var(--font-mono);font-size:10.5px;letter-spacing:.06em;margin-top:7px;text-transform:uppercase}
.field.bad .err{display:block}
.two{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.quote .btn{width:100%;justify-content:center;margin-top:6px}
.form-ok{display:none;text-align:center;padding:30px 10px}
.form-ok.show{display:block;animation:fadeUp .5s var(--ease-out)}
.form-ok .ic{color:var(--orange);margin-bottom:16px}
.form-ok h3{margin:0 0 8px}
.form-ok p{color:var(--fog);margin:0}
.consent{display:flex;gap:10px;align-items:flex-start;font-size:12.5px;color:var(--fog-dim);line-height:1.4}
.consent input{width:auto;margin-top:3px;accent-color:var(--orange)}

