:root{
  --bone:#FBFBFA;
  --surface:#FFFFFF;
  --ink:#2F3437;
  --ink-soft:#787774;
  --border:#EAEAEA;
  --pastel-blue-bg:#E1F3FE; --pastel-blue-fg:#1F6C9F;
  --pastel-green-bg:#EDF3EC; --pastel-green-fg:#346538;
  --pastel-red-bg:#FDEBEC; --pastel-red-fg:#9F2F2D;
  --pastel-yellow-bg:#FBF3DB; --pastel-yellow-fg:#956400;
  --serif:'Newsreader',serif;
  --sans:'Inter',-apple-system,sans-serif;
  --ease:cubic-bezier(.16,1,.3,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bone);
  color:var(--ink);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul{list-style:none}

.wrap{max-width:1040px;margin:0 auto;padding:0 24px}

/* nav */
.nav{
  position:sticky; top:0; z-index:50;
  background:rgba(251,251,250,.85);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--border);
}
.nav-inner{
  max-width:1040px; margin:0 auto; padding:16px 24px;
  display:flex; align-items:center; justify-content:space-between;
}
.logo{font-family:var(--serif); font-size:21px; letter-spacing:-.02em}
.nav-links{display:flex; gap:28px; font-size:14px; color:var(--ink-soft)}
.nav-links a:hover{color:var(--ink)}

.btn-dark{
  background:#111; color:#fff; font-size:13.5px; font-weight:500;
  padding:10px 20px; border-radius:6px;
  transition:background .2s, transform .15s;
  display:inline-block;
}
.btn-dark:hover{background:#333}
.btn-dark:active{transform:scale(.98)}
.btn-ghost{
  font-size:13.5px; font-weight:500; padding:10px 18px; border-radius:6px;
  border:1px solid var(--border); display:inline-block;
  transition:border-color .2s, background .2s;
}
.btn-ghost:hover{border-color:#cfcfcc; background:#fff}

/* hero */
.hero{position:relative; padding:72px 0 84px; overflow:hidden}
.hero-glow{
  position:absolute; inset:-20% -10% auto -10%; height:560px;
  background:radial-gradient(circle at 30% 30%, rgba(31,108,159,.05), transparent 60%),
             radial-gradient(circle at 75% 50%, rgba(149,100,0,.04), transparent 55%);
  pointer-events:none;
}
.hero-grid{
  display:grid; grid-template-columns:minmax(0,1.15fr) minmax(0,.85fr);
  gap:clamp(32px,5vw,72px); align-items:center;
}
.hero-copy{position:relative; z-index:1; align-self:center}
.tag{
  display:inline-block; font-size:11.5px; font-weight:600; letter-spacing:.05em;
  text-transform:uppercase; padding:6px 14px; border-radius:9999px; margin-bottom:24px;
}
.tag-yellow{background:var(--pastel-yellow-bg); color:var(--pastel-yellow-fg)}
.hero h1{
  font-family:var(--serif); font-weight:500; font-size:clamp(38px,5.4vw,58px); line-height:1.06;
  letter-spacing:-.032em; max-width:680px; position:relative;
}
.hero-sub{
  margin-top:22px; max-width:460px; color:var(--ink-soft); font-size:16.5px;
  position:relative;
}
.hero-cta{margin-top:32px; display:flex; gap:12px; flex-wrap:wrap; position:relative}
.btn-arrow{display:inline-block; transition:transform .3s var(--ease)}
.btn-ghost:hover .btn-arrow{transform:translateX(3px)}

/* hero card — editorial signature, not a placeholder */
.hero-card{
  position:relative; z-index:1;
  background:linear-gradient(180deg, rgba(255,255,255,.94), rgba(255,255,255,.80));
  -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px);
  border:1px solid var(--border); border-radius:20px;
  padding:30px 30px 26px; display:flex; flex-direction:column; gap:22px;
  box-shadow:0 1px 2px rgba(47,52,55,.04), 0 24px 48px -28px rgba(47,52,55,.22);
}
.hero-card-top{display:flex; align-items:center; justify-content:space-between}
.hero-card-monogram{
  width:44px; height:44px; border-radius:12px; display:grid; place-items:center;
  background:var(--ink); color:#fff; font-family:var(--serif); font-size:23px; line-height:1;
}
.hero-card-open{
  display:inline-flex; align-items:center; gap:7px; font-size:12px; font-weight:600;
  color:var(--pastel-green-fg); background:var(--pastel-green-bg);
  padding:6px 12px; border-radius:9999px; letter-spacing:.01em;
}
.hero-card-open .dot{width:7px; height:7px; border-radius:50%; background:var(--pastel-green-fg); position:relative}
.hero-card-open .dot::after{
  content:''; position:absolute; inset:-4px; border-radius:50%;
  border:1px solid var(--pastel-green-fg); opacity:.5; animation:pulseRing 2.4s var(--ease) infinite;
}
@keyframes pulseRing{0%{transform:scale(.6);opacity:.6}70%,100%{transform:scale(1.9);opacity:0}}
.hero-card-quote{
  font-family:var(--serif); font-size:20px; line-height:1.42; letter-spacing:-.01em; color:var(--ink);
}
.hero-card-sign{display:flex; flex-direction:column; gap:2px}
.hero-card-name{font-weight:600; font-size:14.5px}
.hero-card-role{font-size:12.5px; color:var(--ink-soft)}
.hero-card-meta{
  display:grid; grid-template-columns:repeat(3,1fr); gap:14px;
  padding-top:20px; border-top:1px solid var(--border);
}
.hero-card-meta div{display:flex; flex-direction:column; gap:3px}
.hero-card-meta .k{font-size:11px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-soft)}
.hero-card-meta .v{font-family:var(--serif); font-size:16px}
@media(prefers-reduced-motion:reduce){.hero-card-open .dot::after{animation:none}}

/* strip */
.strip{border-top:1px solid var(--border); border-bottom:1px solid var(--border); background:var(--surface)}
.strip-grid{display:grid; grid-template-columns:repeat(3,1fr); padding:44px 24px}
.strip-item{display:flex; flex-direction:column; gap:6px; text-align:center; position:relative}
.strip-item + .strip-item::before{
  content:''; position:absolute; left:0; top:50%; transform:translateY(-50%);
  height:44px; width:1px; background:var(--border);
}
.strip-item .num{font-family:var(--serif); font-size:38px; font-weight:500; letter-spacing:-.025em; line-height:1}
.strip-item .label{font-size:13px; color:var(--ink-soft)}

/* sections */
.section{padding:88px 0}
.section-alt{background:var(--surface); border-top:1px solid var(--border); border-bottom:1px solid var(--border)}
.eyebrow{font-size:12px; font-weight:600; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-soft)}
.section h2{
  font-family:var(--serif); font-weight:500; font-size:clamp(29px,3.6vw,40px); letter-spacing:-.022em;
  line-height:1.1; margin-top:10px; margin-bottom:44px;
}

/* chi siamo */
.chi-grid{display:grid; grid-template-columns:1.2fr .8fr; gap:48px; align-items:start}
.chi-text h2{margin-bottom:18px}
.chi-text p{color:var(--ink-soft); margin-bottom:14px; max-width:480px}
.chi-cards{display:flex; flex-direction:column; gap:16px}
.mini-card{
  background:var(--surface); border:1px solid var(--border); border-radius:12px; padding:24px;
}
.mini-icon{width:38px; height:38px; border-radius:8px; display:flex; align-items:center; justify-content:center; margin-bottom:14px}
.mini-icon svg{width:18px; height:18px}
.mini-card h3{font-size:15px; font-weight:600; margin-bottom:4px}
.mini-card p{font-size:13.5px; color:var(--ink-soft)}

/* bento — asymmetric, editorial */
.bento{display:grid; grid-template-columns:repeat(6,1fr); gap:16px}
.card{
  position:relative; background:var(--bone); border:1px solid var(--border); border-radius:16px;
  padding:26px 24px; display:flex; flex-direction:column;
  grid-column:span 3;
  transition:box-shadow .35s var(--ease), border-color .35s var(--ease), transform .3s var(--ease);
  overflow:hidden; isolation:isolate;
}
.card::after{
  content:''; position:absolute; inset:0; z-index:-1; opacity:0;
  background:radial-gradient(120% 90% at 100% 0%, rgba(31,108,159,.05), transparent 60%);
  transition:opacity .4s var(--ease);
}
.card:hover{box-shadow:0 1px 2px rgba(47,52,55,.04), 0 18px 40px -24px rgba(47,52,55,.28); border-color:#dfe2df; transform:translateY(-3px)}
.card:hover::after{opacity:1}
.card:nth-child(1){grid-column:span 4}
.card:nth-child(2){grid-column:span 2}
.card:nth-child(3){grid-column:span 2}
.card:nth-child(4){grid-column:span 4}
.card-icon{width:44px; height:44px; border-radius:11px; display:flex; align-items:center; justify-content:center; margin-bottom:18px; transition:transform .35s var(--ease)}
.card:hover .card-icon{transform:scale(1.06) rotate(-3deg)}
.card-icon svg{width:21px; height:21px}
.card h3{font-size:17px; font-weight:600; margin-bottom:8px; letter-spacing:-.01em}
.card p{font-size:13.5px; color:var(--ink-soft); margin-bottom:18px; max-width:38ch}
.card .price{
  margin-top:auto; align-self:flex-start; font-size:12.5px; font-weight:600; color:var(--ink);
  background:var(--surface); border:1px solid var(--border); padding:5px 12px; border-radius:9999px;
}

.pastel-blue{background:var(--pastel-blue-bg); color:var(--pastel-blue-fg)}
.pastel-green{background:var(--pastel-green-bg); color:var(--pastel-green-fg)}
.pastel-red{background:var(--pastel-red-bg); color:var(--pastel-red-fg)}
.pastel-yellow{background:var(--pastel-yellow-bg); color:var(--pastel-yellow-fg)}

/* dove */
.dove-grid{display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center}
.info-list{display:flex; flex-direction:column; gap:18px; margin-top:8px}
.info-list li{display:flex; flex-direction:column; gap:2px; border-bottom:1px solid var(--border); padding-bottom:14px}
.info-list strong{font-size:13px; color:var(--ink-soft); font-weight:600}
.info-list span{font-size:15.5px}
.map-card{
  position:relative; display:block; border:1px solid var(--border); border-radius:16px;
  overflow:hidden; height:280px; background:#EEF2F0;
  box-shadow:0 1px 2px rgba(47,52,55,.04);
  transition:box-shadow .35s var(--ease), transform .35s var(--ease);
}
.map-card:hover{box-shadow:0 20px 44px -26px rgba(47,52,55,.32); transform:translateY(-2px)}
.map-art{position:absolute; inset:0; width:100%; height:100%; display:block}
.map-pin{
  position:absolute; top:42%; left:50%; transform:translate(-50%,-100%);
  width:40px; height:40px; border-radius:50% 50% 50% 0; rotate:-45deg;
  background:var(--ink); color:#fff; display:grid; place-items:center;
  box-shadow:0 8px 18px -6px rgba(47,52,55,.5);
}
.map-pin svg{width:18px; height:18px; rotate:45deg}
.map-pin::after{
  content:''; position:absolute; left:50%; top:100%; transform:translate(-50%,4px) rotate(45deg);
  width:12px; height:6px; background:rgba(47,52,55,.18); border-radius:50%; filter:blur(2px);
}
.map-chip{
  position:absolute; left:16px; right:16px; bottom:16px;
  background:rgba(255,255,255,.92); -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px);
  border:1px solid var(--border); border-radius:12px; padding:14px 16px;
  display:flex; flex-direction:column; gap:2px; font-size:13px; color:var(--ink-soft);
}
.map-chip strong{font-size:14.5px; color:var(--ink); font-weight:600}
.map-dir{margin-top:6px; font-size:12.5px; font-weight:600; color:var(--pastel-blue-fg); transition:transform .3s var(--ease)}
.map-card:hover .map-dir{transform:translateX(3px)}

/* cta */
.section-cta{padding-top:40px}
.cta-box{
  background:var(--surface); border:1px solid var(--border); border-radius:16px;
  padding:56px 40px; text-align:center;
}
.cta-box .eyebrow{display:block}
.cta-box h2{margin-bottom:8px}
.cta-box p{color:var(--ink-soft); margin-bottom:28px}
.cta-box .hero-cta{justify-content:center}

/* footer */
.footer{border-top:1px solid var(--border); padding:28px 0; margin-top:0}
.footer-inner{display:flex; justify-content:space-between; flex-wrap:wrap; gap:8px; font-size:13px; color:var(--ink-soft)}
.footer-credit a{color:var(--ink); border-bottom:1px solid var(--border)}
.footer-credit a:hover{border-color:var(--ink)}

/* reveal */
.reveal{opacity:0; transform:translateY(12px); transition:opacity .6s var(--ease), transform .6s var(--ease)}
.reveal.in{opacity:1; transform:translateY(0)}

@media(max-width:860px){
  .hero-grid{grid-template-columns:1fr; gap:40px}
  .hero-card{max-width:460px}
  .chi-grid, .dove-grid{grid-template-columns:1fr; gap:32px}
  .bento{grid-template-columns:repeat(2,1fr)}
  .card, .card:nth-child(1), .card:nth-child(2), .card:nth-child(3), .card:nth-child(4){grid-column:span 1}
  .strip-grid{grid-template-columns:1fr; gap:0}
  .strip-item{padding:18px 0}
  .strip-item + .strip-item::before{left:0; right:0; top:0; bottom:auto; width:auto; height:1px; transform:none}
}
@media(max-width:560px){
  .nav-links{display:none}
  .bento{grid-template-columns:1fr}
  .hero{padding:56px 0 56px}
  .section{padding:64px 0}
  .cta-box{padding:40px 24px}
  .hero-card{padding:24px}
  .hero-card-quote{font-size:18px}
}

/* entrance */
.entrance{
  position:fixed; inset:0; z-index:300; background:var(--bone);
  pointer-events:none;
  animation:entranceFade .9s var(--ease) forwards;
}
@keyframes entranceFade{
  0%, 45%{ opacity:1 }
  100%{ opacity:0 }
}
@media(prefers-reduced-motion:reduce){
  .entrance{ display:none }
}

/* accessibilità */
.skip-link{
  position:fixed; top:-100%; left:50%; transform:translateX(-50%); z-index:500;
  padding:10px 22px; background:var(--ink); color:var(--bone);
  font-size:13px; font-weight:600; letter-spacing:.03em;
  border-radius:0 0 10px 10px; transition:top .25s var(--ease);
}
.skip-link:focus{ top:0 }
a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible{
  outline:2px solid var(--pastel-blue-fg); outline-offset:2px; border-radius:4px;
}
h1, h2, h3{ text-wrap:balance }

/* burger + mobile menu */
.burger{display:none; width:38px; height:38px; border-radius:50%; background:rgba(0,0,0,.04); position:relative; align-items:center; justify-content:center}
.burger span{position:absolute; width:16px; height:1.5px; background:var(--ink); transition:transform .28s var(--ease)}
.burger span:nth-child(1){transform:translateY(-4px)}
.burger span:nth-child(2){transform:translateY(4px)}
.burger.open span:nth-child(1){transform:translateY(0) rotate(45deg)}
.burger.open span:nth-child(2){transform:translateY(0) rotate(-45deg)}
.mobile-menu{
  position:fixed; inset:0; z-index:400; background:rgba(251,251,250,.98); backdrop-filter:blur(10px);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:26px;
  opacity:0; pointer-events:none; transition:opacity .3s var(--ease);
}
.mobile-menu.open{ opacity:1; pointer-events:auto }
.mobile-menu a{
  font-family:var(--serif); font-size:26px; color:var(--ink);
  opacity:0; transform:translateY(14px); transition:opacity .4s var(--ease), transform .4s var(--ease);
}
.mobile-menu.open a{ opacity:1; transform:translateY(0) }
.mobile-menu.open a:nth-child(1){transition-delay:.06s}
.mobile-menu.open a:nth-child(2){transition-delay:.11s}
.mobile-menu.open a:nth-child(3){transition-delay:.16s}
.mobile-menu.open a:nth-child(4){transition-delay:.21s}
@media(max-width:560px){
  .burger{display:flex}
}


/* ── JS spring motion (progressive enhancement) ── */
.reveal{ opacity:1; transform:none; filter:none; transition:none; }
.mm-on .reveal{ opacity:0; will-change:transform,opacity; }
@media (prefers-reduced-motion: reduce){
  .mm-on .reveal{ opacity:1 !important; transform:none !important; filter:none !important; }
}


/* -- Capsula flottante "Torna a NZ Agency" -- */
.nz-return{
  position:fixed; z-index:45;
  left:max(16px, env(safe-area-inset-left));
  bottom:max(16px, env(safe-area-inset-bottom));
  display:inline-flex; align-items:center; gap:0;
  padding:7px; border-radius:9999px; white-space:nowrap;
  text-decoration:none; font-size:13px; font-weight:600; letter-spacing:.01em;
  background:rgba(255,255,255,.82); -webkit-backdrop-filter:blur(14px); backdrop-filter:blur(14px);
  border:1px solid var(--border); color:var(--ink);
  box-shadow:0 10px 30px rgba(0,0,0,.16);
  transition:gap .35s cubic-bezier(.16,1,.3,1), padding .35s cubic-bezier(.16,1,.3,1), transform .25s, box-shadow .25s;
}
.nz-return-ic{ width:32px; height:32px; flex-shrink:0; border-radius:50%; background:#111; color:#fff; display:grid; place-items:center; transition:transform .3s; }
.nz-return-ic svg{ width:15px; height:15px; }
.nz-return-tx{ max-width:0; opacity:0; overflow:hidden; transition:max-width .35s cubic-bezier(.16,1,.3,1), opacity .25s; }
.nz-return-tx strong{ font-weight:700; }
.nz-return:hover, .nz-return:focus-visible{ gap:10px; padding-right:18px; transform:translateY(-3px); box-shadow:0 16px 40px rgba(0,0,0,.24); }
.nz-return:hover .nz-return-ic, .nz-return:focus-visible .nz-return-ic{ transform:translateX(-2px); }
.nz-return:hover .nz-return-tx, .nz-return:focus-visible .nz-return-tx{ max-width:200px; opacity:1; }
@media(prefers-reduced-motion:reduce){ .nz-return, .nz-return-tx, .nz-return-ic{ transition:none } }
.nz-return.nz-intro{ gap:10px; padding-right:18px; }
.nz-return.nz-intro .nz-return-tx{ max-width:200px; opacity:1; }
/* capsula sempre espansa: capibile subito all'ingresso */
.nz-return{ gap:10px; padding-right:18px; }
.nz-return .nz-return-tx{ max-width:200px; opacity:1; }

/* ── ambient shader hero ── */
.ambient-canvas{ position:absolute; inset:0; z-index:0; width:100%; height:100%; pointer-events:none; }
.hero{ position:relative; }
.hero > .wrap{ position:relative; z-index:1; }
/* glow stays absolute (out of flow) so it never pushes the hero content down */
.hero > .hero-glow{ position:absolute; z-index:0; }

/* ── Il percorso (steps) ── */
.steps-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.step-card{ background:var(--surface); border:1px solid var(--border); border-radius:12px; padding:28px 24px; }
.step-n{ font-family:var(--serif); font-size:26px; color:var(--pastel-blue-fg); display:block; margin-bottom:14px; }
.step-card h3{ font-size:15.5px; font-weight:600; margin-bottom:8px; }
.step-card p{ font-size:13.5px; color:var(--ink-soft); }

/* ── Listino ── */
.price-cols{ display:grid; grid-template-columns:repeat(3,1fr); gap:48px; }
.price-cat{ font-family:var(--serif); font-size:21px; font-weight:500; margin-bottom:18px; }
.price-list{ display:flex; flex-direction:column; gap:14px; }
.price-list li{ display:flex; justify-content:space-between; gap:12px; border-bottom:1px solid var(--border); padding-bottom:12px; font-size:14.5px; }
.price-list .price{ color:var(--ink); font-weight:600; flex-shrink:0; }
.price-note{ margin-top:36px; font-size:13.5px; color:var(--ink-soft); max-width:560px; }

/* ── Recensioni ── */
.reviews-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.review-card{ background:var(--surface); border:1px solid var(--border); border-radius:12px; padding:28px 26px; margin:0; }
.review-card .stars{ color:#E0A93B; letter-spacing:2px; font-size:14px; margin-bottom:14px; }
.review-card blockquote{ font-family:var(--serif); font-size:18px; line-height:1.5; margin:0 0 16px; }
.review-card figcaption{ font-size:13px; color:var(--ink-soft); font-weight:600; }

/* ── FAQ ── */
.faq-wrap{ display:grid; grid-template-columns:.8fr 1.2fr; gap:56px; align-items:start; }
.faq-intro h2{ margin-bottom:14px; }
.faq-intro p{ color:var(--ink-soft); font-size:14.5px; max-width:300px; }
.faq-list{ display:flex; flex-direction:column; }
.faq-item{ border-bottom:1px solid var(--border); }
.faq-item summary{ list-style:none; cursor:pointer; padding:20px 0; font-size:16px; font-weight:600; display:flex; justify-content:space-between; align-items:center; gap:16px; }
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary::after{ content:'+'; font-size:22px; font-weight:400; color:var(--ink-soft); transition:transform .25s; }
.faq-item[open] summary::after{ transform:rotate(45deg); }
.faq-item p{ padding:0 0 22px; color:var(--ink-soft); font-size:14.5px; max-width:560px; margin:0; }

@media(max-width:860px){
  .steps-grid{ grid-template-columns:1fr 1fr; }
  .price-cols{ grid-template-columns:1fr; gap:32px; }
  .reviews-grid{ grid-template-columns:1fr; }
  .faq-wrap{ grid-template-columns:1fr; gap:28px; }
}
@media(max-width:560px){ .steps-grid{ grid-template-columns:1fr; } }
