@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Syne:wght@400;500;600;700;800&display=swap');
:root{--bg:#f6f2ea;--fg:#141414;--card:#fff;--muted:#555;--muted2:#e8e0d3;--border:rgba(0,0,0,.12);--primary:#eb6100;--accent:#c9184a;--grid:rgba(0,0,0,.035);--font-display:'Syne',sans-serif;--font-body:'Space Grotesk',sans-serif;--ease:cubic-bezier(.16,1,.3,1)}
.dark{--bg:#0a0a0a;--fg:#f4f4f4;--card:#111;--muted:#a6a6a6;--muted2:#1c1c1c;--border:rgba(255,255,255,.1);--primary:#ffc31a;--accent:#ff3e7c;--grid:rgba(255,255,255,.035)}
*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:auto}body{background:var(--bg);color:var(--fg);font-family:var(--font-body);overflow-x:hidden}a{color:inherit;text-decoration:none}.graphic-grid{min-height:100vh;background-image:linear-gradient(var(--grid) 1px,transparent 1px),linear-gradient(90deg,var(--grid) 1px,transparent 1px);background-size:60px 60px}.container{width:min(1280px,100%);margin:0 auto;padding-inline:22px}.section{padding-block:92px}.logo{position:fixed;top:24px;left:28px;z-index:60;font:800 19px var(--font-display)}.logo span{background:linear-gradient(135deg,var(--primary),var(--accent));-webkit-background-clip:text;background-clip:text;color:transparent}.menu-btn{position:fixed;right:28px;top:26px;z-index:60;width:36px;background:none;border:0;display:grid;gap:7px;cursor:pointer}.menu-btn i{display:block;height:2px;background:var(--fg)}.menu-btn i:nth-child(2){width:22px;margin-left:auto;background:var(--primary)}.theme-toggle{position:fixed;right:82px;top:18px;z-index:60;width:44px;height:44px;border:1px solid var(--border);background:var(--card);color:var(--fg);cursor:pointer}.menu-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);backdrop-filter:blur(10px);opacity:0;pointer-events:none;z-index:70;transition:.3s}.menu-overlay.open{opacity:1;pointer-events:auto}.fullscreen-menu{position:fixed;inset:0;background:var(--bg);z-index:80;display:flex;flex-direction:column;justify-content:center;align-items:center;clip-path:circle(0 at calc(100% - 45px) 35px);transition:clip-path .75s var(--ease)}.fullscreen-menu.open{clip-path:circle(150% at calc(100% - 45px) 35px)}.close-menu{position:absolute;right:28px;top:27px;border:0;background:none;color:var(--muted);text-transform:uppercase;letter-spacing:.18em;cursor:pointer}.fullscreen-menu ul{list-style:none;text-align:center}.fullscreen-menu li{margin:18px 0}.fullscreen-menu a{display:inline-flex;align-items:baseline;gap:18px}.fullscreen-menu small{color:var(--primary);letter-spacing:.3em}.fullscreen-menu span{font:800 clamp(2.4rem,12vw,5rem)/.9 var(--font-display);text-transform:uppercase}.fullscreen-menu a:hover span{color:var(--primary)}.fullscreen-menu p{position:absolute;bottom:46px;color:var(--muted);text-transform:uppercase;letter-spacing:.3em;font-size:12px}.hero{min-height:90svh;display:flex;flex-direction:column;justify-content:center;position:relative;padding-top:90px;padding-bottom:70px;overflow:hidden}.shape-square{position:absolute;right:8%;top:18%;width:260px;height:260px;border:2px solid color-mix(in srgb,var(--primary),transparent 75%);rotate:12deg}.shape-glow{position:absolute;left:7%;bottom:20%;width:190px;height:190px;border-radius:50%;background:color-mix(in srgb,var(--accent),transparent 90%);filter:blur(45px)}.shape-dot{position:absolute;right:25%;top:38%;width:11px;height:11px;background:var(--primary);border-radius:50%}.meta{text-transform:uppercase;letter-spacing:.3em;font-size:12px;font-weight:600;color:var(--muted)}.accent{color:var(--primary)}.display{font-family:var(--font-display);font-weight:800;text-transform:uppercase;letter-spacing:-.04em}.hero-title{font-size:clamp(4.2rem,16vw,10rem);line-height:.84;margin-top:24px}.hero-title b,.section-title b{color:var(--primary);font-style:normal}.gradient{background:linear-gradient(135deg,var(--primary),var(--accent));-webkit-background-clip:text;background-clip:text;color:transparent}.hero-desc{display:flex;gap:28px;margin-top:42px;align-items:flex-start}.line{width:64px;height:2px;background:var(--primary);margin-top:14px;flex:0 0 auto}.hero-desc p{max-width:650px;color:var(--muted);font-size:18px;line-height:1.7}.hero-actions{display:flex;gap:28px;align-items:center;margin-top:45px;flex-wrap:wrap}.btn{position:relative;display:inline-block;padding:15px 28px;border:2px solid var(--primary);color:var(--primary);text-transform:uppercase;letter-spacing:.18em;font-weight:800;font-size:13px;overflow:hidden;background:transparent;cursor:pointer}.btn:before{content:'';position:absolute;inset:0;background:var(--primary);transform:scaleX(0);transform-origin:left;transition:.5s var(--ease)}.btn:hover:before{transform:scaleX(1)}.btn span{position:relative;z-index:1}.btn:hover{color:var(--bg)}.link{color:var(--muted);text-transform:uppercase;letter-spacing:.25em;font-size:12px}.link:hover{color:var(--primary)}.marquee{
  border-block:1px solid var(--border);
  overflow:hidden;
  rotate:-1deg;
  padding:30px 0;
  background:transparent;
}
.track{
  display:flex;
  align-items:center;
  width:max-content;
  animation:marquee 30s linear infinite;
}
.track span{
  font:900 clamp(2.4rem,7vw,5.4rem)/1 var(--font-display);
  text-transform:uppercase;
  color:rgba(255,255,255,.045);
  -webkit-text-fill-color:rgba(255,255,255,.045);
  -webkit-text-stroke:0!important;
  text-stroke:0!important;
  opacity:1;
  white-space:nowrap;
}
.track span:nth-child(even){
  color:rgba(255,255,255,.04);
  -webkit-text-fill-color:rgba(255,255,255,.04);
  -webkit-text-stroke:0!important;
  text-stroke:0!important;
  opacity:1;
}
.marquee-dot{
  display:inline-block;
  width:11px;
  height:11px;
  min-width:11px;
  border-radius:50%;
  margin:0 58px;
  background:radial-gradient(circle at 35% 35%,#ffe28a 0%,#ffb300 38%,#ff7a00 72%,rgba(255,122,0,.25) 100%);
  box-shadow:
    0 0 12px rgba(255,179,0,.95),
    0 0 26px rgba(255,122,0,.55),
    0 0 52px rgba(255,122,0,.28);
  opacity:.95;
}
@keyframes marquee{to{transform:translateX(-50%)}}.about{display:grid;grid-template-columns:1fr 2fr;gap:80px}.section-title{font-size:clamp(2.7rem,8vw,5rem);line-height:.88}.body{margin-top:28px;font-size:16px;line-height:1.8;max-width:520px}.muted{color:var(--muted)}.timeline{position:relative;padding-left:58px}.timeline:before{content:'';position:absolute;left:16px;top:0;bottom:0;width:2px;background:var(--border)}.timeline article{position:relative;margin-bottom:44px}.timeline article:before{content:'';position:absolute;left:-48px;top:6px;width:12px;height:12px;border-radius:50%;background:var(--primary)}.timeline span,.project em{font-style:normal;color:var(--primary);font-size:12px;letter-spacing:.3em;text-transform:uppercase;font-weight:800}.timeline h3,.project h3{font-family:var(--font-display);text-transform:uppercase;font-size:25px;margin-top:6px}.timeline p,.project p{color:var(--muted);line-height:1.65;max-width:520px;margin-top:7px}.section-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:62px}.stroke{font:800 clamp(4rem,12vw,8rem)/1 var(--font-display);color:transparent;-webkit-text-fill-color:transparent;-webkit-text-stroke:1.5px rgba(255,255,255,.10);opacity:1}.projects{display:grid;grid-template-columns:repeat(2,1fr);gap:42px}.project.large{grid-column:1/-1}.img-wrap{position:relative;overflow:hidden;background:var(--muted2);aspect-ratio:4/5}.project.large .img-wrap{aspect-ratio:16/9}.img-wrap img{width:100%;height:100%;object-fit:cover;filter:grayscale(40%) contrast(1.08);opacity:.92;transition:.55s var(--ease)}.project:hover img{transform:scale(1.05);filter:grayscale(0) contrast(1.03);opacity:1}.img-wrap span{position:absolute;top:16px;left:16px;background:var(--primary);color:var(--bg);padding:7px 11px;text-transform:uppercase;letter-spacing:.16em;font-size:11px;font-weight:800}.project>div:nth-child(2){display:flex;justify-content:space-between;gap:16px;align-items:baseline;margin-top:18px}.studio-box{border:1px solid var(--border);background:var(--card);margin-top:46px}.studio-top{display:flex;align-items:center;gap:12px;padding:11px 14px;border-bottom:1px solid var(--border);background:var(--muted2)}.studio-top div{display:flex;gap:6px}.studio-top i{width:12px;height:12px;border-radius:50%;background:var(--accent)}.studio-top i:nth-child(2){background:var(--primary)}.studio-top i:nth-child(3){background:#55d383}.studio-top span{flex:1;color:var(--muted);text-transform:uppercase;letter-spacing:.14em;font-size:12px}.studio-top button{border:0;background:none;color:var(--muted);cursor:pointer;text-transform:uppercase;letter-spacing:.14em}.studio-body{display:flex}.tools{display:flex;flex-direction:column;gap:7px;padding:10px;border-right:1px solid var(--border);background:color-mix(in srgb,var(--muted2),transparent 30%)}.tools button{width:40px;height:40px;border:0;background:transparent;color:var(--muted);cursor:pointer}.tools button.active,.tools button:hover{background:var(--primary);color:var(--bg)}.tools input{width:40px}canvas{width:100%;height:auto;display:block;background:#151515;touch-action:none}.contact{display:grid;grid-template-columns:1fr 1fr;gap:80px;position:relative}.contact-links{margin-top:40px;display:grid;gap:22px}.contact-links a{color:var(--muted);font-size:18px}.contact-links a:hover{color:var(--primary)}
.contact-copy{width:100%;text-align:left;background:transparent;border:1px solid var(--border);color:var(--fg);padding:18px 20px;cursor:pointer;font-family:var(--font-body);display:grid;gap:6px;transition:.35s var(--ease)}
.contact-copy span{color:var(--primary);font-size:12px;text-transform:uppercase;letter-spacing:.22em;font-weight:800}
.contact-copy strong{font-size:18px;font-weight:600;word-break:break-word}
.contact-copy small{color:var(--muted);text-transform:uppercase;letter-spacing:.16em;font-size:11px}
.contact-copy:hover{border-color:var(--primary);transform:translateY(-3px);box-shadow:0 18px 40px color-mix(in srgb,var(--primary),transparent 88%)}
form{display:grid;gap:28px;align-content:center}input,textarea{width:100%;background:transparent;border:0;border-bottom:2px solid color-mix(in srgb,var(--muted),transparent 65%);outline:0;color:var(--fg);padding:14px 0;text-transform:uppercase;letter-spacing:.12em;font-family:var(--font-body)}input:focus,textarea:focus{border-color:var(--primary)}

/* Validazione form custom in stile portfolio */
.form-field{display:grid;gap:8px}
.form-error{min-height:18px;color:var(--primary);font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;opacity:0;transform:translateY(-6px);transition:.3s var(--ease)}
.form-error.show{opacity:1;transform:translateY(0)}
.input-error{border-color:var(--primary)!important;box-shadow:0 8px 24px color-mix(in srgb,var(--primary),transparent 88%)}
.input-success{border-color:color-mix(in srgb,var(--primary),transparent 35%)}

.footer{display:flex;justify-content:space-between;border-top:1px solid var(--border);padding-block:52px;color:var(--muted);text-transform:uppercase;letter-spacing:.25em;font-size:12px}.section-reveal{opacity:0;transform:translateY(35px);transition:1s var(--ease)}.section-reveal.visible{opacity:1;transform:none}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%,30px);background:var(--fg);color:var(--bg);padding:13px 18px;z-index:100;border-radius:0;opacity:0;transition:.35s}.toast.show{opacity:1;transform:translate(-50%,0)}@media(max-width:820px){.container{padding-inline:18px}.section{padding-block:70px}.about,.contact{grid-template-columns:1fr;gap:52px}.projects{grid-template-columns:1fr}.hero-title{font-size:clamp(3.5rem,23vw,6rem)}.mobile-break{display:block}.hero-desc{flex-direction:column;gap:18px}.shape-square{width:150px;height:150px;right:-30px}.fullscreen-menu span{font-size:clamp(2.2rem,15vw,4rem)}.section-head{display:block}.stroke{display:none}.studio-body{flex-direction:column}.tools{flex-direction:row;border-right:0;border-bottom:1px solid var(--border);overflow:auto}

/* Validazione form custom in stile portfolio */
.form-field{display:grid;gap:8px}
.form-error{min-height:18px;color:var(--primary);font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;opacity:0;transform:translateY(-6px);transition:.3s var(--ease)}
.form-error.show{opacity:1;transform:translateY(0)}
.input-error{border-color:var(--primary)!important;box-shadow:0 8px 24px color-mix(in srgb,var(--primary),transparent 88%)}
.input-success{border-color:color-mix(in srgb,var(--primary),transparent 35%)}

.footer{display:grid;gap:16px}.project>div:nth-child(2){display:block}.timeline{padding-left:48px}}

/* Form contatti <span class="wm-dot">●</span> errore più morbido e premium */
#contactForm{
  gap:24px;
  align-content:center;
}
#contactForm .form-field{
  display:grid;
  gap:10px;
}
#contactForm input,
#contactForm textarea{
  background:color-mix(in srgb,var(--card),transparent 72%);
  border:1px solid color-mix(in srgb,var(--border),transparent 10%);
  border-bottom:2px solid color-mix(in srgb,var(--muted),transparent 65%);
  padding:18px 20px;
  min-height:58px;
  transition:border-color .3s var(--ease), box-shadow .3s var(--ease), background .3s var(--ease), transform .3s var(--ease);
}
#contactForm textarea{
  min-height:132px;
  resize:vertical;
}
#contactForm input:focus,
#contactForm textarea:focus{
  background:color-mix(in srgb,var(--card),transparent 58%);
  border-color:color-mix(in srgb,var(--primary),transparent 35%);
  border-bottom-color:var(--primary);
  box-shadow:0 16px 45px color-mix(in srgb,var(--primary),transparent 92%);
}
#contactForm .form-error{
  width:max-content;
  max-width:100%;
  min-height:auto;
  padding:7px 11px;
  border:1px solid color-mix(in srgb,var(--primary),transparent 65%);
  background:color-mix(in srgb,var(--primary),transparent 91%);
  color:var(--primary);
  font-size:11px;
  font-weight:800;
  line-height:1;
  letter-spacing:.13em;
  text-transform:uppercase;
  opacity:0;
  transform:translateY(-4px);
  pointer-events:none;
  border-radius:999px;
}
#contactForm .form-error.show{
  opacity:1;
  transform:translateY(0);
}
#contactForm .input-error{
  border-color:color-mix(in srgb,var(--primary),transparent 25%)!important;
  border-bottom-color:var(--primary)!important;
  box-shadow:0 18px 48px color-mix(in srgb,var(--primary),transparent 88%)!important;
}
#contactForm .btn{
  margin-top:8px;
  width:100%;
  padding-block:18px;
}


.logo{display:flex;flex-direction:column;align-items:flex-start;text-decoration:none}
.logo span{font-weight:800;letter-spacing:-.05em}
.logo small{font-size:.55rem;letter-spacing:.18em;text-transform:uppercase;opacity:.7;margin-top:2px}


/* Navigazione verticale premium al centro lato destro */
html{
  scrollbar-width:none;
}
html::-webkit-scrollbar,
body::-webkit-scrollbar{
  width:0;
  height:0;
}
.section-scroll-nav{
  position:fixed;
  right:34px;
  top:50%;
  transform:translateY(-50%);
  z-index:90;
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:9px;
  padding:14px 0;
  pointer-events:auto;
}
.section-scroll-nav::before{
  content:"";
  position:absolute;
  right:-15px;
  top:0;
  bottom:0;
  width:1px;
  background:linear-gradient(180deg,transparent,rgba(255,255,255,.16),transparent);
}
.section-scroll-nav a{
  display:block;
  width:20px;
  height:2px;
  border-radius:999px;
  background:rgba(255,255,255,.42);
  opacity:.75;
  transition:width .35s var(--ease), background .35s var(--ease), opacity .35s var(--ease), transform .35s var(--ease), box-shadow .35s var(--ease);
}
.section-scroll-nav a:hover{
  width:30px;
  opacity:1;
  background:rgba(255,255,255,.9);
}
.section-scroll-nav a.active{
  width:34px;
  opacity:1;
  background:var(--primary);
  box-shadow:0 0 18px color-mix(in srgb,var(--primary),transparent 45%);
}
@media (max-width:780px){
  .section-scroll-nav{
    right:18px;
    gap:8px;
  }
  .section-scroll-nav a{
    width:16px;
  }
  .section-scroll-nav a.active{
    width:26px;
  }
}

/* Rimuove il cursore lampeggiante/testo da tutto il sito */
*{
  caret-color: rgba(255,255,255,.03) !important;
}
body,
a,
button,
.section-scroll-nav,
.section-scroll-nav a{
  user-select: none;
  -webkit-user-select: none;
  outline: none !important;
}
a:focus,
a:focus-visible,
button:focus,
button:focus-visible,
.section-scroll-nav a:focus,
.section-scroll-nav a:focus-visible{
  outline: none !important;
  box-shadow: none !important;
}


/* Caret corretto: visibile solo nei campi del form */
body,
a,
button,
section,
div,
span,
p,
h1,h2,h3,h4,h5,h6{
  caret-color: transparent;
}

#contactForm input,
#contactForm textarea{
  caret-color: var(--primary) !important;
  user-select: text;
  -webkit-user-select: text;
}

/* Campi form più centrati e premium */
#contactForm{
  gap: 26px;
}

#contactForm .form-field{
  gap: 12px;
}

#contactForm input{
  height: 58px;
  padding: 0 20px;
  line-height: 58px;
}

#contactForm textarea{
  min-height: 132px;
  padding: 22px 20px;
  line-height: 1.55;
  resize: vertical;
}

#contactForm input,
#contactForm textarea{
  border: 1px solid var(--primary);
  background: rgba(0,0,0,.14);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.015);
}

#contactForm input::placeholder,
#contactForm textarea::placeholder{
  color: var(--muted);
  opacity: .9;
}

#contactForm input:focus,
#contactForm textarea:focus{
  border-color: var(--primary) !important;
  box-shadow:
    0 0 15px color-mix(in srgb,var(--primary),transparent 72%),
    0 0 35px color-mix(in srgb,var(--primary),transparent 88%),
    inset 0 0 0 1px color-mix(in srgb,var(--primary),transparent 55%) !important;
}

.custom-caret,
.custom-form-caret{
  display: none !important;
}



/* Portfolio progetti reali */
.portfolio-intro{
  max-width:760px;
  color:var(--muted);
  line-height:1.75;
  margin:-36px 0 56px;
}
.project-category-title{
  display:flex;
  align-items:center;
  gap:14px;
  margin:56px 0 22px;
}
.project-category-title span{
  width:9px;
  height:9px;
  border-radius:50%;
  background:var(--primary);
  box-shadow:0 0 18px color-mix(in srgb,var(--primary),transparent 45%);
}
.project-category-title h3{
  font-family:var(--font-body);
  color:var(--muted);
  font-size:12px;
  letter-spacing:.28em;
  text-transform:uppercase;
}
.project-grid-custom{
  margin-bottom:26px;
}
.project-card{
  cursor:pointer;
}
.project-open{
  width:100%;
  display:block;
  background:transparent;
  border:0;
  color:inherit;
  cursor:pointer;
  text-align:left;
}
.project-open:focus-visible .img-wrap{
  outline:2px solid var(--primary);
  outline-offset:4px;
}
.project-card .img-wrap::after{
  content:"Apri progetto";
  position:absolute;
  right:16px;
  bottom:16px;
  padding:9px 12px;
  background:rgba(0,0,0,.68);
  border:1px solid rgba(255,255,255,.14);
  color:#fff;
  font-size:11px;
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
  transform:translateY(12px);
  opacity:0;
  transition:.35s var(--ease);
  backdrop-filter:blur(10px);
}
.project-card:hover .img-wrap::after{
  opacity:1;
  transform:translateY(0);
}
.project-card .img-wrap img{
  object-fit:cover;
}
.project-card:not(.large) .img-wrap{
  aspect-ratio:1/1;
}
.project-card.large .img-wrap{
  aspect-ratio:16/7;
}

/* Popup portfolio */
.project-modal{
  position:fixed;
  inset:0;
  z-index:200;
  display:grid;
  place-items:center;
  padding:24px;
  opacity:0;
  pointer-events:none;
  transition:.35s var(--ease);
}
.project-modal.open{
  opacity:1;
  pointer-events:auto;
}
.project-modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.72);
  backdrop-filter:blur(18px);
}
.project-modal-card{
  position:relative;
  width:min(1180px,100%);
  max-height:90vh;
  overflow:auto;
  display:grid;
  grid-template-columns:1.15fr .85fr;
  background:color-mix(in srgb,var(--bg),#000 12%);
  border:1px solid var(--border);
  box-shadow:0 35px 120px rgba(0,0,0,.58);
  transform:translateY(20px) scale(.98);
  transition:.35s var(--ease);
}
.project-modal.open .project-modal-card{
  transform:none;
}
.project-modal-image-wrap{
  min-height:460px;
  background:#070707;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:18px;
  overflow:hidden;
}
.project-modal-image-wrap img{
  width:100%;
  height:100%;
  max-height:78vh;
  display:block;
  object-fit:contain;
  object-position:center;
}
.project-modal-content{
  padding:46px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.project-modal-content h2{
  font-size:clamp(2.2rem,5vw,4.2rem);
  line-height:.9;
  margin:16px 0 24px;
}
.project-modal-info{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  margin-bottom:28px;
}
.project-modal-info span{
  border:1px solid var(--border);
  padding:14px;
  background:rgba(255,255,255,.025);
}
.project-modal-info b,
.project-modal-info em{
  display:block;
  font-style:normal;
}
.project-modal-info b{
  color:var(--muted);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.18em;
  margin-bottom:7px;
}
.project-modal-info em{
  color:var(--primary);
  font-weight:800;
}
.project-modal-content p:not(.meta){
  color:var(--muted);
  line-height:1.75;
}
.project-modal-close{
  position:absolute;
  top:18px;
  right:18px;
  z-index:3;
  border:1px solid var(--border);
  background:rgba(0,0,0,.46);
  color:#fff;
  padding:10px 13px;
  cursor:pointer;
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:11px;
  font-weight:800;
  backdrop-filter:blur(10px);
}
.project-modal-close:hover{
  border-color:var(--primary);
  color:var(--primary);
}
body.modal-open{
  overflow:hidden;
}
@media(max-width:860px){
  .project-modal-card{
    grid-template-columns:1fr;
  }
  .project-modal-image-wrap{
    min-height:260px;
    padding:12px;
  }
  .project-modal-content{
    padding:28px;
  }
  .project-modal-info{
    grid-template-columns:1fr;
  }
  .project-card.large .img-wrap{
    aspect-ratio:16/10;
  }
}

/* === FIX: immagini portfolio sempre intere nelle card === */
.project-card .img-wrap,
.project.large .img-wrap,
.project-card:not(.large) .img-wrap{
  background:#050505;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}

.project-card .img-wrap img,
.project-card.large .img-wrap img,
.project-card:not(.large) .img-wrap img,
.img-wrap img{
  width:100%;
  height:100%;
  object-fit:contain !important;
  object-position:center center !important;
  transform:none !important;
}

.project-card:hover .img-wrap img,
.project:hover img{
  transform:none !important;
  object-fit:contain !important;
}

.project-card.large .img-wrap{
  aspect-ratio:16/7;
}

.project-card:not(.large) .img-wrap{
  aspect-ratio:1/1;
}

@media(max-width:760px){
  .project-card.large .img-wrap{
    aspect-ratio:16/9;
  }
}

/* === PSD DESIGN PLAYGROUND PREMIUM === */
.playground .section-title{margin-bottom:34px}.psd-editor{margin-top:44px;border:1px solid #1f1f1f;background:#262626;color:#d7d7d7;box-shadow:0 35px 90px rgba(0,0,0,.45);font-family:Arial,Helvetica,sans-serif;overflow:hidden}.psd-menu-bar{height:30px;background:#535353;display:flex;align-items:center;gap:17px;padding:0 12px;font-size:12px;color:#f0f0f0;border-bottom:1px solid #303030}.psd-menu-bar strong{background:#001e36;color:#31a8ff;border-radius:2px;padding:3px 5px;font-size:11px;margin-right:2px}.psd-options-bar{min-height:38px;background:#3a3a3a;border-bottom:1px solid #202020;display:flex;align-items:center;gap:12px;padding:6px 10px;flex-wrap:wrap}.psd-options-bar label{display:flex;align-items:center;gap:7px;color:#ddd;font-size:11px}.psd-options-bar input[type=text]{height:24px;width:150px;background:#252525;border:1px solid #555;color:#fff;padding:0 8px;outline:none;caret-color:#ffc31a}.psd-options-bar input[type=range]{width:110px}.psd-options-bar input[type=color]{width:32px;height:24px;border:1px solid #555;background:#252525;padding:0}.psd-file-name{font-size:11px;color:#f1f1f1;background:#2c2c2c;border:1px solid #555;padding:5px 10px}.psd-options-bar button{height:25px;border:1px solid #5c5c5c;background:#303030;color:#e8e8e8;text-transform:uppercase;letter-spacing:.08em;font-size:10px;font-weight:700;padding:0 10px;cursor:pointer}.psd-options-bar button:hover{background:#ffc31a;color:#111;border-color:#ffc31a}.psd-workspace{height:min(78vh,760px);min-height:560px;display:grid;grid-template-columns:48px minmax(0,1fr) 290px;background:#242424}.psd-toolbar{background:#383838;border-right:1px solid #202020;padding:8px 5px;display:flex;flex-direction:column;gap:6px}.psd-toolbar button,.psd-upload{width:36px;height:34px;border:1px solid transparent;background:transparent;color:#dcdcdc;display:grid;place-items:center;font-size:17px;cursor:pointer;border-radius:2px}.psd-toolbar button:hover,.psd-toolbar button.active,.psd-upload:hover{background:#4c4c4c;border-color:#656565;color:#fff}.psd-upload input{display:none}.psd-canvas-zone{position:relative;min-width:0;background:#252525;display:grid;grid-template-rows:30px 1fr 28px;overflow:hidden}.psd-tab{height:30px;background:#2f2f2f;border-bottom:1px solid #111;border-right:1px solid #111;color:#e7e7e7;font-size:12px;display:flex;align-items:center;padding-left:12px;width:max-content;min-width:250px}.psd-ruler{position:absolute;background:#333;z-index:2}.psd-ruler-x{left:0;right:0;top:30px;height:22px;border-bottom:1px solid #202020;background-image:repeating-linear-gradient(90deg,transparent 0 49px,#555 50px),linear-gradient(#333,#333)}.psd-ruler-y{top:30px;bottom:28px;left:0;width:22px;border-right:1px solid #202020;background-image:repeating-linear-gradient(0deg,transparent 0 49px,#555 50px),linear-gradient(#333,#333)}.psd-scroll-area{margin-top:22px;margin-left:22px;display:grid;place-items:center;overflow:auto;background:#202020;background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);background-size:40px 40px;padding:58px}.psd-artboard{position:relative;background-color:#fff;background-image:linear-gradient(45deg,#d7d7d7 25%,transparent 25%),linear-gradient(-45deg,#d7d7d7 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#d7d7d7 75%),linear-gradient(-45deg,transparent 75%,#d7d7d7 75%);background-size:20px 20px;background-position:0 0,0 10px,10px -10px,-10px 0;box-shadow:0 18px 45px rgba(0,0,0,.55);outline:1px solid rgba(255,255,255,.4);max-width:100%}#canvas{display:block;width:min(900px,65vw);height:auto;background:transparent;touch-action:none}.psd-statusbar{height:28px;background:#303030;border-top:1px solid #151515;display:flex;align-items:center;gap:18px;padding:0 12px;color:#bdbdbd;font-size:11px}.psd-side-panels{background:#3a3a3a;border-left:1px solid #191919;display:flex;flex-direction:column;overflow:auto}.psd-panel{border-bottom:1px solid #242424;background:#3d3d3d}.psd-panel-head{height:32px;background:#4a4a4a;border-bottom:1px solid #282828;display:flex;align-items:center;padding:0 12px;font-size:11px;text-transform:uppercase;font-weight:800;letter-spacing:.08em;color:#efefef}.color-panel{padding-bottom:12px}.color-panel .psd-panel-head{margin-bottom:12px}.psd-color-preview{height:170px;margin:0 12px 10px;border:1px solid #222;background:linear-gradient(135deg,#fff,#ffc31a 45%,#000)}.psd-panel small{display:block;color:#bcbcbc;font-size:11px;padding:0 12px;line-height:1.45}.psd-property{display:flex;justify-content:space-between;gap:12px;padding:12px;border-bottom:1px solid rgba(255,255,255,.06);font-size:12px}.psd-property span{color:#bdbdbd}.psd-property b{color:#ffc31a;text-align:right}.psd-layers{padding:10px}.psd-layer{height:44px;display:flex;align-items:center;gap:10px;background:#343434;border:1px solid #4d4d4d;margin-bottom:8px;padding:0 10px;color:#ddd;font-size:12px}.psd-layer.active{background:#4a4a4a;border-color:#777}.psd-layer span{font-size:13px}.psd-layer b{font-weight:600}.dark .psd-editor{border-color:#232323}@media(max-width:1050px){.psd-workspace{grid-template-columns:44px 1fr}.psd-side-panels{display:none}#canvas{width:min(820px,78vw)}.psd-scroll-area{padding:36px}}@media(max-width:720px){.psd-workspace{height:auto;min-height:0;display:block}.psd-toolbar{flex-direction:row;overflow:auto;border-right:0;border-bottom:1px solid #202020}.psd-canvas-zone{min-height:520px}.psd-scroll-area{padding:26px}#canvas{width:720px}.psd-options-bar{align-items:flex-start}.psd-file-name{width:100%}}


/* === COLOR LAB + DESIGN GENERATOR === */
.color-lab .section-title{margin-bottom:34px}
.lab-shell{display:grid;grid-template-columns:1.05fr .95fr;gap:24px;margin-top:42px}
.lab-left,.lab-right{display:grid;gap:24px}
.lab-card{position:relative;border:1px solid var(--border);background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.018));border-radius:28px;padding:22px;box-shadow:0 24px 70px rgba(0,0,0,.22);overflow:hidden}
.lab-card:before{content:"";position:absolute;inset:-1px;background:radial-gradient(circle at 18% 0%,rgba(235,97,0,.22),transparent 34%),radial-gradient(circle at 90% 10%,rgba(255,255,255,.08),transparent 28%);pointer-events:none}
.lab-card>*{position:relative;z-index:1}.lab-card-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px;text-transform:uppercase;letter-spacing:.13em;font-size:.72rem;color:var(--muted)}
.lab-card-head b{color:var(--primary)}.lab-mini-btn,.lab-btn{border:1px solid var(--border);background:var(--fg);color:var(--bg);font-family:var(--font-body);font-weight:800;text-transform:uppercase;letter-spacing:.1em;border-radius:999px;padding:10px 14px;cursor:pointer;transition:.25s var(--ease)}
.lab-mini-btn{font-size:.65rem;padding:8px 12px}.lab-btn{width:100%;margin-top:18px;padding:15px 18px}.lab-btn.secondary{background:transparent;color:var(--fg)}.lab-mini-btn:hover,.lab-btn:hover{transform:translateY(-2px);border-color:var(--primary);box-shadow:0 14px 32px rgba(235,97,0,.18)}
.palette-preview{height:280px;border-radius:22px;display:grid;grid-template-columns:repeat(5,1fr);overflow:hidden;border:1px solid var(--border);background:#111}.palette-swatch{position:relative;min-height:100%;transition:.35s var(--ease);cursor:pointer}.palette-swatch:hover{transform:scale(1.04);z-index:2}.palette-swatch span{position:absolute;left:14px;bottom:14px;font-size:.72rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:white;text-shadow:0 2px 10px rgba(0,0,0,.55)}
.palette-codes{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin-top:12px}.palette-codes button{border:1px solid var(--border);background:rgba(255,255,255,.04);color:var(--fg);border-radius:12px;padding:10px 6px;font-size:.68rem;font-weight:800;cursor:pointer}.palette-codes button:hover{border-color:var(--primary);color:var(--primary)}
.lab-range{width:100%;accent-color:var(--primary);cursor:pointer}.mood-labels{display:flex;justify-content:space-between;gap:8px;margin-top:14px;color:var(--muted);font-size:.68rem;text-transform:uppercase;letter-spacing:.08em}.concept-card{min-height:360px;display:flex;flex-direction:column}.concept-output{border:1px solid var(--border);border-radius:24px;padding:28px;background:rgba(0,0,0,.18);min-height:210px;display:flex;flex-direction:column;justify-content:center}.concept-output small{text-transform:uppercase;letter-spacing:.18em;color:var(--primary);font-weight:800}.concept-output h3{font-family:var(--font-display);font-size:clamp(2rem,4vw,4.3rem);line-height:.92;margin:18px 0 14px;letter-spacing:-.06em}.concept-output p{color:var(--muted);line-height:1.7;margin:0}.concept-tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}.concept-tags span{border:1px solid var(--border);border-radius:999px;padding:8px 12px;color:var(--muted);font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;background:rgba(255,255,255,.035)}.lab-stats{display:grid;grid-template-columns:1fr 1fr;gap:18px}.lab-stats div{border:1px solid var(--border);border-radius:24px;padding:22px;background:rgba(255,255,255,.035)}.lab-stats strong{display:block;font-family:var(--font-display);font-size:2rem;color:var(--primary);line-height:1}.lab-stats span{display:block;margin-top:8px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;font-size:.68rem}
@media(max-width:900px){.lab-shell{grid-template-columns:1fr}.palette-preview{height:230px}.palette-codes{grid-template-columns:repeat(2,1fr)}.mood-labels{font-size:.58rem}.lab-stats{grid-template-columns:1fr}}

.mood-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.mood-chip{padding:6px 10px;border:1px solid rgba(255,255,255,.15);border-radius:999px;font-size:11px}

.policy-section{padding:40px 80px;color:#8a8a8a;border-top:1px solid rgba(255,255,255,.08)}
.policy-inner{max-width:1000px;margin:0 auto;text-align:center}
.policy-inner h3{color:#cfcfcf;margin-bottom:16px;text-transform:uppercase;letter-spacing:.15em}
.policy-inner p{line-height:1.8;margin:12px 0}

.policy-accordion-section{max-width:1100px;margin:60px auto;padding:0 20px}
.policy-toggle{width:100%;background:none;border:1px solid rgba(255,255,255,.1);padding:18px;color:#fff;cursor:pointer;text-align:left;letter-spacing:.15em}
.policy-content{display:none;padding:24px;border:1px solid rgba(255,255,255,.08);border-top:none;color:#bdbdbd}
.policy-content h4{color:#fff;margin:18px 0 8px}
.policy-content ul{margin:0 0 12px 18px}
.policy-content li{margin:8px 0}
.policy-content.open{display:block}

.policy-link{color:inherit;text-decoration:none}
.policy-accordion-section{max-width:1100px;margin:40px auto 80px;padding:0 20px}


.policy-section,.policy-wrapper,.policy-container{background:transparent !important;}


/* FIX GRID CONTINUA SOTTO POLICY */
body{
  min-height:100vh;
}
.policy-accordion-section{
  position:relative;
  background:transparent !important;
  margin:40px auto 0 !important;
  padding:0 20px 120px !important;
}
.policy-content{
  background:transparent !important;
}


.btn:disabled{opacity:.65;cursor:not-allowed;filter:saturate(.7);}


/* === CLEAN WATERMARK TEXT FIX ===
   Rimuove completamente outline/stroke dai testi grandi di sfondo.
   Il testo ora è pieno, grigio scurissimo, con opacità bassa.
*/
.marquee{
    background: transparent !important;
}

.track span,
.track span:nth-child(even){
    color: rgba(255,255,255,.045) !important;
    -webkit-text-fill-color: rgba(255,255,255,.045) !important;
    -webkit-text-stroke: 0 !important;
    text-stroke: 0 !important;
    opacity: 1 !important;
    filter: none !important;
    text-shadow: none !important;
}

.track span:nth-child(even){
    color: rgba(255,255,255,.028) !important;
    -webkit-text-fill-color: rgba(255,255,255,.028) !important;
}

.wm-dot{
 color:#ffb300;
 opacity:.9;
 text-shadow:0 0 10px rgba(255,179,0,.6),0 0 20px rgba(255,179,0,.3);
}


/* =========================================================
   RESPONSIVE FIX - ErMatte Portfolio
   Ottimizzazione desktop / tablet / smartphone
   ========================================================= */

*,
*::before,
*::after {
    box-sizing: border-box;
}

html,
body {
    max-width: 100%;
    overflow-x: hidden;
}

img,
video,
canvas,
svg {
    max-width: 100%;
    height: auto;
}

section,
.container,
.wrapper,
.content,
.main,
main {
    max-width: 100%;
}

/* Layout fluidi generici */
.projects-grid,
.portfolio-grid,
.cards-grid,
.services-grid,
.stats-grid,
.contact-grid,
.footer-inner,
.policy-grid,
.colorlab-grid,
.lab-grid {
    max-width: 100%;
}

/* Immagini portfolio sempre visibili intere */
.project-card img,
.portfolio-card img,
.project-image img,
.project-thumb img,
.project-thumbnail img {
    width: 100%;
    max-width: 100%;
    object-fit: contain;
}

/* Modale responsive */
.modal,
.project-modal,
.popup,
.lightbox {
    max-width: 100vw;
}

.modal-content,
.project-modal-content,
.popup-content,
.lightbox-content {
    width: min(1100px, calc(100vw - 28px)) !important;
    max-width: calc(100vw - 28px) !important;
    max-height: calc(100vh - 28px) !important;
    overflow: auto !important;
}

.modal img,
.project-modal img,
.popup img,
.lightbox img {
    max-width: 100%;
    max-height: 72vh;
    object-fit: contain;
}

/* Form responsive */
input,
textarea,
button {
    max-width: 100%;
}

textarea {
    resize: vertical;
}

/* Navbar e indicatori laterali */
@media (max-width: 1200px) {
    .section-nav,
    .scroll-nav,
    .vertical-nav {
        right: 18px !important;
        transform: translateY(-50%) scale(.9) !important;
    }

    .hero,
    .hero-content,
    .section-inner,
    .container {
        padding-left: 28px !important;
        padding-right: 28px !important;
    }
}

@media (max-width: 992px) {
    body {
        font-size: 15px;
    }

    .hero,
    .hero-content,
    .section-inner,
    .container {
        padding-left: 22px !important;
        padding-right: 22px !important;
    }

    .projects-grid,
    .portfolio-grid,
    .cards-grid,
    .services-grid,
    .stats-grid,
    .colorlab-grid,
    .lab-grid {
        display: grid !important;
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 18px !important;
    }

    .contact-grid,
    .footer-inner,
    .policy-grid {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 26px !important;
    }

    .watermark,
    .watermark-line,
    .big-watermark,
    .background-title,
    .marquee,
    .marquee-track {
        font-size: clamp(4rem, 14vw, 9rem) !important;
        line-height: .9 !important;
        white-space: nowrap;
    }

    .wm-dot,
    .separator-dot {
        width: 9px !important;
        height: 9px !important;
        margin: 0 24px !important;
    }
}

@media (max-width: 768px) {
    body {
        font-size: 14px;
    }

    header,
    nav,
    .navbar {
        width: 100%;
    }

    .hero,
    .hero-content,
    .section-inner,
    .container {
        padding-left: 18px !important;
        padding-right: 18px !important;
    }

    h1,
    .hero-title {
        font-size: clamp(3rem, 17vw, 6rem) !important;
        line-height: .88 !important;
        word-break: normal;
    }

    h2,
    .section-title {
        font-size: clamp(2rem, 10vw, 4rem) !important;
        line-height: 1 !important;
    }

    .projects-grid,
    .portfolio-grid,
    .cards-grid,
    .services-grid,
    .stats-grid,
    .colorlab-grid,
    .lab-grid {
        grid-template-columns: 1fr !important;
        gap: 18px !important;
    }

    .project-card,
    .portfolio-card,
    .service-card,
    .lab-card,
    .colorlab-card {
        width: 100% !important;
    }

    .project-card img,
    .portfolio-card img,
    .project-image img,
    .project-thumb img,
    .project-thumbnail img {
        height: auto !important;
        min-height: 0 !important;
        object-fit: contain !important;
    }

    .contact-form,
    form {
        width: 100% !important;
    }

    input,
    textarea {
        width: 100% !important;
        min-width: 0 !important;
    }

    .section-nav,
    .scroll-nav,
    .vertical-nav {
        right: 10px !important;
        transform: translateY(-50%) scale(.75) !important;
        opacity: .75;
    }

    .watermark,
    .watermark-line,
    .big-watermark,
    .background-title,
    .marquee,
    .marquee-track {
        font-size: clamp(3.2rem, 18vw, 7rem) !important;
        opacity: .045 !important;
    }

    .modal-content,
    .project-modal-content,
    .popup-content,
    .lightbox-content {
        display: block !important;
        width: calc(100vw - 22px) !important;
        max-width: calc(100vw - 22px) !important;
        padding: 18px !important;
    }

    .modal img,
    .project-modal img,
    .popup img,
    .lightbox img {
        width: 100%;
        max-height: 52vh;
        object-fit: contain;
    }

    .policy-toggle,
    .policy-accordion,
    .policy-box {
        width: 100% !important;
        max-width: 100% !important;
    }

    .policy-grid {
        grid-template-columns: 1fr !important;
    }

    footer,
    .footer {
        padding-left: 18px !important;
        padding-right: 18px !important;
    }

    .footer-inner {
        grid-template-columns: 1fr !important;
        text-align: left !important;
    }
}

@media (max-width: 480px) {
    .hero,
    .hero-content,
    .section-inner,
    .container {
        padding-left: 14px !important;
        padding-right: 14px !important;
    }

    h1,
    .hero-title {
        font-size: clamp(2.5rem, 18vw, 4.4rem) !important;
    }

    .logo,
    .brand {
        transform: scale(.9);
        transform-origin: left center;
    }

    .btn,
    button,
    .button {
        width: 100%;
        justify-content: center;
        text-align: center;
    }

    .watermark,
    .watermark-line,
    .big-watermark,
    .background-title,
    .marquee,
    .marquee-track {
        font-size: clamp(2.8rem, 20vw, 5.5rem) !important;
    }

    .wm-dot,
    .separator-dot {
        width: 7px !important;
        height: 7px !important;
        margin: 0 14px !important;
    }

    .section-nav,
    .scroll-nav,
    .vertical-nav {
        display: none !important;
    }

    .modal-content,
    .project-modal-content,
    .popup-content,
    .lightbox-content {
        padding: 14px !important;
    }
}


/* =========================================================
   MOBILE HERO FIX - ErMatte Portfolio
   Correzione layout telefono: niente tagli orizzontali
   ========================================================= */

@media (max-width: 768px) {
    html,
    body {
        width: 100%;
        max-width: 100%;
        overflow-x: hidden !important;
    }

    body {
        min-width: 0 !important;
    }

    .page,
    .site,
    main,
    .main,
    .container,
    .wrapper,
    .section-inner,
    section {
        width: 100% !important;
        max-width: 100% !important;
        overflow-x: hidden !important;
    }

    header,
    .header,
    .navbar,
    .nav {
        width: 100% !important;
        max-width: 100% !important;
        left: 0 !important;
        right: 0 !important;
        padding: 22px 22px 0 !important;
    }

    .hero,
    #home,
    .hero-section {
        width: 100% !important;
        min-height: 100svh !important;
        overflow: hidden !important;
        padding: 120px 22px 70px !important;
    }

    .hero-content,
    .hero-inner {
        width: 100% !important;
        max-width: 100% !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: flex-start !important;
        justify-content: center !important;
        gap: 22px !important;
    }

    .hero-title,
    h1.hero-title,
    .hero h1,
    #home h1 {
        width: 100% !important;
        max-width: 100% !important;
        font-size: clamp(4rem, 21vw, 6.2rem) !important;
        line-height: .82 !important;
        letter-spacing: -0.08em !important;
        white-space: normal !important;
        word-break: normal !important;
        overflow-wrap: normal !important;
        transform: none !important;
    }

    .hero-title span,
    .hero h1 span,
    #home h1 span {
        display: block !important;
        max-width: 100% !important;
    }

    .hero-subtitle,
    .hero-kicker,
    .eyebrow {
        max-width: 100% !important;
        font-size: .72rem !important;
        letter-spacing: .38em !important;
        line-height: 1.5 !important;
    }

    .hero p,
    .hero-description,
    .intro-text {
        max-width: 100% !important;
        font-size: 1rem !important;
        line-height: 1.7 !important;
    }

    .hero-actions,
    .cta-row,
    .buttons {
        width: 100% !important;
        display: flex !important;
        flex-direction: column !important;
        gap: 16px !important;
    }

    .hero-actions a,
    .hero-actions button,
    .cta-row a,
    .cta-row button,
    .btn,
    .button {
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
    }

    .hero-shape,
    .shape,
    .outline-shape,
    .decor-shape {
        max-width: 45vw !important;
        right: -10vw !important;
        opacity: .55 !important;
        pointer-events: none !important;
    }

    .section-nav,
    .scroll-nav,
    .vertical-nav {
        display: none !important;
    }

    .watermark,
    .watermark-line,
    .big-watermark,
    .background-title,
    .marquee,
    .marquee-track {
        max-width: none !important;
        font-size: clamp(3rem, 18vw, 6rem) !important;
        transform: none !important;
    }
}

@media (max-width: 430px) {
    header,
    .header,
    .navbar,
    .nav {
        padding: 18px 18px 0 !important;
    }

    .hero,
    #home,
    .hero-section {
        padding: 112px 18px 58px !important;
    }

    .hero-title,
    h1.hero-title,
    .hero h1,
    #home h1 {
        font-size: clamp(3.6rem, 22vw, 5.2rem) !important;
        line-height: .84 !important;
        letter-spacing: -0.07em !important;
    }

    .hero-subtitle,
    .hero-kicker,
    .eyebrow {
        font-size: .68rem !important;
        letter-spacing: .32em !important;
    }

    .logo,
    .brand,
    .site-logo {
        max-width: calc(100vw - 120px) !important;
        overflow: hidden !important;
    }

    .logo-subtitle,
    .brand-subtitle {
        white-space: nowrap !important;
        max-width: calc(100vw - 120px) !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }
}

@media (max-width: 380px) {
    .hero-title,
    h1.hero-title,
    .hero h1,
    #home h1 {
        font-size: clamp(3.1rem, 21vw, 4.5rem) !important;
    }
}
