/* ============================================================
   :root — DESIGN TOKEN DEL CLIENTE
   In clonazione: incolla qui il blocco del preset di categoria,
   poi ritocca --brand/--accent sul logo del cliente.
   ============================================================ */
:root{
  --brand:        #0b5cad;
  --accent:       #ff7a00;
  --font-heading: "Inter", system-ui, sans-serif;
  --font-body:    "Inter", system-ui, sans-serif;
  --radius:       4px;
  --hero-mode:    foto;
  --sticky-bar:   on;

  /* derivati / costanti */
  --ink:    #1a1a1a;
  --muted:  #5b5b5b;
  --bg:     #ffffff;
  --soft:   #f3f5f8;
  --line:   #e4e7ec;
  --maxw:   1080px;
  --shadow: 0 10px 24px rgba(0,0,0,.10);
  --shadow-strong: 0 16px 36px rgba(0,0,0,.16);
  --surface: #f7f9fc;
}

/* ---- Font self-hosted ---- */
@font-face{font-family:"Inter";src:url("assets/fonts/inter-400.woff2") format("woff2");font-weight:400;font-display:swap}
@font-face{font-family:"Inter";src:url("assets/fonts/inter-600.woff2") format("woff2");font-weight:600;font-display:swap}
@font-face{font-family:"Inter";src:url("assets/fonts/inter-700.woff2") format("woff2");font-weight:700;font-display:swap}
@font-face{font-family:"Fraunces";src:url("assets/fonts/fraunces-600.woff2") format("woff2");font-weight:600;font-display:swap}
@font-face{font-family:"Oswald";src:url("assets/fonts/oswald-600.woff2") format("woff2");font-weight:600;font-display:swap}

/* ---- Reset minimale ---- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font-body);color:var(--ink);background:var(--bg);line-height:1.55;-webkit-text-size-adjust:100%}
img{max-width:100%;height:auto;display:block}
a{color:var(--brand)}
h1,h2,h3{font-family:var(--font-heading);line-height:1.15;margin:0 0 .4em}
h1{font-size:clamp(1.7rem,5vw,2.6rem)}
h2{font-size:clamp(1.4rem,3.5vw,2rem)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}
.section{padding:48px 0}
.section.alt{background:var(--soft)}
.label{font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--brand);font-weight:700}

/* ---- Bottoni / CTA ---- */
.btn{display:inline-flex;align-items:center;gap:.5em;font-weight:700;text-decoration:none;
  padding:.8em 1.2em;border-radius:var(--radius);min-height:48px}
.btn-call{background:var(--accent);color:#fff}
.btn-wa{background:#25D366;color:#fff}
.btn-ghost{background:transparent;border:2px solid currentColor}

/* ---- Header ---- */
.site-header{position:sticky;top:0;z-index:40;display:flex;align-items:center;gap:12px;padding:12px max(20px, calc((100% - var(--maxw))/2));background:#161616;border-bottom:2px solid var(--accent)}
.site-header .logo{width:38px;height:38px;border-radius:10px;object-fit:cover}
.lang-toggle a{margin-left:.6em;font-weight:700;text-decoration:none}

/* ---- Hero ---- */
.hero{color:#fff;background:var(--brand);position:relative}
.hero[data-mode="foto"]{background:linear-gradient(rgba(0,0,0,.45),rgba(0,0,0,.45)),var(--hero-img,#0b5cad) center/cover no-repeat}
.hero .wrap{padding-top:56px;padding-bottom:56px}
.hero h1{color:#fff}
.hero p{font-size:1.1rem;max-width:40ch;margin:.2em 0 1.4em;color:#f3f3f3}
.hero .cta{display:flex;gap:.7em;flex-wrap:wrap}

/* ---- Servizi ---- */
.servizi-grid{display:grid;grid-template-columns:1fr;gap:18px}
.servizio{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.servizio img{aspect-ratio:16/10;object-fit:cover;width:100%}
.servizio .body{padding:14px 16px}
.servizio h3{margin:.1em 0 .3em;font-size:1.15rem}
.servizio p{margin:0;color:var(--muted)}

/* ---- Galleria ---- */
.galleria{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.galleria img{aspect-ratio:1/1;object-fit:cover;border-radius:var(--radius)}

/* ---- Recensioni ---- */
.recensioni{display:grid;grid-template-columns:1fr;gap:16px;margin-top:24px}
.recensione{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:16px}
.stelle{color:#f5b50a;letter-spacing:2px}
.recensione .autore{font-weight:600;margin-top:.5em}

/* ---- Contatti ---- */
.contatti-grid{display:grid;grid-template-columns:1fr;gap:24px}
.contatti dl{margin:0}
.contatti dt{font-weight:700;margin-top:.8em}
.contatti a.mappa img{border-radius:var(--radius);border:1px solid var(--line)}

/* ---- Footer ---- */
.site-footer{background:var(--ink);color:#cfcfcf;padding:32px 0;font-size:.9rem}
.site-footer a{color:#fff}
.site-footer .nap{font-weight:600;color:#fff}

/* ---- Barra sticky mobile ---- */
.sticky-cta{position:fixed;left:0;right:0;bottom:0;display:flex;z-index:50;
  box-shadow:0 -2px 12px rgba(0,0,0,.15)}
.sticky-cta a{flex:1;text-align:center;padding:14px;font-weight:700;text-decoration:none;color:#fff}
.sticky-cta .c{background:var(--accent)}
.sticky-cta .w{background:#25D366}
body{padding-bottom:60px} /* spazio per la barra su mobile */

/* ---- Responsive ---- */
@media(min-width:768px){
  .servizi-grid{grid-template-columns:repeat(3,1fr)}
  .galleria{grid-template-columns:repeat(4,1fr)}
  .recensioni{grid-template-columns:repeat(3,1fr)}
  .contatti-grid{grid-template-columns:1fr 1fr}
  .sticky-cta{display:none}           /* su desktop la barra sparisce */
  body{padding-bottom:0}
}

/* Disattiva la barra sticky: aggiungi class="no-sticky" al <body> (vedi CLIENTE.md / README). */
.no-sticky .sticky-cta{display:none}

/* ===== UPLIFT v2 ===== */
.section.alt{background:var(--surface)}

.servizio{box-shadow:var(--shadow);transition:transform .25s ease, box-shadow .25s ease}
.servizio .imgwrap{position:relative}
.servizio .imgwrap::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(0,0,0,.30))}
.servizio .chip{position:absolute;top:10px;left:10px;display:inline-flex;align-items:center;gap:.35em;background:rgba(255,255,255,.92);color:var(--brand);font-size:.72rem;font-weight:700;padding:.35em .7em;border-radius:999px}
.servizio .chip svg{width:14px;height:14px;fill:currentColor}
html.js .servizio:hover{transform:translateY(-4px);box-shadow:var(--shadow-strong)}

.galleria img{transition:transform .35s ease}
html.js .galleria a{display:block;overflow:hidden;border-radius:var(--radius)}
html.js .galleria a:hover img{transform:scale(1.05)}

.recensione{box-shadow:var(--shadow);position:relative}
.recensione::before{content:"\201C";position:absolute;top:-2px;left:12px;font-size:2.4rem;color:var(--brand);opacity:.18;font-family:Georgia,serif}
.recensione .autore{display:flex;align-items:center;gap:.5em}
.recensione .autore::before{content:attr(data-ini);width:26px;height:26px;border-radius:50%;background:var(--brand);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700}

.usp-grid{display:grid;grid-template-columns:1fr;gap:16px;margin-top:24px}
.usp{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}
.usp .ico{width:42px;height:42px;border-radius:12px;background:color-mix(in srgb, var(--brand) 12%, #fff);color:var(--brand);display:flex;align-items:center;justify-content:center;margin-bottom:10px}
.usp .ico svg{width:22px;height:22px;fill:currentColor}
.usp h3{margin:.1em 0 .2em;font-size:1.05rem}
.usp p{margin:0;color:var(--muted)}

.aree{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px;padding:0;list-style:none}
.aree li{background:var(--soft);border:1px solid var(--line);border-radius:999px;padding:.4em .9em;font-size:.9rem}

.contatti-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;display:grid;grid-template-columns:1fr}
.contatto-row{display:flex;gap:12px;align-items:center;padding:14px 16px;border-bottom:1px solid var(--line)}
.contatto-row .ico{width:38px;height:38px;border-radius:50%;background:color-mix(in srgb, var(--brand) 12%, #fff);color:var(--brand);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.contatto-row .ico svg{width:18px;height:18px;fill:currentColor}
.contatto-row .k{font-size:.72rem;color:var(--muted);font-weight:700;letter-spacing:.04em}
.contatto-row .v{font-weight:700}
.contatto-row.tel .v{color:var(--brand);font-size:1.15rem}
.mappa-frame{position:relative}
.mappa-frame img{width:100%}
.mappa-frame .open{position:absolute;bottom:10px;left:50%;transform:translateX(-50%);background:var(--brand);color:#fff;font-weight:700;font-size:.85rem;padding:.5em 1em;border-radius:999px;text-decoration:none}

[data-anim]{opacity:1;transform:none}
html.js [data-anim]{opacity:0;transform:translateY(18px);transition:opacity .6s ease, transform .6s cubic-bezier(.2,.7,.2,1);transition-delay:calc(var(--d,0)*90ms)}
html.js [data-anim].in-view{opacity:1;transform:none}
.btn{transition:transform .2s ease, box-shadow .2s ease}
html.js .btn:hover{transform:translateY(-2px)}
.hero[data-parallax]::before{content:"";position:absolute;inset:-20% 0 auto 0;height:140%;background:radial-gradient(60% 50% at 30% 0,rgba(255,255,255,.10),transparent 70%);transform:translateY(var(--py,0));pointer-events:none}

@media (prefers-reduced-motion: reduce){
  html.js [data-anim]{opacity:1;transform:none;transition:none}
  html.js .servizio:hover,html.js .btn:hover,html.js .galleria a:hover img{transform:none}
}

@media(min-width:768px){
  .usp-grid{grid-template-columns:repeat(4,1fr)}
  .contatti-card{grid-template-columns:1.1fr .9fr}
  .contatto-row:last-of-type{border-bottom:0}
}

/* ===== refinements: header sfruttato + icona WhatsApp + gap sticky ===== */
.brand-lockup{display:flex;align-items:center;gap:10px}
.brand-name{font-family:var(--font-heading);font-weight:700;color:#fff;font-size:1.02rem}
.header-tel{margin-left:auto;display:inline-flex;align-items:center;gap:.45em;color:#fff;font-weight:700;text-decoration:none}
.header-tel svg{width:18px;height:18px;fill:currentColor}
@media(max-width:759px){ .header-tel{display:none} }
.btn-wa .ico-wa{width:20px;height:20px;fill:currentColor;flex:0 0 auto}
.sticky-cta a{display:flex;align-items:center;justify-content:center;gap:.45em}
.sticky-cta .ico-wa{width:20px;height:20px;fill:currentColor;flex:0 0 auto}
/* niente striscia chiara tra footer e barra sticky (mobile) */
@media(max-width:767px){ body{padding-bottom:0} .site-footer{padding-bottom:84px} }

/* preset auto-bg-gommista */
:root{--brand:#161616;--accent:#ffd400;--font-heading:"Oswald","Arial Narrow",sans-serif;--font-body:"Inter",system-ui,sans-serif;--radius:2px;--soft:#f2f2f2;--line:#e2e2e2;--surface:#f5f5f5}
.btn-call,.sticky-cta .c{color:#161616}

/* refinements-2: bordo bottoni (chiaro su scuro / scuro su chiaro) */
.btn{border:1.5px solid rgba(0,0,0,.14)}
.dark .btn,.hero .btn{border-color:rgba(255,255,255,.5)}
.sticky-cta a{border-top:1px solid rgba(255,255,255,.22)}
.mappa-frame .open{border:1.5px solid rgba(255,255,255,.6)}

/* lightbox galleria */
.lightbox{position:fixed;inset:0;background:rgba(10,10,10,.93);display:flex;align-items:center;justify-content:center;z-index:100;padding:20px}
.lightbox[hidden]{display:none}
.lightbox .lb-img{max-width:92vw;max-height:82vh;border-radius:8px;box-shadow:0 20px 60px rgba(0,0,0,.55)}
.lb-back{position:fixed;top:16px;left:16px;display:inline-flex;align-items:center;gap:.4em;background:#fff;color:#0a0a0a;border:0;border-radius:999px;padding:.6em 1.1em;font-weight:700;cursor:pointer;z-index:101;box-shadow:0 4px 14px rgba(0,0,0,.35)}
