/* ── Sugo Display (titoli) · metti i file in /fonts ── */
@font-face{
  font-family:'Sugo Display';
  src:url('fonts/sugo-display.ttf') format('truetype');
  font-weight:100 900;
  font-style:normal;
  font-display:swap;
}

:root{
  /* ── NICOLA ATZORI brand · navy + blu · clean/white/hexagons ── */
  --bg:     #eef2fb;
  --surf:   #ffffff;
  --surf2:  #f4f7fe;
  --border: #e2e8f5;
  --navy:   #0f294a;
  --navy2:  #0b1f3a;
  --blue:   #04f7ee;
  --blue-d: #03d4cd;
  --blue-soft: #3a5a8a;
  --indigo: #4d61d6;
  --green:  #16a34a;
  --gold:   #f59e0b;
  --red:    #ef4444;
  --text:   #0f294a;
  --text2:  #475569;
  --dim:    #94a3b8;
  --maxw:   1180px;
}
*{margin:0;padding:0;box-sizing:border-box;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}
html{scroll-behavior:smooth;overflow-x:clip;}
body{
  font-family:'Sora',system-ui,sans-serif;
  color:var(--text);
  line-height:1.6;
  background:
    url("data:image/svg+xml,%3Csvg width='28' height='49' viewBox='0 0 28 49' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23cdd9ef' fill-opacity='0.45'%3E%3Cpath d='M13.99 9.25l13 7.5v15l-13 7.5L1 31.75v-15l12.99-7.5zM3 17.9v12.7l10.99 6.34 11-6.35V17.9l-11-6.34L3 17.9zM0 15l12.98-7.5V0h-2v6.35L0 12.69v2.3zm0 18.5L12.98 41v8h-2v-6.85L0 35.81v-2.3zM15 0v7.5L27.99 15H28v-2.31h-.01L17 6.35V0h-2zm0 49v-8l12.99-7.5H28v2.31h-.01L17 42.15V49h-2z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E") repeat,
    linear-gradient(180deg,#ffffff 0%,#eef2fb 60%,#e7edf9 100%);
}
h1,h2,h3,h4{font-family:'Sugo Display',Georgia,serif;color:var(--navy);font-weight:600;line-height:1.1;letter-spacing:-.005em;}
a{color:inherit;text-decoration:none;}
p{text-wrap:pretty;}
img{max-width:100%;display:block;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px;}

/* display font (Sugo Display) only on the big headlines */
.hero h1,.page-header h1,.sect-title,.cta-strip h2,footer .big-out{
  font-family:'Sugo Display',Georgia,serif;font-weight:600;letter-spacing:-.01em;line-height:1.0;
}

.eyebrow{
  font-family:'Sora',sans-serif;font-weight:700;font-size:12px;
  letter-spacing:.16em;text-transform:uppercase;color:var(--blue-soft);
  display:inline-block;max-width:100%;
}
.eyebrow::before{content:"";display:inline-block;width:30px;height:2px;vertical-align:middle;margin-right:12px;background:var(--blue-soft);}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:'Sora',sans-serif;font-weight:700;font-size:14px;letter-spacing:.01em;
  padding:13px 26px;border-radius:30px;cursor:pointer;border:1.5px solid transparent;
  transition:transform .16s ease, box-shadow .16s ease, background .16s ease, color .16s ease;
}
.btn:active{transform:translateY(1px);}
.btn-primary{background:var(--blue);color:var(--navy);border-color:var(--blue);box-shadow:0 8px 22px rgba(4,247,238,.4);}
.btn-primary:hover{background:var(--blue-d);border-color:var(--blue-d);box-shadow:0 12px 28px rgba(4,247,238,.5);transform:translateY(-2px);}
.btn-blue{background:var(--blue);color:var(--navy);border-color:var(--blue);box-shadow:0 8px 22px rgba(4,247,238,.35);}
.btn-blue:hover{background:var(--blue-d);border-color:var(--blue-d);transform:translateY(-2px);}
.btn-dark{background:var(--navy);color:#fff;border-color:var(--navy);box-shadow:0 8px 20px rgba(15,41,74,.25);}
.btn-dark:hover{background:var(--navy2);border-color:var(--navy2);transform:translateY(-2px);box-shadow:0 12px 26px rgba(15,41,74,.35);}
.btn-ghost{background:#fff;color:var(--navy);border-color:var(--border);box-shadow:0 2px 6px rgba(15,41,74,.06);}
.btn-ghost:hover{background:var(--navy);color:#fff;border-color:var(--navy);transform:translateY(-2px);}

/* ---------- NAV (navy floating pill) ---------- */
header{position:sticky;top:0;z-index:50;background:rgba(247,249,253,.38);backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);border-bottom:1px solid rgba(226,232,245,.5);padding:14px 0;}
.nav{display:flex;align-items:center;justify-content:space-between;
  background:var(--navy);border-radius:18px;padding:14px 24px;box-shadow:0 10px 30px rgba(15,41,74,.18);}
.brand{display:flex;align-items:center;gap:12px;color:#fff;}
.logo-mark{height:36px;width:auto;display:block;}
.brand .bn{font-family:'Sora',sans-serif;font-weight:800;font-size:16px;letter-spacing:.01em;color:#fff;}
.brand .br{font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--blue);font-family:'Sora';font-weight:600;}
.nav-links{display:flex;align-items:center;gap:28px;}
.nav-links a{color:rgba(255,255,255,.82);font-size:13.5px;font-weight:600;transition:color .15s;}
.nav-links a:hover,.nav-links a.active{color:var(--blue);}
.nav-links a.btn{color:var(--navy);}
.nav-links a.btn.active{color:var(--navy);}
.nav .btn{padding:10px 20px;font-size:13px;}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px;}
.burger span{width:24px;height:2px;background:#fff;display:block;border-radius:2px;}

/* ---------- HERO (light · blob sfumati + esagoni) ---------- */
.hero{position:relative;overflow:hidden;border-bottom:1px solid var(--border);
  background:
    url("data:image/svg+xml,%3Csvg width='28' height='49' viewBox='0 0 28 49' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23cdd9ef' fill-opacity='0.30'%3E%3Cpath d='M13.99 9.25l13 7.5v15l-13 7.5L1 31.75v-15l12.99-7.5zM3 17.9v12.7l10.99 6.34 11-6.35V17.9l-11-6.34L3 17.9zM0 15l12.98-7.5V0h-2v6.35L0 12.69v2.3zm0 18.5L12.98 41v8h-2v-6.85L0 35.81v-2.3zM15 0v7.5L27.99 15H28v-2.31h-.01L17 6.35V0h-2zm0 49v-8l12.99-7.5H28v2.31h-.01L17 42.15V49h-2z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E") repeat,
    linear-gradient(180deg,#e9f0fe 0%,#f2f7fe 55%,#eef2fb 100%);}
.hero-blobs{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0;}
.hero-blobs .blob{position:absolute;border-radius:50%;filter:blur(8px);}
.hero-blobs .b1{width:560px;height:560px;top:-150px;left:-100px;background:radial-gradient(circle,rgba(4,247,238,.55),transparent 70%);}
.hero-blobs .b2{width:600px;height:600px;top:0;right:-150px;background:radial-gradient(circle,rgba(77,97,214,.42),transparent 70%);}
.hero-blobs .b3{width:460px;height:460px;bottom:-180px;left:34%;background:radial-gradient(circle,rgba(58,90,138,.30),transparent 72%);}
.hero-inner{padding-top:84px;padding-bottom:78px;position:relative;z-index:1;}
.hero h1{font-size:clamp(30px,6.2vw,68px);color:var(--navy);margin:18px 0 0;line-height:1.08;max-width:22ch;}
.hero h1::after{content:".";color:var(--blue-soft);}
.hero .role{font-family:'Sora',sans-serif;font-weight:600;font-size:clamp(13px,2vw,16px);
  letter-spacing:.28em;text-transform:uppercase;color:var(--blue-soft);margin-top:18px;}
.hero-sub{font-family:'Sora',sans-serif;font-weight:700;font-size:clamp(18px,2.6vw,27px);
  color:var(--navy);margin-top:16px;letter-spacing:-.01em;}
.hero .claim{font-size:clamp(16px,2.3vw,20px);font-weight:500;color:var(--text2);
  max-width:54ch;margin-top:26px;line-height:1.5;}
.hero .claim b{color:var(--navy);font-weight:700;}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:36px;}
.hero-stats{display:flex;flex-wrap:wrap;gap:46px;margin-top:56px;padding-top:32px;border-top:1px solid var(--border);}
.hero-stats .stat .k{font-family:'Sora',sans-serif;font-weight:800;font-size:42px;color:var(--navy);letter-spacing:-.02em;}
.hero-stats .stat .l{font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--dim);margin-top:4px;font-weight:600;}

/* ---------- PAGE HEADER (light · blob sfumati + esagoni) ---------- */
.page-header{position:relative;overflow:hidden;border-bottom:1px solid var(--border);
  background:
    url("data:image/svg+xml,%3Csvg width='28' height='49' viewBox='0 0 28 49' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23cdd9ef' fill-opacity='0.30'%3E%3Cpath d='M13.99 9.25l13 7.5v15l-13 7.5L1 31.75v-15l12.99-7.5zM3 17.9v12.7l10.99 6.34 11-6.35V17.9l-11-6.34L3 17.9zM0 15l12.98-7.5V0h-2v6.35L0 12.69v2.3zm0 18.5L12.98 41v8h-2v-6.85L0 35.81v-2.3zM15 0v7.5L27.99 15H28v-2.31h-.01L17 6.35V0h-2zm0 49v-8l12.99-7.5H28v2.31h-.01L17 42.15V49h-2z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E") repeat,
    linear-gradient(180deg,#e9f0fe 0%,#f2f7fe 60%,#eef2fb 100%);}
.page-header-inner{padding-top:66px;padding-bottom:58px;position:relative;z-index:1;}
.page-header .b1{width:500px;height:500px;top:-210px;left:-90px;background:radial-gradient(circle,rgba(4,247,238,.55),transparent 70%);}
.page-header .b2{width:560px;height:560px;top:-190px;right:-140px;background:radial-gradient(circle,rgba(77,97,214,.42),transparent 70%);}
.page-header .b3{width:400px;height:400px;bottom:-250px;left:36%;background:radial-gradient(circle,rgba(58,90,138,.30),transparent 72%);}
.page-header h1{font-size:clamp(32px,8vw,94px);color:var(--navy);margin:18px 0 0;}
.page-header p{font-size:clamp(16px,2.2vw,19px);color:var(--text2);max-width:60ch;margin-top:18px;}
.breadcrumb{font-family:'Sora';font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--dim);margin-bottom:6px;font-weight:600;}
.breadcrumb a:hover{color:var(--blue-soft);}

/* ---------- SECTION SHELL ---------- */
section.block{padding:88px 0;}
.sect-head{max-width:680px;}
.sect-title{font-size:clamp(29px,6vw,64px);color:var(--navy);margin:16px 0 0;}
.sect-title em{color:var(--blue-soft);font-style:normal;}
.lead{font-size:17px;color:var(--text2);margin-top:18px;max-width:62ch;}

/* light alternate band */
.alt-bg{background:rgba(255,255,255,.55);border-top:1px solid var(--border);border-bottom:1px solid var(--border);}

/* ---------- CARD base (soft navy shadow) ---------- */
.svc-card,.value,.skill,.pf-card,.tcard,.cform,.phase{
  background:var(--surf);border:1px solid var(--border);border-radius:18px;
  box-shadow:0 12px 34px rgba(15,41,74,.07);
}

/* ---------- SERVICES (cards) ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:50px;}
.svc-card{padding:0;overflow:hidden;transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;}
.svc-card:hover{transform:translateY(-5px);box-shadow:0 26px 50px rgba(15,41,74,.13);border-color:var(--blue);}
.svc-card .idx{font-family:'Sora',sans-serif;font-weight:800;font-size:19px;color:var(--navy);background:var(--blue);
  border-radius:12px;width:52px;height:52px;display:flex;align-items:center;justify-content:center;margin-bottom:22px;
  box-shadow:0 8px 18px rgba(4,247,238,.35);}
.svc-card h3{font-size:21px;font-weight:800;margin-bottom:12px;}
.svc-card p{font-size:14.5px;color:var(--text2);}
.svc-card .tag{display:inline-block;margin-top:16px;font-family:'Sora';font-size:11px;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;color:var(--blue-soft);background:#d6fffb;padding:6px 13px;border-radius:20px;}

/* ====== ILLUSTRAZIONI SERVIZI (animate, brand) ====== */
.svc-body{padding:26px 28px 30px;}
.svc-num{font-family:'Sora';font-weight:700;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--blue-soft);margin-bottom:10px;}
.svc-illo{height:188px;border-bottom:1px solid var(--border);position:relative;overflow:hidden;
  background:radial-gradient(130% 120% at 50% -12%, #ffffff, var(--surf2) 72%);}
.svc-illo.boxed{border:1px solid var(--border);border-radius:16px;box-shadow:0 12px 30px rgba(15,41,74,.07);margin-top:22px;}
.gauge-illo > svg,.cluster-illo > svg{position:absolute;inset:0;width:100%;height:100%;display:block;}
.illo-chips{position:absolute;top:14px;left:14px;right:14px;display:flex;gap:7px;z-index:3;}
.ic-chip{display:inline-flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--border);
  border-radius:9px;padding:5px 9px;font-family:'Sora';font-size:10.5px;font-weight:700;color:var(--navy);box-shadow:0 2px 6px rgba(15,41,74,.06);}
.ic-chip i{width:11px;height:11px;border-radius:4px;background:var(--blue);display:inline-block;}

/* — gauge (Strategia) — */
.gauge-illo .g-track{fill:none;stroke:#e1e9f5;stroke-width:9;stroke-linecap:round;}
.gauge-illo .g-ticks{fill:none;stroke:#c4d4ec;stroke-width:7;stroke-linecap:round;stroke-dasharray:1.5 12;}
.gauge-illo .g-fill{fill:none;stroke:var(--blue);stroke-width:9;stroke-linecap:round;stroke-dasharray:195;}
.gauge-illo .g-needle{stroke:var(--navy);stroke-width:3.5;stroke-linecap:round;transform-origin:120px 118px;}
.gauge-illo .g-hub{fill:var(--navy);}
.gauge-read{position:absolute;left:0;right:0;bottom:14px;text-align:center;z-index:3;}
.gauge-read span{font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--dim);font-weight:700;}
.svc-illo.in .g-fill{animation:gdraw 1.6s .15s cubic-bezier(.5,0,.2,1) both;}
.svc-illo.in .g-needle{animation:gneedle 1.7s .1s cubic-bezier(.45,0,.2,1) both;}
@keyframes gdraw{from{stroke-dashoffset:195}to{stroke-dashoffset:0}}
@keyframes gneedle{from{transform:rotate(-128deg)}to{transform:rotate(0)}}

/* — cluster (Automazione) — */
.cluster-illo .cl-lines line{stroke:#aebfdc;stroke-width:2;stroke-linecap:round;stroke-dasharray:96;}
.cluster-illo .cl-ring{fill:none;stroke:#cdd9ef;stroke-width:2;stroke-dasharray:3 9;transform-origin:120px 104px;animation:spin 40s linear infinite;}
.cluster-illo .cl-node{transform-box:fill-box;transform-origin:center;}
.cluster-illo .cl-node circle{fill:var(--blue);}
.cluster-illo .cl-node .ck{stroke:var(--navy);stroke-width:2.6;fill:none;stroke-linecap:round;stroke-linejoin:round;}
.cluster-illo .cl-node.center circle{fill:var(--navy);}
.cluster-illo .cl-node.center .ck{stroke:var(--blue);}
.svc-illo.in .cl-lines line{animation:cdraw 1s .1s ease both;}
.svc-illo.in .cl-node{animation:pop .7s both;}
.svc-illo.in .cl-node.center{animation-delay:.04s;}
.svc-illo.in .cl-node.nA{animation-delay:.18s;}
.svc-illo.in .cl-node.nB{animation-delay:.27s;}
.svc-illo.in .cl-node.nC{animation-delay:.36s;}
.svc-illo.in .cl-node.nD{animation-delay:.45s;}
@keyframes cdraw{from{stroke-dashoffset:96}to{stroke-dashoffset:0}}
@keyframes pop{0%{opacity:0;transform:scale(0)}65%{transform:scale(1.14)}100%{opacity:1;transform:scale(1)}}
@keyframes spin{to{transform:rotate(360deg)}}

/* — pipeline (Conversione) — */
.pipe-illo .pipe{position:absolute;inset:16px 18px;display:flex;flex-direction:column;gap:8px;z-index:2;}
.pipe-illo .pipe-prog{position:absolute;left:19px;top:6px;bottom:6px;width:2px;background:var(--border);z-index:0;}
.pipe-illo .pipe-prog::after{content:"";position:absolute;inset:0;background:var(--blue);transform-origin:top;}
.pipe-illo .pl{display:flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--border);border-radius:10px;
  padding:8px 11px;font-family:'Sora';font-size:11px;font-weight:600;color:var(--navy);box-shadow:0 2px 6px rgba(15,41,74,.05);position:relative;z-index:1;}
.pipe-illo .pl .pi{width:17px;height:17px;border-radius:5px;background:var(--surf2);border:1px solid var(--border);flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;}
.pipe-illo .pl .ck{margin-left:auto;width:16px;height:16px;border-radius:5px;background:var(--blue);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;}
.pipe-illo .pl .ck svg{width:9px;height:9px;stroke:var(--navy);stroke-width:2.8;fill:none;}
.pipe-illo .pl.final{background:var(--navy);color:#fff;border-color:var(--navy);}
.pipe-illo .pl.final .pi{background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.28);}
.pipe-illo .pl.final .pi svg{width:10px;height:10px;stroke:var(--blue);stroke-width:2.8;fill:none;}
.svc-illo.in .pipe-prog::after{animation:pgrow 1.4s .15s ease both;}
.svc-illo.in .pipe-illo .pl{animation:plin .65s both;}
.svc-illo.in .pipe-illo .pl:nth-child(2){animation-delay:.12s;}
.svc-illo.in .pipe-illo .pl:nth-child(3){animation-delay:.28s;}
.svc-illo.in .pipe-illo .pl:nth-child(4){animation-delay:.44s;}
.svc-illo.in .pipe-illo .pl:nth-child(5){animation-delay:.6s;}
@keyframes pgrow{from{transform:scaleY(0)}to{transform:scaleY(1)}}
@keyframes plin{from{opacity:0;transform:translateY(7px)}to{opacity:1;transform:translateY(0)}}

@media (prefers-reduced-motion: reduce){
  .svc-illo *{animation:none!important;}
  .gauge-illo .g-fill{stroke-dashoffset:0!important;}
  .cluster-illo .cl-lines line{stroke-dashoffset:0!important;}
  .cluster-illo .cl-node{opacity:1!important;transform:none!important;}
  .pipe-illo .pl{opacity:1!important;transform:none!important;}
  .pipe-illo .pipe-prog::after{transform:scaleY(1)!important;}
}

/* ---------- SERVICE DETAIL (servizi page) ---------- */
.svc-detail{display:grid;grid-template-columns:0.9fr 1.1fr;gap:50px;align-items:start;
  padding:54px 0;border-bottom:1px solid var(--border);}
.svc-detail:last-of-type{border-bottom:0;}
.svc-detail .sd-head .n{font-family:'Sora';font-weight:700;color:var(--blue-soft);font-size:13px;letter-spacing:.08em;text-transform:uppercase;}
.svc-detail .sd-head h2{font-size:clamp(26px,3.4vw,36px);font-weight:800;margin:10px 0 16px;}
.svc-detail .sd-head .sub{font-size:16px;color:var(--text2);}
.svc-detail .sd-head .tag{display:inline-block;margin-top:16px;font-family:'Sora';font-size:11px;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;color:var(--blue-soft);background:#d6fffb;padding:6px 13px;border-radius:20px;}
.phases{display:flex;flex-direction:column;gap:14px;}
.phase{padding:22px 24px;position:relative;overflow:hidden;}
.phase::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--blue-soft);}
.phase .pn{font-family:'Sora';font-weight:700;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--blue-soft);margin-bottom:8px;}
.phase h4{font-size:16px;font-weight:800;margin-bottom:7px;}
.phase p{font-size:14px;color:var(--text2);}

/* ---------- ABOUT ---------- */
.about-grid{display:grid;grid-template-columns:0.85fr 1.15fr;gap:54px;align-items:center;}
.photo{border-radius:20px;overflow:hidden;border:1px solid var(--border);box-shadow:0 14px 40px rgba(15,41,74,.1);
  background:var(--surf2);max-width:290px;
  aspect-ratio:3/3.5;display:flex;align-items:flex-end;justify-content:center;position:relative;}
.photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center top;z-index:1;}
.photo::before{content:"NA";position:absolute;top:50%;left:50%;transform:translate(-50%,-60%);
  font-family:'Sugo Display',Georgia,serif;font-size:96px;color:rgba(15,41,74,.07);letter-spacing:.02em;}
.photo span{font-family:'Sora',monospace;font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--dim);background:rgba(255,255,255,.92);padding:8px 12px;border-radius:8px;margin-bottom:18px;position:relative;z-index:1;font-weight:600;}
.about-text p{font-size:15.5px;color:var(--text2);margin-bottom:16px;}
.about-text p strong{color:var(--navy);}
.pull{border-left:3px solid var(--blue-soft);padding:6px 0 6px 20px;margin:22px 0;
  font-family:'Sora',sans-serif;font-weight:700;font-size:20px;color:var(--navy);line-height:1.3;}
.sign{margin-top:8px;font-family:'Sora',sans-serif;font-weight:700;color:var(--blue-soft);}

/* ---------- VALUES (3 pillars) ---------- */
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:50px;}
.value{padding:30px 26px;}
.value .vn{font-family:'Sora';font-weight:700;font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--blue-soft);margin-bottom:14px;}
.value h3{font-size:20px;font-weight:800;margin-bottom:10px;}
.value p{font-size:14.5px;color:var(--text2);}

/* ---------- SKILLS ---------- */
.skills-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:50px;}
.skill{padding:24px 22px;}
.skill h3{font-size:16px;font-weight:800;color:var(--navy);margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--border);}
.skill ul{list-style:none;display:flex;flex-direction:column;gap:9px;}
.skill li{font-size:13px;color:var(--text2);padding-left:18px;position:relative;line-height:1.4;}
.skill li::before{content:"";position:absolute;left:0;top:8px;width:6px;height:6px;border-radius:2px;background:var(--blue-soft);}

/* ---------- PORTFOLIO ---------- */
.pf-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:50px;}
.pf-card{overflow:hidden;transition:transform .2s ease, box-shadow .2s ease;}
.pf-card:hover{transform:translateY(-5px);box-shadow:0 26px 50px rgba(15,41,74,.16);}
.pf-card.pf-static{cursor:default;}
.pf-card.pf-static:hover{transform:none;box-shadow:0 12px 34px rgba(15,41,74,.07);}
.pf-thumb{aspect-ratio:16/10;position:relative;overflow:hidden;background:var(--surf2);border-bottom:1px solid var(--border);}
.pf-thumb img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block;transition:transform .45s ease;}
.pf-card:hover .pf-thumb img{transform:scale(1.05);}
.pf-body{padding:22px 24px;}
.pf-body .cat{font-family:'Sora';font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--blue-soft);}
.pf-body h3{font-size:20px;font-weight:800;margin:8px 0 6px;}
.pf-body .url{font-size:13.5px;color:var(--dim);}
.pf-body .go{display:inline-flex;align-items:center;gap:6px;margin-top:14px;font-family:'Sora';font-weight:700;font-size:13px;color:var(--blue-soft);}

/* ---------- TESTIMONIALS ---------- */
.tgrid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:50px;}
.tcard{padding:30px;}
.tcard .mark{font-family:'Sugo Display',Georgia,serif;font-size:48px;color:#bafcf8;line-height:.5;height:24px;}
.tcard .quote{font-size:15px;color:var(--text2);line-height:1.55;}
.tcard .who{margin-top:22px;padding-top:18px;border-top:1px solid var(--border);}
.tcard .who .nm{font-family:'Sora',sans-serif;font-weight:800;font-size:15px;color:var(--navy);}
.tcard .who .rl{font-size:12.5px;color:var(--dim);}

/* ---------- CONTACT (navy) ---------- */
.contact{background:var(--navy);color:#fff;position:relative;}
.contact .eyebrow{color:var(--blue);}
.contact .eyebrow::before{background:var(--blue);}
.contact .sect-title,.contact h2,.contact h3{color:#fff;}
.contact .lead{color:rgba(255,255,255,.78);}
.cgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:44px;}
.cline{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.16);border-radius:14px;padding:22px 24px;}
.cline .lbl{font-family:'Sora',sans-serif;font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--blue);margin-bottom:8px;}
.cline .val{font-size:17px;font-weight:600;word-break:break-word;}
.cta-box{margin-top:34px;background:var(--blue);border-radius:20px;padding:40px;display:flex;
  flex-wrap:wrap;align-items:center;justify-content:space-between;gap:24px;box-shadow:0 18px 40px rgba(4,247,238,.3);}
.cta-box .ct{font-family:'Sora',sans-serif;font-weight:800;font-size:clamp(23px,3vw,29px);line-height:1.1;color:var(--navy);}
.cta-box .cs{font-size:15px;color:rgba(15,41,74,.8);margin-top:8px;max-width:46ch;}
.social-row{display:flex;flex-wrap:wrap;gap:11px;margin-top:34px;}
.social-row a{font-family:'Sora',sans-serif;font-size:12.5px;font-weight:600;letter-spacing:.03em;
  border:1px solid rgba(255,255,255,.25);border-radius:22px;padding:9px 17px;color:rgba(255,255,255,.85);transition:all .15s;}
.social-row a:hover{background:rgba(255,255,255,.1);color:#fff;border-color:var(--blue);}

/* ---------- CONTACT FORM ---------- */
.form-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:start;margin-top:10px;}
.cform{padding:34px;}
.cform .row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.field{margin-bottom:16px;}
.field label{display:block;font-family:'Sora';font-weight:700;font-size:12px;letter-spacing:.05em;
  text-transform:uppercase;color:var(--text2);margin-bottom:7px;}
.field input,.field textarea{width:100%;font-family:'Sora';font-size:15px;color:var(--navy);
  background:var(--surf2);border:1.5px solid var(--border);border-radius:12px;padding:13px 15px;transition:border-color .15s,box-shadow .15s;}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(4,247,238,.18);}
.field textarea{resize:vertical;min-height:130px;}
.cform .btn{width:100%;justify-content:center;margin-top:6px;}
.hp{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;}
.form-msg{padding:13px 16px;border-radius:12px;font-size:14px;font-weight:600;margin-bottom:18px;}
.form-msg.ok{background:#e6fbf9;border:1px solid #c2f1ed;color:var(--navy);}
.form-msg.err{background:#fee2e2;border:1px solid #fca5a5;color:#991b1b;}
.info-card{background:var(--navy);color:#fff;border-radius:20px;padding:34px;box-shadow:0 18px 44px rgba(15,41,74,.22);}
.info-card h3{color:#fff;font-size:22px;font-weight:800;margin-bottom:8px;}
.info-card p.sub{color:rgba(255,255,255,.78);font-size:15px;margin-bottom:24px;}
.info-line{display:flex;gap:14px;padding:16px 0;border-top:1px solid rgba(255,255,255,.14);align-items:center;}
.info-line:first-of-type{border-top:0;}
.info-line .ic{width:42px;height:42px;border-radius:11px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.2);
  display:flex;align-items:center;justify-content:center;font-family:'Sora';font-weight:700;color:var(--blue);flex-shrink:0;font-size:13px;}
.info-line .lbl2{font-family:'Sora';font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--blue);}
.info-line .val2{color:#fff;font-size:15.5px;font-weight:600;}

/* ---------- CTA STRIP (cornice tratteggiata centrata) ---------- */
.cta-strip{background:transparent;padding:10px 0 92px;}
.cta-frame{position:relative;border:1px dashed rgba(15,41,74,.22);border-radius:16px;padding:62px 40px;text-align:center;
  background:linear-gradient(150deg, rgba(50,245,240,0.40) 0%, rgba(10,200,238,0.42) 46%, rgba(40,140,235,0.44) 100%);
  box-shadow:0 24px 60px rgba(10,160,235,.24);}
.cta-frame .cmark{position:absolute;color:rgba(15,41,74,.3);font-size:16px;line-height:1;font-family:'Sora',sans-serif;}
.cta-frame .cmark.tl{top:-8px;left:-8px;} .cta-frame .cmark.tr{top:-8px;right:-8px;}
.cta-frame .cmark.bl{bottom:-8px;left:-8px;} .cta-frame .cmark.br{bottom:-8px;right:-8px;}
.cta-eyebrow{font-family:'Sora',sans-serif;font-weight:700;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--navy);}
.cta-strip h2{color:var(--navy);font-size:clamp(26px,5.4vw,56px);margin:14px auto 0;max-width:20ch;}
.cta-strip p{color:rgba(15,41,74,.82);font-size:16px;margin:16px auto 0;max-width:48ch;}
.cta-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:30px;}
.cta-frame .btn-primary{background:var(--navy);color:#fff;border-color:var(--navy);box-shadow:0 8px 20px rgba(15,41,74,.25);}
.cta-frame .btn-primary:hover{background:var(--navy2);border-color:var(--navy2);box-shadow:0 12px 26px rgba(15,41,74,.4);}
@media(max-width:560px){ .cta-frame{padding:44px 22px;} }

/* ---------- FOOTER (navy + outline headline) ---------- */
footer{background:var(--navy);color:rgba(255,255,255,.6);padding:64px 0 32px;}
.foot-hero{display:flex;align-items:flex-start;justify-content:space-between;gap:30px;
  padding-bottom:38px;margin-bottom:34px;border-bottom:1px solid rgba(255,255,255,.12);}
footer .big-out{font-size:clamp(34px,10vw,124px);line-height:.92;
  color:transparent;-webkit-text-stroke:1.5px rgba(255,255,255,.42);}
.foot-tag{font-size:13px;font-weight:600;color:rgba(255,255,255,.75);max-width:200px;text-align:right;}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:34px;border-bottom:1px solid rgba(255,255,255,.1);}
.footer-top .brand{margin-bottom:16px;}
.footer-top p{font-size:14px;max-width:42ch;}
.footer-col h4{color:#fff;font-size:13px;letter-spacing:.08em;text-transform:uppercase;margin-bottom:16px;}
.footer-col a{display:block;color:rgba(255,255,255,.6);font-size:14px;padding:5px 0;transition:color .15s;}
.footer-col a:hover{color:var(--blue);}
.foot{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:14px;margin-top:30px;
  font-family:'Sora',sans-serif;font-size:12px;letter-spacing:.04em;}
.foot b{color:#fff;font-weight:700;}

::-webkit-scrollbar{width:9px;height:9px;}
::-webkit-scrollbar-track{background:var(--bg);}
::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:5px;}
::-webkit-scrollbar-thumb:hover{background:var(--blue);}

/* ====== ICONE CARD ====== */
.card-ic{width:44px;height:44px;border-radius:12px;background:#e6fbf9;border:1px solid #c2f1ed;
  display:flex;align-items:center;justify-content:center;margin-bottom:18px;}
.card-ic svg{width:20px;height:20px;stroke:var(--navy);stroke-width:1.7;fill:none;stroke-linecap:round;stroke-linejoin:round;}

/* ====== HERO VISUAL (home) ====== */
.hero-inner.has-visual{display:grid;grid-template-columns:1.1fr .9fr;gap:50px;align-items:center;}
.hero-visual{position:relative;}
.hv-panel{background:#fff;border:1px solid var(--border);border-radius:20px;box-shadow:0 22px 54px rgba(15,41,74,.12);padding:22px;position:relative;overflow:hidden;}
.hv-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}
.hv-top .t{font-family:'Sora';font-weight:700;font-size:13.5px;color:var(--navy);}
.hv-badge{font-family:'Sora';font-size:10.5px;font-weight:700;letter-spacing:.04em;color:var(--navy);background:#e6fbf9;border:1px solid #c2f1ed;border-radius:20px;padding:5px 11px;}
.hv-chart svg{width:100%;height:auto;display:block;}
.hv-grid line{stroke:#eef2f8;}
.hv-line{fill:none;stroke:var(--blue);stroke-width:3;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:430;}
.hv-dot{fill:#fff;stroke:var(--navy);stroke-width:2.5;}
.hv-foot{display:flex;gap:9px;margin-top:14px;}
.hv-stat{flex:1;background:var(--surf2);border:1px solid var(--border);border-radius:12px;padding:11px 12px;}
.hv-stat .k{font-family:'Sora';font-weight:800;font-size:15px;color:var(--navy);}
.hv-stat .l{font-size:9.5px;letter-spacing:.04em;text-transform:uppercase;color:var(--dim);font-weight:600;margin-top:2px;}
.hero-visual.in .hv-line{animation:gdraw2 2s .25s ease both;}
.hero-visual.in .hv-area{animation:fadein 1.5s .6s ease both;}
.hero-visual.in .hv-dot{opacity:0;animation:pop .7s both;}
.hero-visual.in .hv-dot:nth-of-type(1){animation-delay:.55s}
.hero-visual.in .hv-dot:nth-of-type(2){animation-delay:.7s}
.hero-visual.in .hv-dot:nth-of-type(3){animation-delay:.85s}
.hero-visual.in .hv-dot:nth-of-type(4){animation-delay:1s}
@keyframes gdraw2{from{stroke-dashoffset:430}to{stroke-dashoffset:0}}
@keyframes fadein{from{opacity:0}to{opacity:1}}

/* ====== METODO (step diagram) ====== */
.method{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:54px;}
.m-line{position:absolute;top:28px;left:12%;right:12%;height:2px;background:var(--border);z-index:0;border-radius:2px;overflow:hidden;}
.m-fill{position:absolute;inset:0;background:var(--blue);transform-origin:left;transform:scaleX(1);}
.mstep{position:relative;z-index:1;text-align:center;padding:0 4px;}
.m-node{width:58px;height:58px;border-radius:17px;background:#fff;border:1px solid var(--border);box-shadow:0 10px 24px rgba(15,41,74,.1);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;transform-origin:center;}
.m-node svg{width:25px;height:25px;stroke:var(--navy);stroke-width:1.7;fill:none;stroke-linecap:round;stroke-linejoin:round;}
.mstep .m-k{font-family:'Sora';font-weight:700;font-size:11px;letter-spacing:.12em;color:var(--blue-soft);margin-bottom:6px;}
.mstep h3{font-size:19px;font-weight:800;margin-bottom:8px;}
.mstep p{font-size:14px;color:var(--text2);max-width:24ch;margin:0 auto;}
.method.in .m-fill{animation:mgrow 1.8s .15s ease both;}
.method.in .m-node{animation:pop .75s both;}
.method.in .mstep:nth-child(2) .m-node{animation-delay:.1s}
.method.in .mstep:nth-child(3) .m-node{animation-delay:.28s}
.method.in .mstep:nth-child(4) .m-node{animation-delay:.46s}
.method.in .mstep:nth-child(5) .m-node{animation-delay:.64s}
@keyframes mgrow{from{transform:scaleX(0)}to{transform:scaleX(1)}}

@media (prefers-reduced-motion: reduce){
  .hero-visual *,.method *{animation:none!important;}
  .hv-line{stroke-dashoffset:0!important;}
  .hv-dot{opacity:1!important;transform:none!important;}
  .m-fill{transform:scaleX(1)!important;}
  .m-node{opacity:1!important;transform:none!important;}
}
@media(max-width:900px){
  .hero-inner.has-visual{grid-template-columns:1fr;gap:38px;}
  .method{grid-template-columns:1fr 1fr;}
  .m-line{display:none;}
}
@media(max-width:560px){ .method{grid-template-columns:1fr;} }

/* ====== ILLUSTRAZIONE PROGETTO (home) ====== */
.proj-illo{max-width:840px;margin:50px auto 0;position:relative;}
.proj-illo svg{width:100%;height:auto;display:block;overflow:visible;}
.proj-illo text{font-family:'Sora',sans-serif;}
.pi-win{transform-box:fill-box;transform-origin:center;}
.pi-bar{transform-box:fill-box;transform-origin:left center;}
.pi-node{transform-box:fill-box;transform-origin:center;}
.pi-conn{stroke:#9db4d8;stroke-width:2;stroke-linecap:round;stroke-dasharray:120;}
.pi-chart{fill:none;stroke:var(--blue);stroke-width:3;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:230;}
.pi-spark{transform-origin:center;animation:sparkle 3.2s ease-in-out infinite;}
.proj-illo.in .pi-win{animation:rise .8s cubic-bezier(.4,0,.2,1) both;}
.proj-illo.in .pi-bar{animation-name:barx;animation-duration:.6s;animation-timing-function:cubic-bezier(.4,0,.2,1);animation-fill-mode:both;}
.proj-illo.in .pi-node{animation-name:pop;animation-duration:.55s;animation-fill-mode:both;}
.proj-illo.in .pi-conn{animation-name:drawS;animation-duration:.9s;animation-timing-function:ease;animation-fill-mode:both;}
.proj-illo.in .pi-chart{animation-name:drawL;animation-duration:1.2s;animation-delay:.5s;animation-timing-function:ease;animation-fill-mode:both;}
@keyframes rise{from{opacity:0;transform:translateY(14px) scale(.985)}to{opacity:1;transform:none}}
@keyframes barx{from{transform:scaleX(0)}to{transform:scaleX(1)}}
@keyframes drawS{from{stroke-dashoffset:120}to{stroke-dashoffset:0}}
@keyframes drawL{from{stroke-dashoffset:230}to{stroke-dashoffset:0}}
@keyframes sparkle{0%,100%{opacity:.2}50%{opacity:.9}}
@media (prefers-reduced-motion: reduce){
  .proj-illo *{animation:none!important;opacity:1!important;transform:none!important;stroke-dashoffset:0!important;}
}
@media(max-width:560px){ .proj-illo{margin-top:36px;} }

/* — versione mobile dell'illustrazione progetto — */
.pi-mobile{display:none;max-width:360px;margin:0 auto;}
.pm-browser{background:#fff;border:1px solid var(--border);border-radius:16px;box-shadow:0 16px 40px rgba(15,41,74,.1);overflow:hidden;}
.pm-bar{display:flex;align-items:center;gap:6px;padding:11px 14px;border-bottom:1px solid var(--border);}
.pm-bar i{width:9px;height:9px;border-radius:50%;display:inline-block;}
.pm-bar .pm-url{flex:1;height:13px;border-radius:7px;background:var(--surf2);margin-left:6px;}
.pm-body{padding:16px;}
.pm-hero{background:#d9fbf9;border-radius:10px;padding:14px;}
.pm-hero .pm-bar-l{display:block;height:9px;border-radius:5px;background:#fff;margin-bottom:8px;}
.pm-hero .pm-btn{display:block;width:56px;height:13px;border-radius:7px;background:var(--blue);margin-top:12px;}
.pm-chart{margin-top:14px;height:86px;}
.pm-chart svg{width:100%;height:100%;display:block;}
.pm-chart .g{stroke:#eef2f8;}
.pm-chart .ln{fill:none;stroke:var(--blue);stroke-width:3;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:300;}
.pm-chart .dt{fill:#fff;stroke:var(--navy);stroke-width:2.5;}
.pm-nodes{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:16px;}
.pm-node{display:flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--border);border-radius:12px;padding:11px 12px;box-shadow:0 4px 14px rgba(15,41,74,.05);transform-origin:center;}
.pm-node .ic{width:30px;height:30px;border-radius:9px;background:#e6fbf9;border:1px solid #c2f1ed;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.pm-node .ic svg{width:16px;height:16px;stroke:var(--navy);stroke-width:1.7;fill:none;stroke-linecap:round;stroke-linejoin:round;}
.pm-node span{font-family:'Sora',sans-serif;font-weight:700;font-size:13px;color:var(--navy);}
.proj-illo.in .pm-browser{animation:rise .7s cubic-bezier(.4,0,.2,1) both;}
.proj-illo.in .pm-chart .ln{animation:drawP 1.1s .35s ease both;}
.proj-illo.in .pm-node{animation-name:pop;animation-duration:.5s;animation-fill-mode:both;}
.proj-illo.in .pm-node:nth-child(1){animation-delay:.2s}
.proj-illo.in .pm-node:nth-child(2){animation-delay:.32s}
.proj-illo.in .pm-node:nth-child(3){animation-delay:.44s}
.proj-illo.in .pm-node:nth-child(4){animation-delay:.56s}
@keyframes drawP{from{stroke-dashoffset:300}to{stroke-dashoffset:0}}
@media(max-width:600px){
  .proj-illo > svg{display:none;}
  .pi-mobile{display:block;}
}

/* ====== PAGINE LEGALI ====== */
.legal{max-width:780px;}
.legal h2{font-family:'Sora',sans-serif;font-weight:800;font-size:clamp(20px,2.6vw,26px);letter-spacing:-.01em;margin:38px 0 12px;color:var(--navy);}
.legal h2:first-child{margin-top:0;}
.legal h3{font-family:'Sora',sans-serif;font-weight:700;font-size:17px;margin:22px 0 8px;color:var(--navy);}
.legal p,.legal li{font-size:15.5px;color:var(--text2);line-height:1.75;}
.legal p{margin-bottom:12px;}
.legal ul{margin:8px 0 14px 22px;}
.legal li{margin-bottom:6px;}
.legal a{color:var(--blue-soft);text-decoration:underline;}
.legal .muted{color:var(--dim);font-size:13.5px;margin-top:30px;}

/* ====== FOOTER LEGAL LINKS ====== */
.foot-legal a{color:rgba(255,255,255,.6);}
.foot-legal a:hover{color:var(--blue);}

/* ====== COOKIE BANNER ====== */
.cookie-banner{position:fixed;left:16px;right:16px;bottom:16px;z-index:100;max-width:720px;margin:0 auto;
  background:linear-gradient(150deg,#173a63,#0f294a 62%);color:#fff;
  border:1px dashed rgba(255,255,255,.28);border-radius:16px;box-shadow:0 20px 50px rgba(15,41,74,.45);
  padding:20px 24px;transition:transform .3s ease,opacity .3s ease;}
.cookie-banner .cmark{position:absolute;color:rgba(255,255,255,.5);font-size:16px;line-height:1;font-family:'Sora',sans-serif;}
.cookie-banner .cmark.tl{top:-8px;left:-8px;} .cookie-banner .cmark.tr{top:-8px;right:-8px;}
.cookie-banner .cmark.bl{bottom:-8px;left:-8px;} .cookie-banner .cmark.br{bottom:-8px;right:-8px;}
.cookie-banner.cb-hide{transform:translateY(24px);opacity:0;}
.cb-inner{display:flex;align-items:center;gap:18px;flex-wrap:wrap;justify-content:space-between;width:100%;}
.cb-inner p{font-size:13px;color:rgba(255,255,255,.85);line-height:1.55;flex:1;min-width:240px;margin:0;}
.cb-inner a{color:var(--blue);text-decoration:underline;}
.cb-actions{flex-shrink:0;display:flex;gap:10px;}
.cb-actions .btn{padding:11px 22px;font-size:13.5px;}
.cb-actions .btn-ghost{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.28);}
.cb-actions .btn-ghost:hover{background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.5);color:#fff;}
@media(max-width:560px){ .cb-actions{width:100%;} .cb-actions .btn{flex:1;justify-content:center;} }

/* ---------- RESPONSIVE ---------- */
@media(max-width:900px){
  .svc-grid,.skills-grid,.pf-grid,.values{grid-template-columns:1fr 1fr;}
  .about-grid,.svc-detail,.form-grid{grid-template-columns:1fr;gap:34px;}
  .about-grid .photo{max-width:340px;}
  .footer-top{grid-template-columns:1fr 1fr;}
}
@media(max-width:760px){
  .nav-links{position:fixed;inset:90px 16px auto 16px;background:var(--navy);flex-direction:column;
    align-items:stretch;gap:0;padding:10px 20px 18px;border-radius:18px;box-shadow:0 20px 50px rgba(15,41,74,.4);
    transform:translateY(-130%);opacity:0;pointer-events:none;transition:transform .28s ease, opacity .2s ease;}
  .nav-links.open{transform:translateY(0);opacity:1;pointer-events:auto;}
  .nav-links a{width:100%;padding:14px 0;border-bottom:1px solid rgba(255,255,255,.08);}
  .nav-links .btn{margin-top:12px;width:100%;justify-content:center;}
  .burger{display:flex;}
  .svc-grid,.skills-grid,.tgrid,.cgrid,.pf-grid,.values,.cform .row,.footer-top{grid-template-columns:1fr;}
  .foot-hero{flex-direction:column;}.foot-tag{text-align:left;}
  .hero-stats{gap:30px;}
  .hero-inner.has-visual{display:block;}
  .hero-visual{margin-top:34px;}
  .hv-foot{flex-wrap:wrap;}
  .hv-stat{min-width:calc(33% - 6px);}
  section.block{padding:62px 0;}
}
