/* Caratteri ospitati sul dominio (no Google Fonts) */
@font-face{font-family:"Fraunces";font-style:normal;font-weight:100 900;font-display:swap;src:url("fonts/fraunces.woff2") format("woff2")}
@font-face{font-family:"Hanken Grotesk";font-style:normal;font-weight:100 900;font-display:swap;src:url("fonts/hanken-grotesk.woff2") format("woff2")}

:root{
  --bg:#FBFAF7; --panel:#F2EEE7; --ink:#23211e; --navy:#14304d;
  --muted:#7a746d; --line:#e6e0d6; --red:#C8102E;
  --serif:"Fraunces",Georgia,serif; --sans:"Hanken Grotesk",-apple-system,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:18px;line-height:1.65;-webkit-font-smoothing:antialiased}
.wrap{max-width:1080px;margin:0 auto;padding:0 40px}
.narrow{max-width:820px}

/* header */
header{position:sticky;top:0;z-index:60;background:rgba(251,250,247,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.bar{display:flex;align-items:center;justify-content:space-between;height:72px;gap:20px}
.brand{font-family:var(--serif);font-weight:600;font-size:20px;color:var(--navy);text-decoration:none;letter-spacing:-.01em;white-space:nowrap}
.brand span{color:var(--red)}
nav{display:flex;align-items:center;gap:24px}
.navlinks{display:flex;gap:24px;align-items:center}
nav a.nl{font-size:13px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;text-decoration:none;color:var(--ink);opacity:.7;transition:opacity .2s;white-space:nowrap}
nav a.nl:hover{opacity:1}
.social-ico{display:inline-flex;opacity:.65;transition:opacity .2s}
.social-ico:hover{opacity:1}
.social-ico svg{width:18px;height:18px;fill:var(--navy)}
.lang{display:flex;border:1px solid var(--line);border-radius:999px;overflow:hidden}
.lang button{display:inline-flex;align-items:center;gap:5px;font-family:var(--sans);background:none;border:none;cursor:pointer;padding:6px 11px;color:var(--muted);font-size:12px;font-weight:700;letter-spacing:.03em;transition:background .15s,color .15s}
.lang button:not(:last-child){border-right:1px solid var(--line)}
.lang button:hover{color:var(--navy)}
.lang button.active{background:var(--red);color:#fff}
.lang .flag{width:17px;height:11px;border-radius:1.5px;flex:0 0 auto;display:block;box-shadow:0 0 0 .5px rgba(0,0,0,.15)}
.write{background:var(--navy);color:#fff;padding:10px 18px;border-radius:2px;text-decoration:none;font-size:13px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;white-space:nowrap;transition:background .2s}
.write:hover{background:var(--red)}
.burger{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:6px}
.burger span{width:22px;height:2px;background:var(--navy);display:block}

/* hero */
.hero-img{width:100%;height:62vh;min-height:420px;max-height:680px;background:var(--panel);position:relative;overflow:hidden;border-bottom:1px solid var(--line)}
.hero-img img{width:100%;height:100%;object-fit:cover;object-position:center 28%;display:block}
.hero-ph{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:var(--muted);font-size:13px;letter-spacing:.12em;text-transform:uppercase}
.hero-ph svg{width:80px;height:80px;opacity:.4}
.namblock{text-align:center;padding:64px 0 18px}
.namblock h1{font-family:var(--serif);font-weight:500;font-size:clamp(40px,6.5vw,74px);line-height:1;letter-spacing:-.025em;color:var(--navy)}
.namblock h1 .sn{color:var(--red)}
.namblock .cred{margin-top:22px;font-size:15px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--red)}
.rule{width:46px;height:3px;background:var(--red);margin:34px auto 0}

/* generic prose */
.lead-blk{max-width:760px;margin:0 auto;padding:56px 0 30px;text-align:center}
.lead-blk p{font-size:19px;color:#3a3631;margin-bottom:22px}
.lead-blk strong,.prose strong,.acc-body strong{color:var(--navy);font-weight:700}
.morelink{display:inline-block;margin-top:14px;font-weight:700;font-size:14px;letter-spacing:.08em;text-transform:uppercase;color:var(--red);text-decoration:none;border-bottom:2px solid var(--red);padding-bottom:3px}

/* pillars */
.faccio{border-top:1px solid var(--line);padding:74px 0}
.faccio .lbl,.news .lbl,.sec .lbl{text-align:center;font-size:13px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.faccio h2,.news h2,.sec h2{text-align:center;font-family:var(--serif);font-weight:500;font-size:clamp(28px,4vw,40px);color:var(--navy);margin-bottom:42px;letter-spacing:-.01em}
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.pillar{background:var(--bg);padding:36px 30px}
.pillar .num{font-family:var(--serif);color:var(--red);font-size:15px;font-weight:600;display:block;margin-bottom:18px}
.pillar h3{font-family:var(--serif);font-weight:600;font-size:21px;color:var(--navy);margin-bottom:12px}
.pillar p{font-size:16px;color:var(--muted);line-height:1.55}
.center-cta{text-align:center;margin-top:36px}

/* news feed */
.news{border-top:1px solid var(--line);padding:74px 0}
.feed{max-width:820px;margin:0 auto}
.item{display:block;text-decoration:none;padding:26px 4px;border-top:1px solid var(--line);transition:padding-left .25s;color:inherit}
.item:last-child{border-bottom:1px solid var(--line)}
.item:hover{padding-left:14px}
.item .date{font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--red);margin-bottom:8px;min-height:1px}
.item .ttl{font-family:var(--serif);font-weight:500;font-size:22px;color:var(--navy);line-height:1.3}
.item .src{font-size:14px;color:var(--muted);margin-top:6px}

/* contact + form */
.contact{border-top:1px solid var(--line);padding:80px 0}
.contact .head{text-align:center;margin-bottom:44px}
.contact h2{font-family:var(--serif);font-weight:500;font-size:clamp(30px,4vw,44px);color:var(--navy);margin-bottom:16px;letter-spacing:-.01em}
.contact .head p{color:var(--muted);max-width:520px;margin:0 auto}
.formwrap{max-width:620px;margin:0 auto}
.formwrap label{display:block;font-size:12.5px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin:18px 0 7px}
.formwrap input[type=text],.formwrap input[type=email],.formwrap textarea{width:100%;border:1px solid var(--line);border-radius:4px;padding:13px 15px;font-family:var(--sans);font-size:16px;color:var(--ink);background:#fff}
.formwrap input:focus,.formwrap textarea:focus{outline:none;border-color:var(--navy)}
.formwrap textarea{min-height:130px;resize:vertical;line-height:1.5}
.consent{display:flex;gap:10px;align-items:flex-start;margin-top:20px;font-size:14px;color:var(--muted);line-height:1.45}
.consent input{margin-top:4px}
.consent a{color:var(--red)}
.hp{position:absolute;left:-9999px}
.btn-send{margin-top:24px;background:var(--red);color:#fff;border:none;border-radius:2px;font-family:var(--sans);font-weight:700;font-size:15px;letter-spacing:.04em;padding:15px 34px;cursor:pointer;transition:background .2s}
.btn-send:hover{background:#a50d26}
.form-msg{margin-top:18px;font-size:15px;display:none}
.form-msg.ok{display:block;color:#1c7a3f}
.form-msg.err{display:block;color:var(--red)}

/* contact details */
.cdetails{max-width:620px;margin:46px auto 0;border-top:1px solid var(--line);padding-top:34px;display:flex;flex-wrap:wrap;gap:14px 40px;align-items:baseline}
.cdetails .pair{display:flex;flex-direction:column;gap:4px}
.cdetails .k{font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:700}
.cdetails a,.cdetails span{font-family:var(--serif);font-size:19px;color:var(--navy);text-decoration:none;border-bottom:1px solid transparent;transition:border-color .2s}
.cdetails a:hover{border-color:var(--red)}
.cdetails .sedi{font-size:14px;color:var(--muted);font-family:var(--sans)}

/* internal page (bio / servizi) */
.page-top{padding:64px 0 10px}
.page-photo{width:100%;max-width:560px;margin:0 auto 40px;aspect-ratio:16/10;background:var(--panel);border:1px solid var(--line);overflow:hidden;position:relative}
.page-photo img{width:100%;height:100%;object-fit:cover;display:block}
.page-photo .hero-ph{font-size:12px}
.page-h{font-family:var(--serif);font-weight:600;font-size:clamp(30px,4.5vw,44px);color:var(--navy);letter-spacing:-.015em;margin-bottom:8px}
.page-sub{font-size:13px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--red);margin-bottom:8px}
.hr-red{width:46px;height:3px;background:var(--red);margin:22px 0 30px}
.prose p{margin-bottom:20px;color:#3a3631}
.acc{margin-top:36px;border-top:1px solid var(--line)}
.acc details{border-bottom:1px solid var(--line)}
.acc summary{list-style:none;cursor:pointer;padding:24px 40px 24px 4px;font-family:var(--serif);font-weight:500;font-size:21px;color:var(--navy);position:relative;transition:color .2s}
.acc summary::-webkit-details-marker{display:none}
.acc summary:hover{color:var(--red)}
.acc summary::after{content:"+";position:absolute;right:4px;top:50%;transform:translateY(-50%);font-family:var(--sans);font-weight:400;font-size:26px;color:var(--red);line-height:1}
.acc details[open] summary::after{content:"\2212"}
.acc-body{padding:0 4px 28px}
.acc-body p{margin-bottom:16px;color:#3a3631;max-width:760px}
.acc-body p:last-child{margin-bottom:0}
.backhome{display:inline-block;margin:50px 0 0;font-size:14px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--navy);text-decoration:none}
.backhome:hover{color:var(--red)}

/* privacy */
.legal{padding:60px 0}
.legal h1{font-family:var(--serif);font-weight:600;font-size:34px;color:var(--navy);margin-bottom:8px}
.legal h2{font-family:var(--serif);font-weight:600;font-size:21px;color:var(--navy);margin:30px 0 10px}
.legal p{margin-bottom:14px;color:#3a3631;font-size:16px}

footer{border-top:1px solid var(--line);padding:40px 0;font-size:13px;color:var(--muted)}
.foot{display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;align-items:center}
.foot a{color:var(--muted);text-decoration:none;border-bottom:1px solid transparent}
.foot a:hover{border-color:var(--red);color:var(--navy)}
.foot .fsoc{display:flex;gap:16px}
.foot .fsoc svg{width:17px;height:17px;fill:var(--muted)}
.foot .fsoc a:hover svg{fill:var(--navy)}

.rv{opacity:0;transform:translateY(16px);transition:opacity .7s ease,transform .7s ease}
.rv.in{opacity:1;transform:none}

@media(max-width:860px){
  .wrap{padding:0 22px}
  .burger{display:flex}
  .navlinks{display:none;position:absolute;top:72px;left:0;right:0;background:var(--bg);border-bottom:1px solid var(--line);flex-direction:column;gap:0;padding:8px 0}
  .navlinks.open{display:flex}
  .navlinks a.nl{padding:14px 24px;width:100%}
  .navlinks .social-ico{padding:14px 24px}
  nav{gap:14px}
  .lang button{padding:6px 8px;font-size:11px}
  .write{padding:9px 12px;font-size:12px}
  .pillars{grid-template-columns:1fr}
  .hero-img{height:48vh}
  .cdetails{gap:18px 30px}
}

@media(max-width:560px){
  .lang button .code{display:none}
  .lang button{padding:6px 7px}
}
