/* ============ FONT LOCALI (nessuna chiamata a server esterni) ============ */
@font-face{font-family:'Archivo';src:url('fonts/archivo.woff2') format('woff2');font-weight:100 900;font-stretch:62% 125%;font-style:normal;font-display:swap}
@font-face{font-family:'Manrope';src:url('fonts/manrope.woff2') format('woff2');font-weight:200 800;font-style:normal;font-display:swap}
@font-face{font-family:'Lora';src:url('fonts/lora-italic.woff2') format('woff2');font-weight:400 700;font-style:italic;font-display:swap}
@font-face{font-family:'IBM Plex Mono';src:url('fonts/plexmono-reg.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'IBM Plex Mono';src:url('fonts/plexmono-med.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap}

/* ============================================================
   EMME TRE — Tavola tecnica n.01
   Sistema: grafite + arancione cantiere + carta da spolvero
   Display: Archivo (expanded) · Body: Manrope
   Utility: IBM Plex Mono · Accento editoriale: Lora italic
   ============================================================ */

:root{
  --ink:#1C1C1B;
  --graphite:#2B2B2B;
  --cantiere:#F07800;
  --cantiere-deep:#D96A00;
  --carta:#EFEDE8;
  --bianco:#FFFFFF;
  --cemento:#8B8983;
  --cemento-scuro:#6E6C66;
  --linea:#DCD9D1;
  --linea-dark:#3B3B39;

  --f-display:'Archivo',sans-serif;
  --f-body:'Manrope',sans-serif;
  --f-mono:'IBM Plex Mono',monospace;
  --f-serif:'Lora',serif;

  --mx:6vw;
  --max:1480px;
  --ease:cubic-bezier(.16,1,.3,1);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:auto}
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}

body{
  font-family:var(--f-body);
  background:var(--carta);
  color:var(--ink);
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

::selection{background:var(--cantiere);color:var(--bianco)}

img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}

/* ---- grain sottile ---- */
body::after{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:2000;
  opacity:.05;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)' opacity='.6'/%3E%3C/svg%3E");
}

/* ============ UTILITY TIPOGRAFICHE ============ */
.eyebrow{
  font-family:var(--f-mono);
  font-size:12px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--cantiere);display:inline-flex;align-items:center;gap:12px;
}
.eyebrow::before{content:'';width:34px;height:1px;background:var(--cantiere)}

.h-display{
  font-family:var(--f-display);
  font-variation-settings:'wdth' 112;
  font-weight:850;
  text-transform:uppercase;
  line-height:.92;
  letter-spacing:-.01em;
}

.mono{font-family:var(--f-mono);font-size:12.5px;letter-spacing:.08em}

.container{max-width:var(--max);margin:0 auto;padding-left:var(--mx);padding-right:var(--mx)}

/* ============ QUOTA ARCHITETTONICA (signature) ============ */
.quota{
  position:relative;display:flex;align-items:center;justify-content:center;
  font-family:var(--f-mono);font-size:12px;letter-spacing:.12em;color:var(--cemento-scuro);
  padding:0 14px;
}
.quota::before,.quota::after{content:'';flex:1;height:1px;background:currentColor;opacity:.45}
.quota span{padding:0 16px;white-space:nowrap}
.quota .tick-l,.quota .tick-r{width:1px;height:14px;background:currentColor;opacity:.45}

/* ============ PRELOADER ============ */
#preloader{
  position:fixed;inset:0;z-index:1000;
  background:var(--ink);color:var(--carta);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:26px;
}
#preloader .pl-logo{
  font-family:var(--f-display);font-variation-settings:'wdth' 120;
  font-weight:900;font-size:clamp(34px,6vw,64px);text-transform:uppercase;letter-spacing:.02em;
}
#preloader .pl-logo em{font-style:normal;color:var(--cantiere)}
#preloader .pl-count{
  font-family:var(--f-mono);font-size:13px;letter-spacing:.18em;color:var(--cemento);
}
#preloader .pl-bar{
  width:min(320px,60vw);height:1px;background:var(--linea-dark);position:relative;overflow:hidden;
}
#preloader .pl-bar i{position:absolute;left:0;top:0;bottom:0;width:0%;background:var(--cantiere)}

#curtain{
  position:fixed;inset:0;z-index:1001;background:var(--cantiere);
  transform:translateY(101%);display:flex;align-items:center;justify-content:center;
  pointer-events:none;
}
#curtain span{
  font-family:var(--f-display);font-variation-settings:'wdth' 122;font-weight:900;
  text-transform:uppercase;color:var(--ink);font-size:clamp(40px,8vw,110px);letter-spacing:.02em;
}

/* ============ PROGRESS + NAV ============ */
#progress{position:fixed;top:0;left:0;height:2px;width:0%;background:var(--cantiere);z-index:950}

#nav{
  position:fixed;top:0;left:0;right:0;z-index:900;
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;
  padding:22px var(--mx);
  transition:transform .5s var(--ease),background .4s,padding .4s,box-shadow .4s;
}
#nav.hidden{transform:translateY(-110%)}
#nav.scrolled{background:rgba(239,237,232,.92);backdrop-filter:blur(12px);padding:12px var(--mx);box-shadow:0 1px 0 var(--linea)}

#nav .nav-left{justify-self:start}
#nav .nav-logo{justify-self:center;text-align:center;line-height:1}
#nav .nav-right{justify-self:end}

.nav-logo a{
  font-family:var(--f-display);font-variation-settings:'wdth' 120;font-weight:900;
  text-transform:uppercase;letter-spacing:.02em;
  font-size:30px;color:var(--bianco);transition:font-size .4s var(--ease),color .4s;
  display:inline-block;
}
.nav-logo a em{font-style:normal;color:var(--cantiere)}
.nav-logo .nav-sub{
  display:block;font-family:var(--f-mono);font-size:9.5px;letter-spacing:.32em;
  color:rgba(255,255,255,.65);margin-top:5px;text-transform:uppercase;transition:color .4s;
}
#nav.scrolled .nav-logo a{font-size:21px;color:var(--ink)}
#nav.scrolled .nav-sub{color:var(--cemento-scuro)}

.nav-left .mono{color:rgba(255,255,255,.7);transition:color .4s}
#nav.scrolled .nav-left .mono{color:var(--cemento-scuro)}
@media(max-width:860px){.nav-left{display:none}}

.nav-cta{
  font-family:var(--f-mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--bianco);border:1px solid rgba(255,255,255,.45);padding:11px 20px;
  transition:all .35s var(--ease);display:inline-block;
}
.nav-cta:hover{background:var(--cantiere);border-color:var(--cantiere);color:var(--ink)}
#nav.scrolled .nav-cta{color:var(--ink);border-color:var(--ink)}
#nav.scrolled .nav-cta:hover{background:var(--ink);color:var(--carta)}

/* ---- logo immagine (appare se foto/logo.png esiste) ---- */
.nav-logo .logo-img{
  display:none;max-height:46px;max-width:min(76vw,460px);width:auto;height:auto;margin:0 auto;
  transition:max-height .4s var(--ease);
}
.nav-logo.has-logo .logo-img--light{display:block}
#nav.scrolled .nav-logo.has-logo .logo-img--light{display:none}
#nav.scrolled .nav-logo.has-logo .logo-img--dark{display:block}
body.menu-open .nav-logo.has-logo .logo-img--light{display:block!important}
body.menu-open .nav-logo.has-logo .logo-img--dark{display:none!important}
.nav-logo.has-logo .logo-text,.nav-logo.has-logo .nav-sub{display:none}
#nav.scrolled .logo-img{max-height:32px}
.pl-logo-img{display:block;max-height:64px;max-width:74vw;width:auto;height:auto;margin:0 auto}
.pl-logo.has-img .pl-logo-text{display:none}

/* ---- burger ---- */
.menu-btn{
  display:inline-flex;align-items:center;gap:14px;
  font-family:var(--f-mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--bianco);padding:10px 0;transition:color .4s;
}
#nav.scrolled .menu-btn{color:var(--ink)}
.menu-btn .bars{position:relative;width:30px;height:12px}
.menu-btn .bars span{
  position:absolute;left:0;right:0;height:1.6px;background:currentColor;
  transition:transform .45s var(--ease),top .45s var(--ease),width .45s var(--ease);
}
.menu-btn .bars span:nth-child(1){top:0}
.menu-btn .bars span:nth-child(2){top:10px;width:70%}
.menu-btn:hover .bars span:nth-child(2){width:100%}
body.menu-open .menu-btn .bars span:nth-child(1){top:5px;transform:rotate(45deg)}
body.menu-open .menu-btn .bars span:nth-child(2){top:5px;width:100%;transform:rotate(-45deg)}
body.menu-open #nav{z-index:975;background:transparent;box-shadow:none}
body.menu-open .menu-btn,body.menu-open #nav.scrolled .menu-btn{color:var(--carta)}
body.menu-open .nav-logo a,body.menu-open #nav.scrolled .nav-logo a{color:var(--carta)}
body.menu-open .nav-sub,body.menu-open #nav.scrolled .nav-sub{color:var(--cemento)}
body.menu-open .nav-left .mono{color:var(--cemento)}
body.menu-open #nav.hidden{transform:none}

/* ---- overlay menu ---- */
#menuOverlay{
  position:fixed;inset:0;z-index:960;background:var(--ink);color:var(--carta);
  clip-path:inset(0 0 100% 0);visibility:hidden;
  transition:clip-path .85s var(--ease),visibility .85s;
  overflow-y:auto;
}
body.menu-open #menuOverlay{clip-path:inset(0 0 0% 0);visibility:visible}
#menuOverlay::before{
  content:'';position:absolute;inset:0;pointer-events:none;opacity:.5;
  background:
    repeating-linear-gradient(0deg,transparent,transparent 89px,rgba(240,120,0,.07) 89px,rgba(240,120,0,.07) 90px),
    repeating-linear-gradient(90deg,transparent,transparent 89px,rgba(240,120,0,.07) 89px,rgba(240,120,0,.07) 90px);
}
.menu-inner{
  position:relative;min-height:100%;
  display:grid;grid-template-columns:minmax(0,1.35fr) minmax(0,.65fr);
  gap:60px;padding:150px var(--mx) 70px;max-width:var(--max);margin:0 auto;
}
.menu-list{display:flex;flex-direction:column}
.menu-link{
  display:flex;align-items:baseline;gap:26px;
  padding:14px 0;border-bottom:1px solid var(--linea-dark);
  opacity:0;transform:translateY(36px);
  transition:opacity .6s var(--ease),transform .6s var(--ease);
}
body.menu-open .menu-link{opacity:1;transform:translateY(0)}
body.menu-open .menu-link:nth-child(1){transition-delay:.22s}
body.menu-open .menu-link:nth-child(2){transition-delay:.28s}
body.menu-open .menu-link:nth-child(3){transition-delay:.34s}
body.menu-open .menu-link:nth-child(4){transition-delay:.40s}
body.menu-open .menu-link:nth-child(5){transition-delay:.46s}
body.menu-open .menu-link:nth-child(6){transition-delay:.52s}
.menu-link .n{font-family:var(--f-mono);font-size:12px;letter-spacing:.14em;color:var(--cantiere);flex:0 0 44px}
.menu-link .t{
  font-family:var(--f-display);font-variation-settings:'wdth' 110;font-weight:850;text-transform:uppercase;
  font-size:clamp(30px,4.6vw,62px);line-height:1.05;letter-spacing:-.01em;
  color:var(--cemento);transition:color .35s,letter-spacing .35s;
}
.menu-link .pg{font-family:var(--f-mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--cemento-scuro);margin-left:auto}
.menu-link:hover .t{color:var(--carta);letter-spacing:.005em}
.menu-link:hover .pg{color:var(--cantiere)}
.menu-side{
  display:flex;flex-direction:column;gap:34px;justify-content:flex-end;padding-bottom:14px;
  opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease) .5s,transform .7s var(--ease) .5s;
}
body.menu-open .menu-side{opacity:1;transform:translateY(0)}
.menu-side .blocco{border-top:1px solid var(--linea-dark);padding-top:20px}
.menu-side .k{font-family:var(--f-mono);font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--cemento);display:block;margin-bottom:10px}
.menu-side .v{font-size:16px;font-weight:500;line-height:1.7}
.menu-side .v a:hover{color:var(--cantiere)}
@media(max-width:980px){
  .menu-inner{grid-template-columns:1fr;padding-top:120px;gap:44px}
  .menu-side{justify-content:flex-start}
}

/* ---- foto fratelli nel preloader ---- */
.pl-photo{position:absolute;inset:0;overflow:hidden}
.pl-photo img{
  width:100%;height:100%;object-fit:cover;
  filter:grayscale(1) contrast(1.08) brightness(.5);
  opacity:0;
}
.pl-photo::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center,rgba(28,28,27,.25),rgba(28,28,27,.82))}
#preloader .pl-logo,#preloader .pl-bar,#preloader .pl-count{position:relative;z-index:2}

/* ---- foto fratelli in sezione storia ---- */
.storia-visual{position:relative;overflow:hidden}
.storia-visual .sv-img{
  width:100%;aspect-ratio:4/3.4;object-fit:cover;
  filter:grayscale(1) contrast(1.06) brightness(.82);
  border:1px solid var(--linea-dark);
}
.storia-visual:hover .sv-img{filter:grayscale(.25) contrast(1.04) brightness(.9)}
.storia-visual .sv-img{transition:filter .8s var(--ease)}
.storia-visual .sv-cap{
  position:absolute;left:18px;bottom:64px;
  font-family:var(--f-mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(239,237,232,.85);background:rgba(28,28,27,.55);padding:8px 12px;backdrop-filter:blur(4px);
}
.storia-visual .storia-anno{
  position:absolute;left:0;right:0;bottom:-14px;text-align:left;
}
.storia-visual.no-photo .storia-anno{position:static;text-align:left}
.storia-visual.no-photo .sv-cap{display:none}

/* ============ HERO SLIDESHOW ============ */
#hero{position:relative;height:100vh;height:100svh;min-height:620px;background:var(--ink);overflow:hidden;color:var(--bianco)}

.slide{position:absolute;inset:0;opacity:0;visibility:hidden;transition:opacity 1.1s ease,visibility 1.1s}
.slide.active{opacity:1;visibility:visible}

.slide .media{position:absolute;inset:0;overflow:hidden}
.slide .media img{
  width:100%;height:100%;object-fit:cover;
  transform:scale(1);filter:brightness(.62) saturate(1.04);
}
.slide.active .media img{animation:kenburns 7s ease-out forwards}
@keyframes kenburns{from{transform:scale(1)}to{transform:scale(1.08)}}

/* placeholder blueprint quando manca la foto */
.slide .ph{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:
    linear-gradient(rgba(28,28,27,.6),rgba(28,28,27,.85)),
    repeating-linear-gradient(0deg,transparent,transparent 79px,rgba(240,120,0,.13) 79px,rgba(240,120,0,.13) 80px),
    repeating-linear-gradient(90deg,transparent,transparent 79px,rgba(240,120,0,.13) 79px,rgba(240,120,0,.13) 80px),
    var(--graphite);
}
.slide .ph .ph-tag{
  font-family:var(--f-mono);font-size:12px;letter-spacing:.16em;color:var(--cemento);
  border:1px dashed var(--linea-dark);padding:14px 22px;text-transform:uppercase;text-align:center;line-height:2;
}
.slide .ph .ph-tag b{color:var(--cantiere);font-weight:500}

.slide .veil{position:absolute;inset:0;background:linear-gradient(to top,rgba(28,28,27,.88) 0%,rgba(28,28,27,.25) 45%,rgba(28,28,27,.35) 100%)}

.slide-content{
  position:absolute;left:var(--mx);right:var(--mx);bottom:13vh;z-index:5;max-width:1100px;
}
.slide-label{
  font-family:var(--f-mono);font-size:12.5px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--cantiere);margin-bottom:20px;display:block;
}
.slide-title{
  font-family:var(--f-display);font-variation-settings:'wdth' 110;font-weight:870;
  text-transform:uppercase;line-height:.93;letter-spacing:-.012em;
  font-size:clamp(40px,7.4vw,108px);
}
.slide-title .accent{color:var(--cantiere)}
.slide-desc{
  margin-top:24px;max-width:520px;color:rgba(255,255,255,.78);
  font-size:16px;line-height:1.7;
}

/* reveal interno slide */
.slide .rv{opacity:0;transform:translateY(34px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.slide.active .rv{opacity:1;transform:translateY(0)}
.slide.active .rv:nth-child(1){transition-delay:.25s}
.slide.active .rv:nth-child(2){transition-delay:.4s}
.slide.active .rv:nth-child(3){transition-delay:.55s}

/* controlli */
.hero-arrow{
  position:absolute;top:50%;transform:translateY(-50%);z-index:10;
  width:58px;height:58px;border:1px solid rgba(255,255,255,.3);border-radius:0;
  display:flex;align-items:center;justify-content:center;color:var(--bianco);
  transition:all .35s var(--ease);
}
.hero-arrow:hover{background:var(--cantiere);border-color:var(--cantiere);color:var(--ink)}
.hero-arrow svg{width:20px;height:20px}
.hero-arrow.prev{left:calc(var(--mx) - 10px)}
.hero-arrow.next{right:calc(var(--mx) - 10px)}
@media(max-width:860px){.hero-arrow{display:none}}

.hero-indicators{
  position:absolute;bottom:5vh;left:var(--mx);z-index:10;display:flex;gap:10px;align-items:center;
}
.ind{width:34px;height:2px;background:rgba(255,255,255,.3);position:relative;overflow:hidden;transition:width .4s var(--ease);padding:0}
.ind i{position:absolute;left:0;top:0;bottom:0;width:0%;background:var(--cantiere)}
.ind.active{width:64px}

.hero-counter{
  position:absolute;bottom:4.4vh;right:var(--mx);z-index:10;
  font-family:var(--f-mono);font-size:13px;letter-spacing:.18em;color:rgba(255,255,255,.75);
}
.hero-counter b{color:var(--bianco);font-weight:500}

.hero-scrollhint{
  position:absolute;bottom:4.6vh;left:50%;transform:translateX(-50%);z-index:10;
  font-family:var(--f-mono);font-size:10.5px;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.55);
  display:flex;flex-direction:column;align-items:center;gap:10px;
}
.hero-scrollhint::after{content:'';width:1px;height:34px;background:linear-gradient(var(--cantiere),transparent);animation:drop 1.8s ease-in-out infinite}
@keyframes drop{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}
@media(max-width:860px){.hero-scrollhint{display:none}}

/* ============ MARQUEE ============ */
#marquee{
  background:var(--ink);color:var(--carta);overflow:hidden;white-space:nowrap;
  border-top:1px solid var(--linea-dark);padding:16px 0;
}
.mq-track{display:inline-flex;gap:0;animation:mq 36s linear infinite;will-change:transform}
.mq-track span{
  font-family:var(--f-mono);font-size:12.5px;letter-spacing:.22em;text-transform:uppercase;
  padding:0 34px;color:var(--cemento);
}
.mq-track span b{color:var(--cantiere);font-weight:500;padding-right:34px}
@keyframes mq{to{transform:translateX(-50%)}}

/* ============ SEZIONI BASE ============ */
.sec{padding:130px 0}
.sec--dark{background:var(--ink);color:var(--carta)}
.sec--paper{background:var(--carta);color:var(--ink)}

.sec-head{display:grid;grid-template-columns:1fr;gap:26px;margin-bottom:74px}
.sec-title{
  font-size:clamp(38px,6vw,92px);
}
.sec-title .outline{
  color:transparent;-webkit-text-stroke:1.5px currentColor;
}
.sec--paper .sec-title .outline{-webkit-text-stroke:1.5px var(--ink)}
.sec--dark .sec-title .outline{-webkit-text-stroke:1.5px var(--carta)}

/* riga reveal */
.line-rv{display:block;overflow:hidden}
.line-rv>span{display:block;transform:translateY(110%)}

/* ============ MANIFESTO ============ */
#manifesto{padding-top:120px;padding-bottom:100px}
.man-grid{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(0,.75fr);gap:80px;align-items:start}
.man-text{
  font-size:clamp(22px,2.5vw,34px);line-height:1.45;font-weight:500;letter-spacing:-.01em;
}
.man-text .hl{color:var(--cantiere)}
.man-quote{
  font-family:var(--f-serif);font-style:italic;font-size:clamp(20px,1.8vw,25px);
  line-height:1.55;color:var(--cemento-scuro);
  border-left:2px solid var(--cantiere);padding-left:28px;margin-top:8px;
}
.man-quote .firma{
  display:block;margin-top:18px;font-family:var(--f-mono);font-style:normal;
  font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--cemento);
}
@media(max-width:980px){.man-grid{grid-template-columns:1fr;gap:46px}}

/* ============ STATS / QUOTE ============ */
#stats{padding:0 0 130px}
.stats-grid{
  display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--linea);
}
.stat{
  padding:44px 30px 40px;border-right:1px solid var(--linea);position:relative;
}
.stat:last-child{border-right:none}
.stat-num{
  font-family:var(--f-display);font-variation-settings:'wdth' 105;font-weight:850;
  font-size:clamp(46px,4.6vw,76px);line-height:1;letter-spacing:-.01em;
}
.stat-num sup{font-size:.42em;color:var(--cantiere);font-weight:800;vertical-align:super}
.stat-label{margin-top:14px}
.stat .quota{justify-content:flex-start;padding:0;margin-top:22px;color:var(--cemento)}
.stat .quota::before{display:none}
.stat .quota::after{flex:1}
.stat .quota span{padding-left:0}
@media(max-width:980px){
  .stats-grid{grid-template-columns:1fr 1fr}
  .stat:nth-child(2){border-right:none}
  .stat:nth-child(-n+2){border-bottom:1px solid var(--linea)}
}
@media(max-width:560px){
  .stats-grid{grid-template-columns:1fr}
  .stat{border-right:none;border-bottom:1px solid var(--linea)}
  .stat:last-child{border-bottom:none}
}

/* ============ SERVIZI ============ */
.serv-list{border-top:1px solid var(--linea)}
.serv{
  display:grid;grid-template-columns:120px minmax(0,1fr) minmax(0,1.1fr) 60px;
  gap:34px;align-items:center;
  padding:42px 0;border-bottom:1px solid var(--linea);
  transition:background .4s,padding .4s var(--ease);
  position:relative;cursor:default;
}
.serv:hover{background:var(--bianco);padding-left:22px;padding-right:22px}
.serv-code{font-family:var(--f-mono);font-size:12px;letter-spacing:.12em;color:var(--cemento);text-transform:uppercase;line-height:1.9}
.serv-code b{display:block;color:var(--cantiere);font-weight:500}
.serv-name{
  font-family:var(--f-display);font-variation-settings:'wdth' 106;font-weight:800;text-transform:uppercase;
  font-size:clamp(22px,2.4vw,34px);line-height:1.02;letter-spacing:-.008em;
  transition:color .3s;
}
.serv:hover .serv-name{color:var(--cantiere)}
.serv-desc{color:var(--cemento-scuro);font-size:15.5px;line-height:1.7}
.serv-arrow{
  width:46px;height:46px;border:1px solid var(--linea);display:flex;align-items:center;justify-content:center;
  transition:all .35s var(--ease);justify-self:end;
}
.serv:hover .serv-arrow{background:var(--cantiere);border-color:var(--cantiere);color:var(--bianco);transform:rotate(-45deg)}
.serv-arrow svg{width:17px;height:17px}
@media(max-width:980px){
  .serv{grid-template-columns:1fr;gap:14px;align-items:start}
  .serv-arrow{display:none}
  .serv:hover{padding-left:0;padding-right:0;background:transparent}
}

/* ============ SPECIALIZZAZIONI (pin orizzontale) ============ */
#spec{background:var(--ink);color:var(--carta);position:relative;overflow:hidden}
.spec-intro{padding:120px 0 70px}
.spec-intro .sec-title{max-width:1100px}
.spec-wrap{position:relative}
.spec-track{display:flex;will-change:transform}
.panel{
  flex:0 0 100vw;min-height:100vh;min-height:100svh;
  display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  border-top:1px solid var(--linea-dark);
}
.panel-visual{
  position:relative;border-right:1px solid var(--linea-dark);overflow:hidden;
  background:
    linear-gradient(rgba(28,28,27,.35),rgba(28,28,27,.7)),
    repeating-linear-gradient(0deg,transparent,transparent 69px,rgba(240,120,0,.12) 69px,rgba(240,120,0,.12) 70px),
    repeating-linear-gradient(90deg,transparent,transparent 69px,rgba(240,120,0,.12) 69px,rgba(240,120,0,.12) 70px),
    var(--graphite);
  display:flex;align-items:flex-end;
}
.panel-visual img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.7) saturate(1.05)}
.panel-bignum{
  position:relative;z-index:2;
  font-family:var(--f-display);font-variation-settings:'wdth' 118;font-weight:900;
  font-size:clamp(120px,22vw,330px);line-height:.78;color:transparent;
  -webkit-text-stroke:1.5px rgba(240,120,0,.85);
  padding:0 0 28px 36px;user-select:none;
}
.panel-body{padding:clamp(40px,6vw,90px);display:flex;flex-direction:column;justify-content:center;gap:26px}
.panel-tag{display:flex;align-items:center;gap:16px}
.badge-new{
  font-family:var(--f-mono);font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;
  background:var(--cantiere);color:var(--ink);padding:6px 12px;font-weight:500;
  animation:pulse 2.4s ease-in-out infinite;
}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(240,120,0,.5)}50%{box-shadow:0 0 0 9px rgba(240,120,0,0)}}
.panel-title{
  font-size:clamp(34px,4.2vw,64px);
}
.panel-desc{color:rgba(239,237,232,.72);max-width:480px;font-size:16px;line-height:1.75}
.panel-points{list-style:none;display:flex;flex-direction:column;gap:13px;margin-top:6px}
.panel-points li{
  display:flex;gap:14px;align-items:baseline;font-size:15px;color:rgba(239,237,232,.85);
}
.panel-points li::before{
  content:'—';color:var(--cantiere);font-family:var(--f-mono);flex:0 0 auto;
}
.spec-progress{
  position:absolute;bottom:34px;left:var(--mx);right:var(--mx);height:1px;background:var(--linea-dark);z-index:5;
}
.spec-progress i{position:absolute;left:0;top:0;bottom:0;width:0%;background:var(--cantiere)}
@media(max-width:1023px){
  .spec-track{display:block}
  .panel{flex:none;grid-template-columns:1fr;min-height:0}
  .panel-visual{min-height:300px;border-right:none;border-bottom:1px solid var(--linea-dark)}
  .spec-progress{display:none}
}

/* ============ COMMITTENZA ============ */
.comm-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--linea);border:1px solid var(--linea)}
.comm{
  background:var(--carta);padding:42px 32px 48px;display:flex;flex-direction:column;gap:18px;
  transition:background .4s,transform .4s var(--ease);position:relative;min-height:280px;
}
.comm:hover{background:var(--bianco);transform:translateY(-6px)}
.comm-ico{width:44px;height:44px;color:var(--cantiere)}
.comm-ico svg{width:100%;height:100%}
.comm h3{
  font-family:var(--f-display);font-variation-settings:'wdth' 106;font-weight:800;
  text-transform:uppercase;font-size:19px;letter-spacing:.005em;line-height:1.15;
}
.comm p{font-size:14.5px;color:var(--cemento-scuro);line-height:1.7}
.comm .mono{margin-top:auto;color:var(--cemento)}
@media(max-width:980px){.comm-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.comm-grid{grid-template-columns:1fr}}

/* ============ STORIA ============ */
#storia .man-grid{align-items:center}
.storia-anno{
  font-family:var(--f-display);font-variation-settings:'wdth' 118;font-weight:900;
  font-size:clamp(110px,16vw,260px);line-height:.82;letter-spacing:-.02em;
  color:transparent;-webkit-text-stroke:1.5px var(--carta);
  user-select:none;
}
.storia-anno .fill{color:var(--cantiere);-webkit-text-stroke:0}
.storia-txt p{color:rgba(239,237,232,.8);margin-bottom:22px;font-size:16.5px}
.storia-txt p b{color:var(--carta);font-weight:600}
.fratelli{display:flex;gap:0;margin-top:34px;border:1px solid var(--linea-dark)}
.fratello{
  flex:1;padding:22px 18px;border-right:1px solid var(--linea-dark);text-align:center;
}
.fratello:last-child{border-right:none}
.fratello b{
  display:block;font-family:var(--f-display);font-variation-settings:'wdth' 108;
  font-weight:800;text-transform:uppercase;font-size:17px;margin-bottom:7px;
}
.fratello span{font-family:var(--f-mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--cemento)}
@media(max-width:560px){.fratelli{flex-direction:column}.fratello{border-right:none;border-bottom:1px solid var(--linea-dark)}.fratello:last-child{border-bottom:none}}

/* ============ CERTIFICAZIONI ============ */
.cert-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.cert{
  border:1px solid var(--linea);padding:36px 32px;background:var(--bianco);position:relative;
  display:flex;flex-direction:column;gap:14px;min-height:230px;
  transition:border-color .35s,transform .35s var(--ease);
}
.cert:hover{border-color:var(--cantiere);transform:translateY(-5px)}
.cert::before{
  content:attr(data-n);position:absolute;top:30px;right:30px;
  font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;color:var(--cemento);
}
.cert-sigla{
  font-family:var(--f-display);font-variation-settings:'wdth' 112;font-weight:870;text-transform:uppercase;
  font-size:clamp(30px,3vw,42px);line-height:1;
}
.cert-sigla em{font-style:normal;color:var(--cantiere)}
.cert p{font-size:14.5px;color:var(--cemento-scuro);line-height:1.7}
.cert .mono{margin-top:auto;color:var(--cemento);border-top:1px solid var(--linea);padding-top:16px}
@media(max-width:980px){.cert-grid{grid-template-columns:1fr}}

/* ============ CTA ============ */
#cta,.cta-band{background:var(--cantiere);color:var(--ink);padding:110px 0;position:relative;overflow:hidden}
#cta .cta-big{
  font-size:clamp(42px,7vw,104px);max-width:1200px;
}
#cta .cta-big .ghost{color:transparent;-webkit-text-stroke:1.6px var(--ink)}
#cta p{margin-top:26px;max-width:560px;font-size:17px;font-weight:500}
.cta-row{display:flex;gap:18px;margin-top:44px;flex-wrap:wrap}
.btn{
  font-family:var(--f-mono);font-size:13px;letter-spacing:.12em;text-transform:uppercase;
  padding:18px 34px;display:inline-flex;align-items:center;gap:12px;
  transition:all .35s var(--ease);position:relative;overflow:hidden;
}
.btn-dark{background:var(--ink);color:var(--carta)}
.btn-dark:hover{background:var(--graphite);transform:translateY(-3px);box-shadow:0 14px 30px rgba(28,28,27,.3)}
.btn-line{border:1.5px solid var(--ink);color:var(--ink)}
.btn-line:hover{background:var(--ink);color:var(--cantiere)}

/* ============ CONTATTI / FOOTER ============ */
#contatti,.footer-int{background:var(--ink);color:var(--carta);padding:130px 0 0}
.cont-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:90px;align-items:start}
.cont-info h2{font-size:clamp(36px,4.6vw,64px);margin-bottom:40px}
.cont-rows{display:flex;flex-direction:column}
.cont-row{
  display:grid;grid-template-columns:130px 1fr;gap:24px;padding:20px 0;
  border-bottom:1px solid var(--linea-dark);align-items:baseline;
}
.cont-row .k{font-family:var(--f-mono);font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--cemento)}
.cont-row .v{font-size:17px;font-weight:500}
.cont-row .v a{border-bottom:1px solid transparent;transition:border-color .3s,color .3s}
.cont-row .v a:hover{color:var(--cantiere);border-color:var(--cantiere)}

.cont-form{display:flex;flex-direction:column;gap:0;border:1px solid var(--linea-dark)}
.cont-form .form-head{
  padding:24px 28px;border-bottom:1px solid var(--linea-dark);
  font-family:var(--f-mono);font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--cemento);
  display:flex;justify-content:space-between;
}
.cont-form .form-head b{color:var(--cantiere);font-weight:500}
.fgroup{position:relative;border-bottom:1px solid var(--linea-dark)}
.fgroup input,.fgroup textarea{
  width:100%;background:transparent;border:none;color:var(--carta);
  font-family:var(--f-body);font-size:16px;padding:24px 28px;outline:none;resize:vertical;
}
.fgroup input::placeholder,.fgroup textarea::placeholder{color:var(--cemento);opacity:.8}
.fgroup:focus-within{background:rgba(240,120,0,.05)}
.fgroup::after{content:'';position:absolute;left:0;bottom:-1px;height:1px;width:0;background:var(--cantiere);transition:width .5s var(--ease)}
.fgroup:focus-within::after{width:100%}
.cont-form button{
  font-family:var(--f-mono);font-size:13px;letter-spacing:.14em;text-transform:uppercase;
  background:var(--cantiere);color:var(--ink);padding:22px;font-weight:500;
  transition:background .3s,letter-spacing .3s;
}
.cont-form button:hover{background:var(--bianco);letter-spacing:.22em}
@media(max-width:980px){.cont-grid{grid-template-columns:1fr;gap:60px}}

.footer-mega{
  margin-top:110px;border-top:1px solid var(--linea-dark);padding:50px 0 0;overflow:hidden;
}
.footer-word{
  font-family:var(--f-display);font-variation-settings:'wdth' 122;font-weight:900;text-transform:uppercase;
  font-size:clamp(48px,11vw,185px);line-height:.84;text-align:center;letter-spacing:.01em;
  color:transparent;-webkit-text-stroke:1.5px var(--graphite);
  transition:color 1.2s var(--ease);user-select:none;white-space:nowrap;
}
.footer-word:hover{color:var(--cantiere);-webkit-text-stroke:1.5px var(--cantiere)}
.footer-bottom{
  display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;
  padding:36px var(--mx) 30px;border-top:1px solid var(--linea-dark);margin-top:46px;
  font-family:var(--f-mono);font-size:11px;letter-spacing:.1em;color:var(--cemento);text-transform:uppercase;
}
.footer-bottom a:hover{color:var(--cantiere)}

/* ============ CURSORE CUSTOM (solo desktop) ============ */
html.has-cursor,html.has-cursor a,html.has-cursor button,html.has-cursor input,html.has-cursor textarea{cursor:none}
.cur-dot,.cur-ring{position:fixed;top:0;left:0;pointer-events:none;z-index:2002;border-radius:50%}
.cur-dot{width:8px;height:8px;background:var(--cantiere)}
.cur-ring{
  width:36px;height:36px;border:1.5px solid rgba(240,120,0,.75);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--f-mono);font-size:12px;letter-spacing:.05em;color:var(--ink);
  transition:width .35s var(--ease),height .35s var(--ease),background .35s,border-color .35s;
}
.cur-ring span{opacity:0;transition:opacity .25s}
body.cur-link .cur-ring{width:56px;height:56px;background:rgba(240,120,0,.14)}
body.cur-view .cur-ring{width:86px;height:86px;background:var(--cantiere);border-color:var(--cantiere)}
body.cur-view .cur-ring span{opacity:1}

/* ============ ANTEPRIMA FLOTTANTE SERVIZI ============ */
.serv-float{
  position:fixed;top:0;left:0;width:330px;height:225px;
  pointer-events:none;z-index:60;opacity:0;overflow:hidden;
  border:1px solid var(--ink);box-shadow:0 24px 60px rgba(28,28,27,.28);
}
.serv-float .sf-chip{
  position:absolute;inset:0;display:flex;flex-direction:column;gap:10px;align-items:center;justify-content:center;
  background:
    repeating-linear-gradient(0deg,transparent,transparent 39px,rgba(240,120,0,.16) 39px,rgba(240,120,0,.16) 40px),
    repeating-linear-gradient(90deg,transparent,transparent 39px,rgba(240,120,0,.16) 39px,rgba(240,120,0,.16) 40px),
    var(--graphite);
  color:var(--cantiere);font-family:var(--f-mono);font-size:13px;letter-spacing:.18em;text-transform:uppercase;
}
.serv-float .sf-chip small{font-size:10px;color:var(--cemento);letter-spacing:.14em}
.serv-float img{position:relative;width:100%;height:100%;object-fit:cover;z-index:2}
@media(max-width:1023px){.serv-float{display:none}}

/* ============ WATERMARK DI SEZIONE ============ */
#manifesto,#committenza{position:relative;overflow:hidden}
#manifesto .container,#committenza .container{position:relative;z-index:1}
.wm{
  position:absolute;top:50%;left:-2vw;transform:translateY(-50%);
  font-family:var(--f-display);font-variation-settings:'wdth' 120;font-weight:900;text-transform:uppercase;
  font-size:clamp(140px,26vw,380px);line-height:.8;white-space:nowrap;
  color:transparent;-webkit-text-stroke:1px rgba(28,28,27,.09);
  pointer-events:none;user-select:none;z-index:0;
}

/* ============ HERO: TITOLI A RIGHE MASCHERATE ============ */
.slide-title .lr{display:block;overflow:hidden}
.slide-title .lri{display:inline-block;transform:translateY(114%);transition:transform 1s var(--ease)}
.slide.active .lri{transform:translateY(0)}
.slide.active .lr:nth-child(1) .lri{transition-delay:.3s}
.slide.active .lr:nth-child(2) .lri{transition-delay:.44s}

/* ============ QUOTE CHE SI DISEGNANO ============ */
.stat .quota::after{transform:scaleX(0);transform-origin:left;transition:transform 1.1s var(--ease) .25s}
.stat .quota.draw::after{transform:scaleX(1)}
.no-anim .stat .quota::after{transform:scaleX(1)}

/* ============ FOOTER: LETTERE ============ */
.footer-word{overflow:hidden}
.footer-word .fl{display:inline-block;will-change:transform}

/* ============ REVEAL GENERICI ============ */
.fade-up{opacity:0;transform:translateY(46px)}
.no-js .fade-up,.no-anim .fade-up{opacity:1;transform:none}

/* ============ REDUCED MOTION ============ */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  .fade-up{opacity:1;transform:none}
  .line-rv>span{transform:none}
  .slide-title .lri{transform:none}
  .stat .quota::after{transform:scaleX(1)}
}

@media(max-width:860px){
  :root{--mx:5.5vw}
  .sec{padding:90px 0}
  body{font-size:16px}
}

/* ============ PAGINE INTERNE ============ */
.page-hero{
  background:var(--ink);color:var(--carta);
  padding:200px 0 100px;position:relative;overflow:hidden;
}
.page-hero::before{
  content:'';position:absolute;inset:0;opacity:.55;pointer-events:none;
  background:
    repeating-linear-gradient(0deg,transparent,transparent 89px,rgba(240,120,0,.08) 89px,rgba(240,120,0,.08) 90px),
    repeating-linear-gradient(90deg,transparent,transparent 89px,rgba(240,120,0,.08) 89px,rgba(240,120,0,.08) 90px);
}
.page-hero .container{position:relative;z-index:1}
.ph-crumb{font-family:var(--f-mono);font-size:11.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--cemento);display:block;margin-bottom:26px}
.ph-crumb b{color:var(--cantiere);font-weight:500}
.ph-title{font-size:clamp(46px,8.5vw,120px)}
.ph-title .outline{color:transparent;-webkit-text-stroke:1.5px var(--carta)}
.ph-sub{margin-top:28px;max-width:580px;color:rgba(239,237,232,.75);font-size:17px;line-height:1.75}

/* blocchi servizio dettaglio */
.sv-block{
  display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:clamp(40px,6vw,90px);
  padding:96px 0;border-bottom:1px solid var(--linea);align-items:center;
}
.sv-block:last-of-type{border-bottom:none}
.sv-block:nth-of-type(even) .sv-media{order:2}
.sv-media{
  position:relative;aspect-ratio:4/3;overflow:hidden;border:1px solid var(--linea);
  background:
    linear-gradient(rgba(28,28,27,.5),rgba(28,28,27,.78)),
    repeating-linear-gradient(0deg,transparent,transparent 59px,rgba(240,120,0,.14) 59px,rgba(240,120,0,.14) 60px),
    repeating-linear-gradient(90deg,transparent,transparent 59px,rgba(240,120,0,.14) 59px,rgba(240,120,0,.14) 60px),
    var(--graphite);
  display:flex;align-items:center;justify-content:center;
}
.sv-media .tag{font-family:var(--f-mono);font-size:11.5px;letter-spacing:.16em;color:var(--cemento);text-transform:uppercase;border:1px dashed var(--linea-dark);padding:12px 18px}
.sv-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.sv-block:hover .sv-media img{transform:scale(1.05)}
.sv-copy .serv-code{margin-bottom:18px;display:block}
.sv-copy h2{
  font-family:var(--f-display);font-variation-settings:'wdth' 108;font-weight:830;text-transform:uppercase;
  font-size:clamp(30px,3.6vw,52px);line-height:.98;letter-spacing:-.01em;margin-bottom:22px;
}
.sv-copy p{color:var(--cemento-scuro);margin-bottom:18px}
.check-list{list-style:none;display:flex;flex-direction:column;gap:12px;margin-top:24px}
.check-list li{display:flex;gap:14px;align-items:baseline;font-size:15.5px;font-weight:500}
.check-list li::before{content:'—';color:var(--cantiere);font-family:var(--f-mono);flex:0 0 auto}
@media(max-width:980px){
  .sv-block{grid-template-columns:1fr;gap:30px}
  .sv-block:nth-of-type(even) .sv-media{order:0}
}

/* portfolio lavori */
.lav-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.lav-card{
  border:1px solid var(--linea);background:var(--bianco);overflow:hidden;
  transition:transform .45s var(--ease),box-shadow .45s var(--ease);
}
.lav-card:hover{transform:translateY(-7px);box-shadow:0 26px 54px rgba(28,28,27,.16)}
.lav-media{
  position:relative;aspect-ratio:4/3;overflow:hidden;
  background:
    linear-gradient(rgba(28,28,27,.5),rgba(28,28,27,.78)),
    repeating-linear-gradient(0deg,transparent,transparent 49px,rgba(240,120,0,.14) 49px,rgba(240,120,0,.14) 50px),
    repeating-linear-gradient(90deg,transparent,transparent 49px,rgba(240,120,0,.14) 49px,rgba(240,120,0,.14) 50px),
    var(--graphite);
  display:flex;align-items:center;justify-content:center;
}
.lav-media .tag{font-family:var(--f-mono);font-size:10.5px;letter-spacing:.16em;color:var(--cemento);text-transform:uppercase;border:1px dashed var(--linea-dark);padding:10px 14px;text-align:center;line-height:1.9}
.lav-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.lav-card:hover .lav-media img{transform:scale(1.06)}
.lav-body{padding:24px 24px 28px}
.lav-body h3{
  font-family:var(--f-display);font-variation-settings:'wdth' 106;font-weight:800;text-transform:uppercase;
  font-size:19px;line-height:1.12;margin-bottom:10px;
}
.lav-meta{font-family:var(--f-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--cemento)}
@media(max-width:980px){.lav-grid{grid-template-columns:1fr 1fr}}
@media(max-width:620px){.lav-grid{grid-template-columns:1fr}}

/* griglia due colonne generica per pagine */
.duo{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr);gap:clamp(40px,6vw,90px);align-items:center}
@media(max-width:980px){.duo{grid-template-columns:1fr}}
.duo .txt p{color:var(--cemento-scuro);margin-bottom:18px}
.sec--dark .duo .txt p{color:rgba(239,237,232,.78)}
.big-claim{
  font-family:var(--f-serif);font-style:italic;font-size:clamp(22px,2.4vw,32px);line-height:1.5;
  border-left:2px solid var(--cantiere);padding-left:28px;margin:30px 0;
}

.serv-float .sf-chip{display:none}

.sv-block{scroll-margin-top:110px}

/* ============ PAGINA LEGALE ============ */
.legal{max-width:840px}
.legal h2{font-family:var(--f-display);font-variation-settings:'wdth' 106;font-weight:800;text-transform:uppercase;font-size:22px;margin:44px 0 14px;letter-spacing:.005em}
.legal h2:first-child{margin-top:0}
.legal p{color:var(--cemento-scuro);font-size:15.5px;line-height:1.8;margin-bottom:14px}
.legal p b{color:var(--ink)}
.legal a{color:var(--cantiere);text-decoration:underline}
.ph-data{background:var(--bianco);border:1px dashed var(--cantiere);padding:2px 10px;font-family:var(--f-mono);font-size:13px;white-space:nowrap}

/* preloader su schermi stretti: la foto di gruppo si vede per intero */
@media(max-width:760px){
  .pl-photo img{object-fit:contain;filter:grayscale(1) contrast(1.08) brightness(.62)}
}

/* ============ RIFINITURA SMARTPHONE ============ */
@media(max-width:860px){
  #nav{grid-template-columns:minmax(0,1fr) auto;gap:14px}
  .nav-logo{justify-self:start;text-align:left}
  .nav-logo .logo-img{margin:0;max-height:36px;max-width:58vw}
  #nav.scrolled .logo-img{max-height:28px}
  .nav-logo a{font-size:24px}
  #nav.scrolled .nav-logo a{font-size:19px}
}
@media(max-width:640px){
  .cont-row{grid-template-columns:1fr;gap:6px;padding:16px 0}
  .cont-row .v{overflow-wrap:anywhere}
}
