*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
:root{--bg:#f5f0e8;--paper:#ede8dc;--ink:#1a1614;--mid:#4a4038;--line:rgba(26,22,20,0.18);--red:#8b2020}
body{background:var(--bg);color:var(--ink);font-family:'Barlow',sans-serif;font-size:15px;line-height:1.7;overflow-x:hidden;cursor:none}

/* Cursore */
#cur{position:fixed;width:6px;height:6px;background:var(--red);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%)}
#cur::before{content:'';position:absolute;top:50%;left:50%;width:20px;height:1px;background:var(--red);transform:translate(-50%,-50%);opacity:.5}
#cur::after{content:'';position:absolute;top:50%;left:50%;width:1px;height:20px;background:var(--red);transform:translate(-50%,-50%);opacity:.5}
#cur2{position:fixed;width:28px;height:28px;border:1px solid rgba(139,32,32,0.3);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:left .08s,top .08s}

/* Canvas */
#topo-canvas{position:fixed;inset:0;z-index:0;pointer-events:none}
#ripple-canvas{position:fixed;inset:0;z-index:1;pointer-events:none}

/* Legenda */
#legend{position:fixed;right:1.5rem;bottom:5.5rem;z-index:50;pointer-events:none;display:flex;flex-direction:row;align-items:center;gap:.5rem;opacity:.35}
.legend-gradient{width:50px;height:3px;background:linear-gradient(to right,rgba(26,22,20,0.05),rgba(26,22,20,0.6))}
.legend-label{font-family:'Barlow Condensed',sans-serif;font-size:8px;letter-spacing:.12em;color:rgba(26,22,20,0.5)}

/* Torna su */
#back-top{position:fixed;bottom:2rem;right:2rem;z-index:200;width:42px;height:42px;background:transparent;color:var(--ink);border:1px solid rgba(26,22,20,0.4);border-radius:50%;cursor:none;display:flex;align-items:center;justify-content:center;font-size:16px;opacity:0;pointer-events:none;transition:opacity .3s,border-color .2s,color .2s,background .2s}
#back-top.show{opacity:1;pointer-events:all}
#back-top:hover{border-color:var(--red);background:var(--red);color:var(--bg)}

/* Nav */
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:1.2rem 2.5rem;display:flex;align-items:center;justify-content:space-between;background:rgba(245,240,232,0.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.logo{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:1rem;letter-spacing:.15em;text-transform:uppercase;color:var(--ink);text-decoration:none}
.logo span{color:var(--red)}
.nav-links{display:flex;gap:2.5rem;list-style:none}
.nav-links a{font-family:'Barlow Condensed',sans-serif;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--mid);text-decoration:none;transition:color .2s}
.nav-links a:hover{color:var(--red)}
.nav-right{font-family:'Barlow Condensed',sans-serif;font-size:10px;letter-spacing:.15em;color:rgba(26,22,20,0.25);display:flex;align-items:center;gap:.8rem}
.scale-bar{display:flex}
.scale-seg{width:20px;height:6px;border:1px solid rgba(26,22,20,0.3)}
.scale-seg:nth-child(odd){background:var(--ink);opacity:.25}

/* Layout */
.wrap{position:relative;z-index:10;max-width:1060px;margin:0 auto;padding:0 2.5rem}
section{padding:9rem 0}

/* Etichette sezione — Courier Prime come // 02 — progetti */
.s-label{font-family:'Courier Prime','Courier New',monospace;font-size:12px;letter-spacing:.25em;text-transform:uppercase;color:rgba(26,22,20,0.28);margin-bottom:.8rem}
.s-title{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:clamp(2rem,4vw,3.8rem);color:var(--ink);line-height:1.05;letter-spacing:-.01em;text-transform:uppercase;margin-bottom:1.5rem}
.s-title em{font-style:italic;font-weight:300;color:var(--red)}
.reveal{opacity:0;transform:translateY(20px);transition:opacity .8s ease,transform .8s ease}
.reveal.vis{opacity:1;transform:translateY(0)}

/* Hero */
#hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:9rem 0 5rem}
.hero-tag{font-family:'Barlow Condensed',sans-serif;font-size:12px;letter-spacing:.35em;text-transform:uppercase;color:var(--red);margin-bottom:1.5rem;display:flex;align-items:center;gap:1rem}
.hero-tag::before{content:'▲';font-size:8px}
.hero-title{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:clamp(5rem,13vw,12rem);line-height:.85;letter-spacing:-.02em;text-transform:uppercase;color:var(--ink)}
.hero-title .sub{display:block;font-weight:300;font-style:italic;font-size:clamp(3rem,7vw,7rem);color:var(--red);letter-spacing:0}
.hero-bottom{display:grid;grid-template-columns:1fr 1fr 1fr;gap:3rem;margin-top:4rem;padding-top:2rem;border-top:1px solid var(--line);align-items:end}
.hero-sub{font-size:14px;color:var(--mid);line-height:2;grid-column:span 2}
.hero-meta{font-family:'Barlow Condensed',sans-serif;font-size:10px;letter-spacing:.15em;line-height:2.2;color:rgba(26,22,20,0.3);text-align:right;border-left:1px solid var(--line);padding-left:2rem}
.hero-cta{grid-column:span 3;display:flex;gap:1.5rem;align-items:center;padding-top:1.5rem;border-top:1px solid var(--line)}
.btn{font-family:'Barlow Condensed',sans-serif;font-size:12px;letter-spacing:.25em;text-transform:uppercase;text-decoration:none;padding:.75rem 2rem;display:inline-block;transition:all .3s}
.btn-solid{background:var(--ink);color:var(--bg)}
.btn-solid:hover{background:var(--red)}
.btn-outline{border:1px solid var(--line);color:var(--mid)}
.btn-outline:hover{border-color:var(--red);color:var(--red)}

/* About */
#about{border-top:1px solid var(--line)}
.about-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:6rem;margin-top:4rem}
.about-text p{font-size:16px;color:var(--mid);margin-bottom:1.4rem;line-height:2}
.about-text strong{color:var(--ink);font-weight:600}
.stat-list{display:flex;flex-direction:column}
.stat-row{display:flex;align-items:center;justify-content:space-between;padding:1.2rem 0;border-bottom:1px solid var(--line)}
.stat-row:first-child{border-top:1px solid var(--line)}
.stat-n{display:flex;align-items:center;color:var(--ink);line-height:1}
.stat-l{font-family:'Barlow Condensed',sans-serif;font-size:12px;letter-spacing:.15em;text-transform:uppercase;color:rgba(26,22,20,0.35)}

/* Passioni */
#passioni{border-top:1px solid var(--line)}
.pass-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;margin-top:4rem;background:var(--line)}
.pass{background:var(--bg);padding:3rem;transition:background .3s}
.pass:last-child{grid-column:span 2}
.pass:hover{background:var(--paper)}
.pass-n{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:5rem;color:rgba(26,22,20,0.05);line-height:1;margin-bottom:1.2rem}
.pass h3{font-family:'Barlow Condensed',sans-serif;font-weight:600;font-size:1.6rem;text-transform:uppercase;letter-spacing:.05em;color:var(--ink);margin-bottom:.8rem}
.pass p{font-size:15px;color:var(--mid);line-height:2}
.tags{display:flex;flex-wrap:wrap;gap:.3rem;margin-top:1.2rem}
.tag{font-family:'Barlow Condensed',sans-serif;font-size:11px;letter-spacing:.15em;text-transform:uppercase;padding:.2rem .6rem;border:1px solid var(--line);color:rgba(26,22,20,0.4)}

/* Progetti */
#progetti{border-top:1px solid var(--line)}
.proj-top{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:end;margin-bottom:4rem}
.proj-top p{font-size:14px;color:var(--mid);line-height:2}
.proj{display:grid;grid-template-columns:56px 1fr 100px;border:1px solid var(--line);margin-bottom:-1px;background:var(--bg);position:relative;transition:background .2s}
.proj::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--red);transform:scaleY(0);transform-origin:top;transition:transform .35s}
.proj:hover{background:var(--paper)}
.proj:hover::before{transform:scaleY(1)}
.proj:hover .pn{color:var(--red)}
.mob-title{display:none}
.pn{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:1.6rem;color:rgba(26,22,20,0.12);padding:2rem 1.2rem;transition:color .3s;line-height:1}
.pb{padding:2rem;border-left:1px solid var(--line);border-right:1px solid var(--line)}
.pb h3{font-family:'Barlow Condensed',sans-serif;font-weight:600;font-size:1.2rem;text-transform:uppercase;letter-spacing:.05em;color:var(--ink);margin-bottom:.5rem}
.pb p{font-size:14px;color:var(--mid);line-height:1.85}
.pb .tags{margin-top:.8rem}
.ps{padding:2rem 1rem;display:flex;align-items:center;justify-content:center}
.status{font-family:'Barlow Condensed',sans-serif;font-size:11px;letter-spacing:.12em;text-transform:uppercase;padding:.25rem .6rem;border:1px solid}
.s-a{border-color:#2ecc71;color:#2ecc71}
.s-p{border-color:#e67e22;color:#e67e22}
.s-c{border-color:var(--red);color:var(--red)}


/* Contatti */
#contatti{border-top:1px solid var(--line)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:start;margin-top:4rem}
.ct-sub{font-size:14px;color:var(--mid);line-height:2}
.clinks{display:flex;flex-direction:column;border:1px solid var(--line)}
.clink{display:flex;align-items:center;gap:1rem;text-decoration:none;color:var(--mid);font-size:14px;padding:1.4rem 1.5rem;border-bottom:1px solid var(--line);transition:background .2s,color .2s}
.clink:last-child{border-bottom:none}
.clink:hover{background:var(--paper);color:var(--ink)}
.clink:hover .ca{transform:translateX(4px);color:var(--red)}
.cl{font-family:'Barlow Condensed',sans-serif;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:rgba(26,22,20,0.25);min-width:55px}
.ca{margin-left:auto;transition:transform .2s,color .2s}

/* Footer */
footer{border-top:2px solid var(--ink);padding:2rem 2.5rem;background:var(--ink);position:relative;overflow:hidden}
footer::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 20px,rgba(245,240,232,0.03) 20px,rgba(245,240,232,0.03) 21px)}
.fi{display:flex;justify-content:space-between;align-items:center;position:relative;z-index:1;max-width:1060px;margin:0 auto}
.fi span{font-family:'Barlow Condensed',sans-serif;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:rgba(245,240,232,0.3)}
.fi a{color:rgba(245,240,232,0.3);text-decoration:none}
.fi a:hover{color:#f5f0e8}

/* Responsive */
@media(max-width:768px){
  /* Layout generale */
  body{cursor:auto}
  #cur,#cur2{display:none}
  section{padding:5rem 0}
  .wrap{padding:0 1.2rem}

  /* Nav */
  nav{padding:.9rem 1.2rem}
  .nav-links,#legend,.nav-right{display:none}

  /* Hero */
  .hero-title{font-size:clamp(3.5rem,18vw,6rem)}
  .hero-title .sub{font-size:clamp(2rem,10vw,4rem)}
  .hero-bottom{grid-template-columns:1fr;gap:1.5rem}
  .hero-sub{grid-column:1}
  .hero-cta{grid-column:1;flex-direction:column;align-items:flex-start;gap:1rem}
  .hero-meta{display:none}

  /* Intestazioni sezione */
  .proj-top{grid-template-columns:1fr;gap:1.5rem;margin-bottom:2.5rem}
  .s-title{font-size:clamp(1.8rem,7vw,2.8rem)}

  /* About */
  .about-grid{grid-template-columns:1fr;gap:2.5rem}
  .stat-row{padding:.9rem 0}

  /* Passioni */
  .pass-grid{grid-template-columns:1fr;gap:0}
  .pass{padding:2rem 1.2rem}
  .pass:last-child{grid-column:span 1}
  .pass-n{font-size:3.5rem}

  /* Progetti: riga 1 = numero + titolo + stato | riga 2 = descrizione + tag */
  .proj{display:grid;grid-template-columns:32px 1fr 72px;grid-template-rows:auto auto;margin-bottom:-1px}
  .pn{grid-column:1;grid-row:1;font-size:.85rem;padding:.8rem .4rem;align-self:center;border:none}
  .mob-title{display:block;grid-column:2;grid-row:1;font-family:'Barlow Condensed',sans-serif;font-weight:600;font-size:.9rem;text-transform:uppercase;letter-spacing:.05em;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;align-self:center}
  .pb{grid-column:1 / 4;grid-row:2;border-left:none;border-right:none;border-top:1px solid var(--line);padding:.6rem .8rem .8rem}
  .pb h3{display:none}
  .ps{grid-column:3;grid-row:1;padding:.5rem .3rem;border:none;align-self:center;justify-content:center}

  /* Contatti */
  .contact-grid{grid-template-columns:1fr;gap:2rem}
  .clink{padding:1.1rem 1rem}

  /* Footer */
  footer{padding:1.5rem 1.2rem}
  .fi{flex-direction:column;gap:.5rem;text-align:center}
}

@media(max-width:480px){
  .hero-title{font-size:clamp(3rem,16vw,5rem)}
}

/* Animazioni icone */
@keyframes rec-blink {
  0%, 45% { opacity: 1; transform: scale(1); }
  50%, 95% { opacity: 0; transform: scale(0.5); }
  100% { opacity: 1; transform: scale(1); }
}
@keyframes lamp-pulse {
  0%, 100% { opacity: 1; }
  40%, 60% { opacity: 0.05; }
}
@keyframes glow-pulse {
  0%, 100% { opacity: 0.9; stroke-width: 0.6px; }
  40%, 60% { opacity: 0; stroke-width: 4px; }
}
@keyframes filament-drop {
  0%, 10% { stroke-dashoffset: 8; opacity: 0; }
  40%, 70% { stroke-dashoffset: 0; opacity: 1; }
  90%, 100% { stroke-dashoffset: 0; opacity: 0; }
}
@keyframes layer-draw {
  0%, 10% { stroke-dashoffset: 32; }
  60%, 90% { stroke-dashoffset: 0; }
  100% { stroke-dashoffset: 32; }
}
@keyframes code-scroll {
  0% { transform: translateY(-4px); opacity: 0; }
  20%, 80% { transform: translateY(0); opacity: 1; }
  100% { transform: translateY(4px); opacity: 0; }
}
@keyframes bracket-pulse {
  0%, 100% { stroke-width: 1.2px; }
  50% { stroke-width: 2.2px; }
}

.anim-rec {
  transform-origin: center;
  animation: rec-blink 1s step-end infinite;
}
.anim-lamp {
  animation: lamp-pulse 1.6s ease-in-out infinite;
}
.anim-glow {
  animation: glow-pulse 1.6s ease-in-out infinite;
  transform-origin: 14px 14px;
}
/* animazioni stampa e codice ora gestite con SVG animate nativo */
.anim-bracket {
  animation: bracket-pulse 1.6s ease-in-out infinite;
}
