/* =====================================================================
   PUGLIAI — Landing page styles  (cinematic dark, built on brand.css)
   ===================================================================== */

:root{
  --nav-h: 68px;
  --ease: cubic-bezier(.22,.61,.36,1);
  --glass: rgba(11,26,45,.55);
  --hairline: rgba(255,255,255,.10);
  --hairline-2: rgba(255,255,255,.06);
  --txt-dim: rgba(255,255,255,.72);
  --txt-faint: rgba(255,255,255,.58);
}

html{ scroll-behavior:smooth; }
body{
  background: var(--notte);
  color:#fff;
  overflow-x:clip;
}
html{ overflow-x:clip; }
body.no-scroll{ overflow:hidden; }

::selection{ background: var(--green-400); color: var(--notte); }

img{ max-width:100%; display:block; }
a{ text-decoration:none; color:inherit; }

.shell{ max-width: 1240px; margin:0 auto; padding:0 40px; }
@media (max-width:720px){ .shell{ padding:0 22px; } }

/* tiny utilities */
.serif{ font-family:var(--serif); font-style:italic; font-weight:300; }
.grad-text{
  background: linear-gradient(100deg, var(--green-400) 0%, #4fd2c0 42%, var(--blue-400) 100%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.eyebrow-lux{
  display:inline-flex; align-items:center; gap:10px;
  font-size:12px; font-weight:600; letter-spacing:.22em; text-transform:uppercase;
  color: var(--blue-200);
}
.eyebrow-lux::before{
  content:""; width:26px; height:1px; background:linear-gradient(90deg, transparent, var(--green-400));
}

/* =========================================================
   NAV
   ========================================================= */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:60;
  height:var(--nav-h);
  display:flex; align-items:center;
  transition: background .4s var(--ease), border-color .4s var(--ease), backdrop-filter .4s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background: var(--glass);
  -webkit-backdrop-filter: blur(16px) saturate(160%);
  backdrop-filter: blur(16px) saturate(160%);
  border-bottom:1px solid var(--hairline);
}
.nav__inner{ max-width:1240px; margin:0 auto; padding:0 40px; width:100%; display:flex; align-items:center; justify-content:space-between; gap:24px; }
.nav__logo{ display:flex; align-items:center; gap:11px; }
.nav__logo img{ height:26px; }
.nav__links{ display:flex; align-items:center; gap:4px; }
.nav__links a{
  font-size:13.5px; font-weight:500; color:var(--txt-dim);
  padding:8px 14px; border-radius:999px; transition:color .2s, background .2s;
}
.nav__links a:hover{ color:#fff; background:rgba(255,255,255,.06); }
.nav__right{ display:flex; align-items:center; gap:14px; }
.lang{
  display:flex; align-items:center; border:1px solid var(--hairline); border-radius:999px; overflow:hidden;
  font-size:12px; font-weight:600;
}
.lang button{
  background:none; border:none; color:var(--txt-faint); cursor:pointer;
  padding:6px 11px; font:inherit; letter-spacing:.04em; transition:.2s;
}
.lang button.on{ background:rgba(255,255,255,.12); color:#fff; }
.btn{
  display:inline-flex; align-items:center; gap:9px; cursor:pointer; border:none;
  font-family:inherit; font-weight:600; font-size:14px; letter-spacing:.01em;
  padding:12px 22px; border-radius:11px; transition: transform .25s var(--ease), box-shadow .25s, background .25s; white-space:nowrap;
}
.btn svg{ width:17px; height:17px; }
.btn--grad{
  position:relative; color:#fff;
  background: linear-gradient(118deg, var(--green) 0%, #1a7b6e 50%, var(--blue) 100%);
  box-shadow: 0 10px 30px -10px rgba(19,92,169,.7), inset 0 1px 0 rgba(255,255,255,.18);
}
.btn--grad:hover{ transform: translateY(-2px); box-shadow:0 16px 40px -12px rgba(19,92,169,.85), inset 0 1px 0 rgba(255,255,255,.25); }
.btn--ghost{ background:rgba(255,255,255,.05); color:#fff; border:1px solid var(--hairline); }
.btn--ghost:hover{ background:rgba(255,255,255,.1); transform:translateY(-2px); }
.btn--sm{ padding:10px 18px; font-size:13px; }
.btn--dark{ background:var(--notte); color:#fff; }
.btn--dark:hover{ transform:translateY(-2px); box-shadow: var(--shadow-lg); }
.nav__burger{ display:none; background:none; border:none; cursor:pointer; flex-direction:column; gap:5px; padding:8px; }
.nav__burger span{ width:22px; height:2px; background:#fff; border-radius:2px; transition:.3s; }
@media (max-width:1080px){ .nav__links{ display:none; } }
@media (max-width:980px){
  .nav__inner{ padding:0 22px; }
  .nav__cta{ display:none; }
  .nav__burger{ display:flex; }
}

/* mobile menu */
.mmenu{
  position:fixed; inset:0; z-index:55; background:rgba(8,18,32,.96);
  -webkit-backdrop-filter:blur(20px); backdrop-filter:blur(20px);
  display:flex; flex-direction:column; justify-content:center; gap:6px; padding:0 32px;
  opacity:0; pointer-events:none; transition:opacity .35s var(--ease);
}
.mmenu.open{ opacity:1; pointer-events:auto; }
.mmenu a{ font-size:30px; font-weight:600; padding:12px 0; color:#fff; border-bottom:1px solid var(--hairline-2); }
.mmenu a .serif{ color:var(--green-400); }

/* =========================================================
   AURORA / ambient background
   ========================================================= */
.aurora{ position:absolute; inset:0; overflow:hidden; pointer-events:none; z-index:0; }
.aurora i{
  position:absolute; border-radius:50%; filter:blur(70px); opacity:var(--aurora-op,.55);
  mix-blend-mode:screen; will-change:transform;
}
.aurora .a1{ width:60vw; height:60vw; left:-12vw; bottom:-20vw; background:radial-gradient(circle, rgba(27,144,50,.55), transparent 62%); animation: drift1 22s ease-in-out infinite; }
.aurora .a2{ width:55vw; height:55vw; right:-10vw; top:-18vw; background:radial-gradient(circle, rgba(19,92,169,.6), transparent 62%); animation: drift2 26s ease-in-out infinite; }
.aurora .a3{ width:36vw; height:36vw; left:40%; top:30%; background:radial-gradient(circle, rgba(26,123,110,.5), transparent 60%); animation: drift3 30s ease-in-out infinite; }
@keyframes drift1{ 0%,100%{ transform:translate(0,0) scale(1);} 50%{ transform:translate(8vw,-6vw) scale(1.15);} }
@keyframes drift2{ 0%,100%{ transform:translate(0,0) scale(1);} 50%{ transform:translate(-7vw,7vw) scale(1.2);} }
@keyframes drift3{ 0%,100%{ transform:translate(0,0) scale(1);} 50%{ transform:translate(-10vw,-4vw) scale(.85);} }
/* fine grain to kill banding */
.grain{ position:absolute; inset:0; z-index:1; pointer-events:none; opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }

/* =========================================================
   HERO
   ========================================================= */
.hero{
  position:relative; min-height:100svh; display:flex; align-items:center;
  padding-top:var(--nav-h); overflow:hidden;
  background:
    radial-gradient(120% 90% at 80% -10%, rgba(19,92,169,.30), transparent 55%),
    radial-gradient(90% 80% at 0% 110%, rgba(27,144,50,.26), transparent 55%),
    var(--notte);
}
.hero__canvas{ position:absolute; inset:0; width:100%; height:100%; z-index:2; }
.hero__grid{
  position:relative; z-index:3; width:100%;
  max-width:1240px; margin:0 auto; padding:0 40px;
  display:grid; grid-template-columns: 1.02fr .98fr; align-items:center; gap:40px;
}
.hero__copy{ max-width:620px; }
.hero h1{
  font-size:clamp(40px, 5.6vw, 80px); font-weight:700; line-height:1.0; letter-spacing:-.035em;
  margin-top:22px;
}
.hero h1 .serif{ color:var(--green-400); }
.hero__lead{
  margin-top:26px; font-size:clamp(17px,1.55vw,20px); line-height:1.6; color:var(--txt-dim); max-width:50ch;
}
.hero__cta{ margin-top:36px; display:flex; gap:14px; flex-wrap:wrap; align-items:center; }
.hero__trust{ margin-top:40px; display:flex; gap:28px; flex-wrap:wrap; }
.hero__trust .ti{ display:flex; flex-direction:column; gap:3px; }
.hero__trust .ti b{ font-size:24px; font-weight:700; font-variant-numeric:tabular-nums; letter-spacing:-.02em; }
.hero__trust .ti span{ font-size:12px; color:var(--txt-faint); letter-spacing:.04em; }
.hero__trust .ti b .grad-text{ }
.hero__treewrap{ position:relative; height:100%; min-height:60vh; }
.scrollcue{
  position:absolute; left:50%; bottom:26px; transform:translateX(-50%); z-index:4;
  display:flex; flex-direction:column; align-items:center; gap:8px; color:var(--txt-faint); font-size:11px; letter-spacing:.2em; text-transform:uppercase;
}
.scrollcue .mouse{ width:22px; height:34px; border:1.5px solid var(--hairline); border-radius:12px; position:relative; }
.scrollcue .mouse::before{ content:""; position:absolute; left:50%; top:7px; width:3px; height:7px; border-radius:2px; background:var(--green-400); transform:translateX(-50%); animation: scrolldot 1.8s var(--ease) infinite; }
@keyframes scrolldot{ 0%{ opacity:0; transform:translate(-50%,0);} 30%{opacity:1;} 70%{ opacity:1; transform:translate(-50%,9px);} 100%{ opacity:0; transform:translate(-50%,12px);} }
@media (max-width:920px){
  .hero__grid{ grid-template-columns:1fr; gap:0; }
  .hero__treewrap{ position:absolute; inset:0; opacity:.5; min-height:0; }
  .hero__copy{ position:relative; }
}

/* hero canvas should not block buttons but sits above bg */
.hero__canvas{ pointer-events:none; }

/* =========================================================
   SECTION scaffolding
   ========================================================= */
.sec{ position:relative; padding:130px 0; }
.sec--tight{ padding:96px 0; }
.sec--dark{ background:var(--notte); }
.sec--darker{ background:#081320; }
.sec--panel{ background: var(--notte-800); }
.sec--light{ background: var(--paper); color:var(--ink); }
.sec--light .shead__lead{ color:var(--slate); }
.divider{ height:1px; background:linear-gradient(90deg, transparent, var(--hairline), transparent); }

.shead{ max-width:760px; margin:0 auto 64px; text-align:center; }
.shead--left{ text-align:left; margin-left:0; }
.shead h2{
  font-size:clamp(30px,3.9vw,52px); font-weight:700; letter-spacing:-.028em; line-height:1.04; margin-top:16px;
}
.shead h2 .serif{ color:var(--green-400); }
.sec--light .shead h2 .serif{ color:var(--blue); }
.shead__lead{ margin-top:20px; font-size:clamp(16px,1.5vw,19px); line-height:1.6; color:var(--txt-dim); }
.sec--light .eyebrow-lux{ color:var(--blue); }
.sec--light .eyebrow-lux::before{ background:linear-gradient(90deg,transparent,var(--green)); }

/* =========================================================
   STATS
   ========================================================= */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--hairline-2); border:1px solid var(--hairline-2); border-radius:20px; overflow:hidden; }
.stat{ background:rgba(255,255,255,.015); padding:40px 30px; position:relative; }
.stat .n{ font-size:clamp(40px,4.6vw,60px); font-weight:700; letter-spacing:-.03em; line-height:1; font-variant-numeric:tabular-nums; }
.stat .l{ margin-top:12px; font-size:14.5px; color:#fff; font-weight:500; }
.stat .s{ margin-top:4px; font-size:12px; color:var(--txt-faint); }
@media (max-width:820px){ .stats{ grid-template-columns:1fr 1fr; } }
@media (max-width:460px){ .stats{ grid-template-columns:1fr; } }

/* =========================================================
   METAPHOR (light, editorial)
   ========================================================= */
.meta{ display:grid; grid-template-columns: 1fr 1fr; gap:60px; align-items:center; }
.meta__visual{
  position:relative; aspect-ratio:1/1; border-radius:26px; overflow:hidden;
  background:
    radial-gradient(80% 70% at 50% 110%, rgba(27,144,50,.12), transparent 60%),
    linear-gradient(160deg, #fff, #eef3f9);
  border:1px solid var(--line); box-shadow: var(--shadow-lg);
  display:grid; place-items:center;
}
.meta__visual canvas{ position:absolute; inset:0; width:100%; height:100%; }
.meta__halo{ position:absolute; width:78%; height:78%; border-radius:50%; filter:blur(46px);
  background: radial-gradient(circle, rgba(62,132,203,.28), rgba(52,177,76,.18) 50%, transparent 70%); animation: halo 8s ease-in-out infinite; }
@keyframes halo{ 0%,100%{ transform:scale(1); opacity:.8;} 50%{ transform:scale(1.12); opacity:1;} }
.meta__tree{ position:relative; width:62%; max-width:300px; filter: drop-shadow(0 18px 40px rgba(11,26,45,.22)); animation: treefloat 9s ease-in-out infinite; }
@keyframes treefloat{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-12px); } }
.mnode{ position:absolute; left:var(--x); top:var(--y); width:10px; height:10px; border-radius:50%;
  background: var(--blue); box-shadow:0 0 0 0 rgba(62,132,203,.6); transform:translate(-50%,-50%);
  animation: nodepulse 2.6s var(--ease) infinite; animation-delay:var(--d); }
@keyframes nodepulse{ 0%{ box-shadow:0 0 0 0 rgba(62,132,203,.55); opacity:.9; } 70%{ box-shadow:0 0 0 16px rgba(62,132,203,0); opacity:1; } 100%{ box-shadow:0 0 0 0 rgba(62,132,203,0); opacity:.9; } }
.meta__rows{ display:grid; }
.mrow{ display:grid; grid-template-columns:auto 1fr; gap:20px; padding:26px 0; border-top:1px solid var(--line); align-items:start; cursor:default; transition:.3s; }
.mrow:last-child{ border-bottom:1px solid var(--line); }
.mrow:hover{ padding-left:8px; }
.mrow__icon{ width:46px; height:46px; border-radius:13px; display:grid; place-items:center; color:#fff; flex:none; box-shadow: var(--shadow-sm); }
.mrow__k{ font-size:19px; font-weight:700; letter-spacing:-.01em; display:flex; align-items:baseline; gap:10px; }
.mrow__k .it{ font-family:var(--serif); font-style:italic; font-weight:400; color:var(--mist); font-size:15px; }
.mrow__v{ margin-top:6px; font-size:15px; color:var(--slate); line-height:1.55; }
.mrow__v b{ color:var(--ink); font-weight:600; }
@media (max-width:900px){ .meta{ grid-template-columns:1fr; gap:36px; } }

/* =========================================================
   SERVICE CARDS
   ========================================================= */
.cards3{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
@media (max-width:900px){ .cards3{ grid-template-columns:1fr; } }
.gcard{
  position:relative; border-radius:20px; padding:34px 30px 30px;
  background: linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.015));
  border:1px solid var(--hairline); overflow:hidden;
  transition: transform .4s var(--ease), border-color .4s, background .4s;
}
.gcard::before{
  content:""; position:absolute; inset:0; border-radius:20px; padding:1px;
  background:linear-gradient(140deg, rgba(52,177,76,.5), transparent 40%, rgba(62,132,203,.5));
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude;
  opacity:0; transition:opacity .4s;
}
.gcard:hover{ transform:translateY(-6px); background:linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.02)); }
.gcard:hover::before{ opacity:1; }
.gcard__ic{ width:54px; height:54px; border-radius:15px; display:grid; place-items:center; color:#fff; margin-bottom:22px;
  background:linear-gradient(140deg, rgba(52,177,76,.25), rgba(62,132,203,.25)); border:1px solid var(--hairline); }
.gcard__ic svg{ width:26px; height:26px; }
.gcard h3{ font-size:21px; font-weight:700; letter-spacing:-.01em; margin-bottom:10px; }
.gcard p{ font-size:14.5px; color:var(--txt-dim); line-height:1.6; }
.gcard__link{ margin-top:20px; display:inline-flex; align-items:center; gap:7px; font-size:13.5px; font-weight:600; color:var(--green-400); }
.gcard__link svg{ width:16px; height:16px; transition:transform .25s; }
.gcard:hover .gcard__link svg{ transform:translateX(4px); }

/* =========================================================
   ON-PREMISE feature cards
   ========================================================= */
.prod{ display:grid; grid-template-columns:1fr 1fr; gap:24px; }
@media (max-width:860px){ .prod{ grid-template-columns:1fr; } }
.pcard{
  position:relative; border-radius:22px; padding:38px; overflow:hidden;
  background: linear-gradient(165deg, rgba(255,255,255,.05), rgba(255,255,255,.01));
  border:1px solid var(--hairline);
}
.pcard__glow{ position:absolute; width:260px; height:260px; border-radius:50%; filter:blur(50px); opacity:.4; top:-80px; right:-60px; pointer-events:none; }
.pcard--g .pcard__glow{ background:var(--green); }
.pcard--b .pcard__glow{ background:var(--blue); }
.pcard__tag{ display:inline-block; font-size:11.5px; font-weight:700; letter-spacing:.08em; padding:5px 12px; border-radius:999px; border:1px solid var(--hairline); margin-bottom:18px; }
.pcard--g .pcard__tag{ color:var(--green-400); background:rgba(52,177,76,.08); }
.pcard--b .pcard__tag{ color:var(--blue-400); background:rgba(62,132,203,.1); }
.pcard h3{ position:relative; font-size:26px; font-weight:700; letter-spacing:-.02em; }
.pcard__price{ font-family:var(--serif); font-style:italic; color:var(--txt-faint); font-size:16px; margin:6px 0 16px; }
.pcard p{ position:relative; font-size:15px; color:var(--txt-dim); line-height:1.6; }
.pcard ul{ position:relative; list-style:none; margin:22px 0 26px; display:grid; gap:11px; }
.pcard li{ display:flex; gap:11px; font-size:14px; color:rgba(255,255,255,.82); align-items:flex-start; }
.pcard li svg{ width:19px; height:19px; flex:none; margin-top:1px; }
.pcard--g li svg{ color:var(--green-400); }
.pcard--b li svg{ color:var(--blue-400); }

/* sovereignty band */
.soverign{ margin-top:30px; border-radius:18px; padding:28px 34px; display:flex; gap:18px; align-items:center; justify-content:center; flex-wrap:wrap; text-align:center;
  background:rgba(8,18,32,.6); border:1px solid var(--hairline); }
.soverign svg{ width:30px; height:30px; color:var(--green-400); flex:none; }
.soverign p{ font-size:15px; color:var(--txt-dim); max-width:60ch; }
.soverign b{ color:#fff; font-weight:600; }

/* =========================================================
   ACCELERATOR feature band
   ========================================================= */
.accel{
  position:relative; border-radius:28px; overflow:hidden; padding:64px;
  background: linear-gradient(125deg, #0c2a22 0%, #0a2138 55%, #0b1a2d 100%);
  border:1px solid var(--hairline);
}
.accel__glow{ position:absolute; inset:0; background:
  radial-gradient(50% 60% at 12% 20%, rgba(27,144,50,.4), transparent 60%),
  radial-gradient(50% 60% at 90% 90%, rgba(19,92,169,.45), transparent 60%); pointer-events:none; }
.accel__inner{ position:relative; display:grid; grid-template-columns:1.1fr .9fr; gap:48px; align-items:center; }
.accel h2{ font-size:clamp(28px,3.4vw,44px); font-weight:700; letter-spacing:-.025em; line-height:1.05; }
.accel h2 .serif{ color:var(--green-400); }
.accel p{ margin-top:18px; color:var(--txt-dim); font-size:16px; line-height:1.6; max-width:46ch; }
.accel__feats{ display:grid; gap:14px; }
.accel__feat{ display:flex; gap:14px; align-items:center; padding:16px 20px; border-radius:14px; background:rgba(255,255,255,.04); border:1px solid var(--hairline); }
.accel__feat .fn{ font-family:var(--serif); font-style:italic; color:var(--green-400); font-size:22px; flex:none; min-width:34px; width:auto; white-space:nowrap; }
.accel__feat span{ font-size:14.5px; color:rgba(255,255,255,.86); }
@media (max-width:840px){ .accel{ padding:40px 28px; } .accel__inner{ grid-template-columns:1fr; gap:32px; } }

/* =========================================================
   PROCESS / timeline
   ========================================================= */
.proc{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; position:relative; }
.proc::before{ content:""; position:absolute; top:34px; left:8%; right:8%; height:1px; background:linear-gradient(90deg, var(--green-400), var(--blue-400)); opacity:.4; }
.pstep{ position:relative; }
.pstep__dot{ width:68px; height:68px; border-radius:50%; display:grid; place-items:center; margin-bottom:24px;
  background:var(--notte); border:1px solid var(--hairline); position:relative; z-index:2; box-shadow:0 0 0 6px var(--notte); }
.pstep__dot b{ font-family:var(--serif); font-style:italic; font-size:26px; color:var(--green-400); }
.pstep h4{ font-size:18px; font-weight:700; margin-bottom:8px; }
.pstep .wk{ font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--blue-400); font-weight:600; margin-bottom:10px; }
.pstep p{ font-size:14px; color:var(--txt-dim); line-height:1.55; }
@media (max-width:860px){ .proc{ grid-template-columns:1fr 1fr; } .proc::before{ display:none; } }
@media (max-width:460px){ .proc{ grid-template-columns:1fr; } }

/* =========================================================
   CLIENTS / LOGO WALL (light)
   ========================================================= */
.clients{ padding-bottom:clamp(72px,9vw,104px); }
.clients .shead{ margin-bottom:48px; }
.lwall{ position:relative; }
.lwall__viewport{ overflow:hidden; }
.lwall::before, .lwall::after{ content:""; position:absolute; top:0; bottom:0; z-index:2;
  width:clamp(48px,9vw,150px); pointer-events:none; }
.lwall::before{ left:0; background:linear-gradient(90deg, var(--paper) 8%, transparent); }
.lwall::after{ right:0; background:linear-gradient(270deg, var(--paper) 8%, transparent); }
.lwall__track{ display:flex; width:max-content; align-items:center;
  animation:logoscroll 64s linear infinite; }
.lwall:hover .lwall__track, .lwall:focus-within .lwall__track{ animation-play-state:paused; }
.lwall__group{ display:flex; align-items:center; flex:none; list-style:none; margin:0; padding:0; }
.lwall__item{ flex:none; display:grid; place-items:center; height:108px; padding:0 clamp(22px,3.4vw,50px); }
.lwall__item img{ display:block; width:auto; height:auto; max-height:40px; max-width:152px; object-fit:contain;
  mix-blend-mode:multiply; filter:grayscale(1); opacity:.58;
  transition:filter .45s var(--ease), opacity .45s var(--ease), transform .45s var(--ease); }
.lwall__item:hover img, .lwall__item:focus-visible img{ filter:grayscale(0); opacity:1; transform:scale(1.06); }
/* whitespace-padded source canvases need a larger box to read at the same optical size */
.lwall__item--lg img{ max-height:58px; max-width:166px; }
.lwall__item--xl img{ max-height:74px; max-width:182px; }
@keyframes logoscroll{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }
@media (max-width:640px){
  .lwall__item{ height:88px; padding:0 24px; }
  .lwall__item img{ max-height:30px; max-width:116px; }
  .lwall__item--lg img{ max-height:44px; max-width:128px; }
  .lwall__item--xl img{ max-height:56px; max-width:140px; }
}
@media (prefers-reduced-motion: reduce){
  .lwall__track{ animation:none; flex-wrap:wrap; width:auto; justify-content:center; row-gap:8px; }
  .lwall__group[aria-hidden="true"]{ display:none; }
  .lwall::before, .lwall::after{ display:none; }
}

/* =========================================================
   TESTIMONIALS (light)
   ========================================================= */
.tgrid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
@media (max-width:900px){ .tgrid{ grid-template-columns:1fr; } }
.tcard{ background:#fff; border:1px solid var(--line); border-radius:20px; padding:34px 30px; box-shadow:var(--shadow-sm); display:flex; flex-direction:column; transition:.35s var(--ease); }
.tcard:hover{ transform:translateY(-5px); box-shadow:var(--shadow-md); }
.tcard .stars{ display:flex; gap:3px; color:var(--terra); margin-bottom:18px; }
.tcard .stars svg{ width:17px; height:17px; }
.tcard blockquote{ font-size:16px; line-height:1.62; color:var(--ink); font-weight:450; flex:1; }
.tcard blockquote b{ color:var(--green-800); font-weight:700; }
.tcard__by{ margin-top:24px; display:flex; align-items:center; gap:13px; }
.tcard__av{ width:44px; height:44px; border-radius:50%; display:grid; place-items:center; color:#fff; font-weight:700; font-size:16px; background:var(--grad); flex:none; }
.tcard__by .nm{ font-size:14.5px; font-weight:700; }
.tcard__by .rl{ font-size:12.5px; color:var(--mist); }

/* =========================================================
   FINAL CTA
   ========================================================= */
.finale{ position:relative; overflow:hidden; padding:140px 0; background:var(--notte); text-align:center; }
.finale__canvas{ position:absolute; inset:0; z-index:1; opacity:.7; pointer-events:none; }
.finale__inner{ position:relative; z-index:3; max-width:780px; margin:0 auto; }
.finale h2{ font-size:clamp(34px,5.2vw,68px); font-weight:700; letter-spacing:-.035em; line-height:1.02; }
.finale h2 .serif{ color:var(--green-400); }
.finale p{ margin:24px auto 0; font-size:clamp(17px,1.7vw,21px); color:var(--txt-dim); max-width:48ch; line-height:1.55; }
.finale__cta{ margin-top:40px; display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
.finale__contact{ margin-top:52px; display:flex; gap:40px; justify-content:center; flex-wrap:wrap; color:var(--txt-faint); font-size:14px; }
.finale__contact b{ display:block; color:#fff; font-weight:600; margin-bottom:4px; }

/* =========================================================
   FOOTER
   ========================================================= */
.foot{ background:#081320; border-top:1px solid var(--hairline); padding:54px 0 40px; }
.foot__top{ display:flex; justify-content:space-between; align-items:flex-start; gap:40px; flex-wrap:wrap; }
.foot__brand img{ height:26px; margin-bottom:14px; }
.foot__brand p{ font-size:13.5px; color:var(--txt-faint); max-width:30ch; line-height:1.6; }
.foot__cols{ display:flex; gap:64px; flex-wrap:wrap; }
.foot__col h5{ font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--txt-faint); margin-bottom:16px; }
.foot__col a{ display:block; font-size:14px; color:var(--txt-dim); padding:5px 0; transition:color .2s; }
.foot__col a:hover{ color:#fff; }
.foot__bar{ margin-top:46px; padding-top:24px; border-top:1px solid var(--hairline-2); display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; font-size:12.5px; color:var(--txt-faint); }

/* =========================================================
   reveal-on-scroll
   ========================================================= */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal[data-d="1"]{ transition-delay:.08s; }
.reveal[data-d="2"]{ transition-delay:.16s; }
.reveal[data-d="3"]{ transition-delay:.24s; }
.reveal[data-d="4"]{ transition-delay:.32s; }
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1; transform:none; }
  .aurora i{ animation:none; }
}

/* lang visibility */
[data-lang-en], [data-lang-it]{ }
body[data-lang="it"] [data-lang-en]{ display:none; }
body[data-lang="en"] [data-lang-it]{ display:none; }
