/* ============================================================
   AUTOTECNICA — Design System
   Officine / Autoriparatori / Gommisti
   Tokens · Type · Layout · Components
   Mobile-first, light CSS, no framework.
   ============================================================ */

/* ---------- TOKENS ---------- */
:root{
  /* brand palette */
  --ink:        #111827;   /* nero soft   */
  --anthracite: #1F2937;   /* antracite   */
  --accent:     #dd3333;   /* arancio     */
  --accent-700: #b02828;
  --accent-300: #e87a7a;
  --steel:      #2563EB;   /* blu acciaio */
  --steel-700:  #1D4ED8;
  --yellow:     #FACC15;   /* giallo      */
  --gray-50:    #F3F4F6;
  --gray-100:   #E9EBEF;
  --gray-200:   #D6DAE1;
  --gray-400:   #9AA1AD;
  --gray-600:   #5B6470;
  --white:      #FFFFFF;

  /* semantic */
  --bg:          var(--white);
  --bg-alt:      var(--gray-50);
  --bg-dark:     var(--anthracite);
  --bg-darker:   var(--ink);
  --text:        var(--ink);
  --text-muted:  var(--gray-600);
  --text-invert: #EAECEF;
  --line:        var(--gray-200);
  --line-dark:   rgba(255,255,255,.10);

  /* type */
  --f-display: "Oswald", "Arial Narrow", sans-serif;
  --f-ui:      "Montserrat", system-ui, sans-serif;
  --f-body:    "Inter", system-ui, sans-serif;

  /* spacing scale */
  --s-1: 4px;  --s-2: 8px;  --s-3: 12px; --s-4: 16px;
  --s-5: 24px; --s-6: 32px; --s-7: 48px; --s-8: 64px;
  --s-9: 96px; --s-10: 128px;

  /* density (tweakable) */
  --section-y: clamp(56px, 8vw, 112px);
  --container: 1200px;
  --gutter: clamp(16px, 4vw, 32px);

  /* radius — angular/technical, small */
  --r-1: 3px; --r-2: 6px; --r-3: 10px; --r-pill: 999px;

  /* elevation */
  --sh-1: 0 1px 2px rgba(17,24,39,.06), 0 1px 3px rgba(17,24,39,.08);
  --sh-2: 0 4px 12px rgba(17,24,39,.08), 0 2px 4px rgba(17,24,39,.06);
  --sh-3: 0 18px 40px rgba(17,24,39,.16);
  --sh-accent: 0 10px 24px rgba(234,88,12,.30);

  --t-fast: .15s cubic-bezier(.4,0,.2,1);
  --t-med:  .28s cubic-bezier(.4,0,.2,1);
}

/* ---------- RESET ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  margin:0; background:var(--bg); color:var(--text);
  font-family:var(--f-body); font-size:16px; line-height:1.65;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg,video{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; cursor:pointer; }
ul{ margin:0; padding:0; list-style:none; }
:focus-visible{ outline:3px solid var(--steel); outline-offset:2px; }

/* ---------- TYPE ---------- */
h1,h2,h3,h4{ font-family:var(--f-display); font-weight:600; line-height:1.04;
  margin:0; letter-spacing:.01em; text-transform:uppercase; }
h1{ font-size:clamp(2.4rem,6vw,4.4rem); }
h2{ font-size:clamp(1.9rem,4.2vw,3rem); }
h3{ font-size:clamp(1.3rem,2.4vw,1.7rem); }
h4{ font-size:1.05rem; letter-spacing:.04em; }
p{ margin:0 0 1em; }
strong{ font-weight:700; }
.lead{ font-size:clamp(1.05rem,1.6vw,1.2rem); color:var(--text-muted); }
.muted{ color:var(--text-muted); }
.accent{ color:var(--accent); }

/* ---------- LAYOUT ---------- */
.container{ width:100%; max-width:var(--container); margin-inline:auto; padding-inline:var(--gutter); }
.container-wide{ max-width:1380px; }
.section{ padding-block:var(--section-y); position:relative; }
.section--alt{ background:var(--bg-alt); }
.section--dark{ background:var(--bg-dark); color:var(--text-invert); }
.section--dark h1,.section--dark h2,.section--dark h3,.section--dark h4{ color:#fff; }
.section--dark .muted{ color:var(--gray-400); }
.grid{ display:grid; gap:var(--s-6); }
.stack{ display:flex; flex-direction:column; gap:var(--s-4); }
.row{ display:flex; gap:var(--s-4); align-items:center; flex-wrap:wrap; }
.center{ text-align:center; }

/* ---------- KICKER / SECTION HEAD ---------- */
.kicker{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--f-ui); font-weight:700; font-size:.78rem;
  letter-spacing:.18em; text-transform:uppercase; color:var(--accent);
  margin-bottom:14px;
}
.kicker::before{ content:""; width:30px; height:3px; background:var(--accent);
  transform:skewX(-20deg); }
.kicker--center{ justify-content:center; }
.section-head{ max-width:64ch; margin-bottom:var(--s-7); }
.section-head.center{ margin-inline:auto; }
.section-head p{ margin-top:14px; }

/* ---------- BUTTONS ---------- */
.btn{
  --btn-bg:var(--accent); --btn-fg:#fff;
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--f-ui); font-weight:700; font-size:.92rem;
  letter-spacing:.04em; text-transform:uppercase;
  padding:15px 26px; background:var(--btn-bg); color:var(--btn-fg);
  border:2px solid var(--btn-bg); border-radius:var(--r-1);
  clip-path:polygon(0 0, 100% 0, 100% 100%, 14px 100%, 0 calc(100% - 14px));
  transition:transform var(--t-fast), background var(--t-fast), box-shadow var(--t-fast);
  position:relative; line-height:1;
}
.btn svg{ width:18px; height:18px; }
.btn:hover{ transform:translateY(-2px); box-shadow:var(--sh-accent); }
.btn:active{ transform:translateY(0); }
.btn--steel{ --btn-bg:var(--steel); box-shadow:none; }
.btn--steel:hover{ background:var(--steel-700); box-shadow:0 10px 24px rgba(37,99,235,.30); }
.btn--ghost{ --btn-bg:transparent; --btn-fg:var(--ink); border-color:var(--ink); }
.btn--ghost:hover{ background:var(--ink); color:#fff; box-shadow:none; }
.btn--on-dark{ --btn-bg:transparent; --btn-fg:#fff; border-color:rgba(255,255,255,.4); }
.btn--on-dark:hover{ background:#fff; color:var(--ink); box-shadow:none; }
.btn--lg{ padding:18px 32px; font-size:1rem; }
.btn--block{ width:100%; justify-content:center; }
.btn--link{ background:none; border:none; clip-path:none; padding:0; color:var(--accent);
  text-transform:uppercase; font-family:var(--f-ui); font-weight:700; letter-spacing:.06em;
  font-size:.82rem; }
.btn--link:hover{ transform:none; box-shadow:none; gap:14px; }
.btn--link svg{ width:15px; }

/* ---------- BADGES / CHIPS ---------- */
.badge{ display:inline-flex; align-items:center; gap:6px; font-family:var(--f-ui);
  font-weight:700; font-size:.72rem; letter-spacing:.1em; text-transform:uppercase;
  padding:6px 12px; border-radius:var(--r-1); background:var(--yellow); color:var(--ink); }
.badge--steel{ background:rgba(37,99,235,.12); color:var(--steel-700); }
.badge--accent{ background:rgba(234,88,12,.12); color:var(--accent-700); }
.chip{ display:inline-flex; align-items:center; gap:8px; padding:9px 16px;
  border:1.5px solid var(--line); border-radius:var(--r-pill); font-family:var(--f-ui);
  font-weight:600; font-size:.85rem; background:#fff; transition:all var(--t-fast); }
.chip[aria-pressed="true"],.chip:hover{ border-color:var(--accent); color:var(--accent); }

/* ---------- TOPBAR ---------- */
.topbar{ background:var(--ink); color:var(--text-invert); font-family:var(--f-ui);
  font-size:.82rem; font-weight:500; }
.topbar .container{ display:flex; justify-content:space-between; align-items:center;
  gap:var(--s-4); min-height:42px; flex-wrap:wrap; }
.topbar a,.topbar span{ display:inline-flex; align-items:center; gap:7px; color:var(--text-invert); line-height:1; }
.topbar a:hover{ color:var(--accent-300); }
.topbar .topbar__meta{ display:flex; gap:var(--s-5); align-items:center; flex-wrap:wrap; }
.topbar svg{ width:15px; height:15px; color:var(--accent); flex:none; }
.topbar .topbar__meta > span > svg{ position:relative; top:-.5px; }
@media (max-width:720px){ .topbar .topbar__meta .hide-sm{ display:none; } }

/* ---------- HEADER / NAV ---------- */
.header{ position:sticky; top:0; z-index:60; background:#fff;
  border-bottom:1px solid var(--line); transition:box-shadow var(--t-fast); }
.header.is-stuck{ box-shadow:var(--sh-2); }
.header .container{ display:flex; align-items:center; gap:var(--s-5); min-height:74px; }
.brand{ display:flex; align-items:center; gap:12px; font-family:var(--f-display);
  font-weight:700; text-transform:uppercase; font-size:1.35rem; letter-spacing:.02em;
  color:var(--ink); white-space:nowrap; }
.brand__mark{ width:42px; height:42px; display:grid; place-items:center; color:#fff;
  background:var(--accent); clip-path:polygon(0 0,100% 0,100% 70%,70% 100%,0 100%); }
.brand__mark svg{ width:24px; height:24px; }
.brand small{ display:block; font-family:var(--f-ui); font-weight:600; font-size:.6rem;
  letter-spacing:.22em; color:var(--accent); text-transform:uppercase; margin-top:2px; }
.nav{ margin-left:auto; display:flex; align-items:center; gap:var(--s-2); }
.nav__links{ display:flex; align-items:center; gap:2px; }
.nav__links a{ font-family:var(--f-ui); font-weight:600; font-size:.92rem; padding:10px 14px;
  border-radius:var(--r-1); color:var(--anthracite); transition:color var(--t-fast); position:relative; }
.nav__links a::after{ content:""; position:absolute; left:14px; right:14px; bottom:4px; height:2px;
  background:var(--accent); transform:scaleX(0); transform-origin:left; transition:transform var(--t-fast); }
.nav__links a:hover,.nav__links a[aria-current="page"]{ color:var(--accent); }
.nav__links a:hover::after,.nav__links a[aria-current="page"]::after{ transform:scaleX(1); }
.nav__cta{ margin-left:var(--s-3); }
.nav__toggle{ display:none; width:46px; height:46px; border:1.5px solid var(--line);
  border-radius:var(--r-1); background:#fff; align-items:center; justify-content:center; }
.nav__toggle span{ position:relative; width:20px; height:2px; background:var(--ink); display:block; }
.nav__toggle span::before,.nav__toggle span::after{ content:""; position:absolute; left:0; width:20px;
  height:2px; background:var(--ink); transition:transform var(--t-fast); }
.nav__toggle span::before{ top:-6px; } .nav__toggle span::after{ top:6px; }
body.nav-open .nav__toggle span{ background:transparent; }
body.nav-open .nav__toggle span::before{ transform:translateY(6px) rotate(45deg); }
body.nav-open .nav__toggle span::after{ transform:translateY(-6px) rotate(-45deg); }

@media (max-width:1024px){
  .nav__cta .btn span.cta-text-long{ display:none; }
  .nav__links a{ padding:10px 10px; font-size:.88rem; }
}
@media (max-width:920px){
  .nav__toggle{ display:flex; margin-left:auto; }
  .nav{ position:fixed; inset:0 0 0 auto; width:min(86vw,360px); margin:0;
    background:#fff; flex-direction:column; align-items:stretch; gap:0;
    padding:90px var(--s-5) var(--s-6); transform:translateX(100%);
    transition:transform var(--t-med); box-shadow:var(--sh-3); overflow-y:auto; }
  body.nav-open .nav{ transform:translateX(0); }
  .nav__links{ flex-direction:column; align-items:stretch; gap:0; }
  .nav__links a{ padding:14px 4px; border-bottom:1px solid var(--line); border-radius:0; font-size:1rem; }
  .nav__links a::after{ display:none; }
  .nav__cta{ margin:var(--s-5) 0 0; }
  .nav__cta .btn{ width:100%; justify-content:center; }
  .nav__cta .btn span.cta-text-long{ display:inline; }
  .nav-scrim{ position:fixed; inset:0; background:rgba(17,24,39,.5); z-index:50;
    opacity:0; visibility:hidden; transition:opacity var(--t-med); }
  body.nav-open .nav-scrim{ opacity:1; visibility:visible; }
}

/* ---------- HERO ---------- */
.hero{ position:relative; background:var(--anthracite); color:#fff; overflow:hidden; }
.hero::before{ content:""; position:absolute; inset:0; z-index:0;
  background:
    radial-gradient(120% 90% at 85% 10%, rgba(37,99,235,.18), transparent 60%),
    linear-gradient(120deg, var(--ink) 0%, var(--anthracite) 55%, #243244 100%); }
.hero__deco{ position:absolute; top:0; right:0; bottom:0; width:55%; z-index:1;
  background:var(--accent); opacity:.10;
  clip-path:polygon(28% 0, 100% 0, 100% 100%, 8% 100%); pointer-events:none; }
.hero .container{ position:relative; z-index:3; display:grid; gap:var(--s-7);
  grid-template-columns:1fr; padding-block:clamp(48px,7vw,90px); align-items:center; }
.hero__copy{ max-width:60ch; }
.hero__title{ margin:.1em 0 .35em; }
.hero__title em{ font-style:normal; color:var(--accent); }
.hero p.lead{ color:#C7CDD6; }
.hero__actions{ display:flex; gap:var(--s-4); flex-wrap:wrap; margin-top:var(--s-6); align-items:center; }
.hero__phone{ display:inline-flex; align-items:center; gap:12px; font-family:var(--f-ui); font-weight:600; }
.hero__phone .ico{ width:48px; height:48px; border-radius:50%; display:grid; place-items:center;
  background:rgba(255,255,255,.10); border:1px solid rgba(255,255,255,.18); color:#fff; }
.hero__phone small{ display:block; font-size:.72rem; letter-spacing:.14em; text-transform:uppercase;
  color:var(--gray-400); }
.hero__phone b{ font-family:var(--f-display); font-size:1.25rem; font-weight:600; }
.hero__media{ position:relative; }
.hero__media image-slot,.hero__media .ph{ width:100%; aspect-ratio:5/4;
  clip-path:polygon(12% 0, 100% 0, 100% 100%, 0 100%); box-shadow:var(--sh-3); }
.hero__badge{ position:absolute; left:-10px; bottom:18px; background:#fff; color:var(--ink);
  padding:16px 22px; box-shadow:var(--sh-3); display:flex; align-items:center; gap:14px;
  clip-path:polygon(0 0,100% 0,100% 100%,14px 100%,0 calc(100% - 14px)); }
.hero__badge .big{ font-family:var(--f-display); font-size:2.6rem; line-height:.9; color:var(--accent); }
.hero__badge small{ font-family:var(--f-ui); font-weight:700; text-transform:uppercase;
  letter-spacing:.08em; font-size:.72rem; }
.hero__strip{ position:relative; z-index:3; border-top:1px solid var(--line-dark);
  background:rgba(0,0,0,.20); }
.hero__strip .container{ display:grid; grid-template-columns:repeat(2,1fr); gap:0;
  padding-block:0; }
.hero__stat{ display:flex; align-items:center; gap:14px; padding:22px var(--gutter); }
.hero__stat svg{ width:30px; height:30px; color:var(--accent); flex:none; }
.hero__stat b{ font-family:var(--f-display); font-size:1.05rem; display:block; }
.hero__stat span{ font-size:.85rem; color:var(--gray-400); }
@media (min-width:880px){
  .hero .container{ grid-template-columns:1.05fr .95fr; }
  .hero__strip .container{ grid-template-columns:repeat(4,1fr); }
  .hero__stat:not(:last-child){ border-right:1px solid var(--line-dark); }
}

/* ---------- PAGE HERO (inner pages) ---------- */
.pagehero{ background:var(--anthracite); color:#fff; position:relative; overflow:hidden; }
.pagehero::before{ content:""; position:absolute; inset:0;
  background:linear-gradient(115deg,var(--ink),var(--anthracite) 70%); }
.pagehero__deco{ position:absolute; inset:0 0 0 auto; width:40%; background:var(--accent);
  opacity:.10; clip-path:polygon(35% 0,100% 0,100% 100%,0 100%); }
.pagehero .container{ position:relative; z-index:2; padding-block:clamp(48px,7vw,84px); }
.pagehero h1{ margin-bottom:10px; }
.pagehero p{ color:#C7CDD6; max-width:60ch; }
.breadcrumb{ display:flex; gap:8px; align-items:center; font-family:var(--f-ui); font-size:.82rem;
  font-weight:600; color:var(--gray-400); margin-bottom:18px; text-transform:uppercase; letter-spacing:.06em; }
.breadcrumb a:hover{ color:var(--accent-300); }
.breadcrumb svg{ width:12px; height:12px; opacity:.6; }
.breadcrumb [aria-current]{ color:#fff; }

/* ---------- SERVICE CARDS ---------- */
.cards{ display:grid; gap:var(--s-5); grid-template-columns:1fr; }
@media (min-width:600px){ .cards{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:980px){ .cards--3{ grid-template-columns:repeat(3,1fr); } }
.card-svc{ background:#fff; border:1px solid var(--line); padding:var(--s-6);
  position:relative; transition:transform var(--t-med), box-shadow var(--t-med), border-color var(--t-med);
  overflow:hidden; }
.card-svc::after{ content:""; position:absolute; left:0; bottom:0; width:100%; height:4px;
  background:var(--accent); transform:scaleX(0); transform-origin:left; transition:transform var(--t-med); }
.card-svc:hover{ transform:translateY(-6px); box-shadow:var(--sh-3); border-color:transparent; }
.card-svc:hover::after{ transform:scaleX(1); }
.card-svc__icon{ width:62px; height:62px; display:grid; place-items:center; color:#fff;
  background:var(--anthracite); margin-bottom:var(--s-5);
  clip-path:polygon(0 0,100% 0,100% 72%,72% 100%,0 100%); transition:background var(--t-med); }
.card-svc:hover .card-svc__icon{ background:var(--accent); }
.card-svc__icon svg{ width:30px; height:30px; }
.card-svc h3{ margin-bottom:10px; }
.card-svc p{ color:var(--text-muted); font-size:.95rem; margin-bottom:18px; }

/* ---------- FEATURE / WHY ---------- */
.feature{ display:flex; gap:var(--s-4); align-items:flex-start; }
.feature__ico{ width:54px; height:54px; flex:none; display:grid; place-items:center;
  border:2px solid var(--accent); color:var(--accent); clip-path:polygon(0 0,100% 0,100% 72%,72% 100%,0 100%); }
.feature__ico svg{ width:26px; height:26px; }
.feature h4{ font-family:var(--f-display); font-size:1.15rem; margin-bottom:6px; }
.feature p{ color:var(--text-muted); font-size:.92rem; margin:0; }

/* checklist */
.checklist li{ display:flex; gap:10px; align-items:flex-start; padding:7px 0; font-weight:500; }
.checklist svg{ width:20px; height:20px; color:var(--accent); flex:none; margin-top:3px; }

/* ---------- STAT STRIP ---------- */
.stats{ display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--line); }
@media (min-width:760px){ .stats{ grid-template-columns:repeat(4,1fr); } }
.stat{ background:#fff; padding:var(--s-6) var(--s-5); text-align:center; }
.stat b{ font-family:var(--f-display); font-size:clamp(2.2rem,4vw,3rem); color:var(--accent); display:block; }
.stat span{ font-family:var(--f-ui); font-weight:600; font-size:.85rem; color:var(--text-muted);
  text-transform:uppercase; letter-spacing:.08em; }
.section--dark .stat{ background:transparent; }
.section--dark .stats{ background:var(--line-dark); }

/* ---------- BEFORE / AFTER ---------- */
.ba{ position:relative; user-select:none; aspect-ratio:16/9; overflow:hidden;
  box-shadow:var(--sh-3); }
.ba .ba__img{ position:absolute; inset:0; }
.ba .ba__after{ clip-path:inset(0 0 0 var(--pos,50%)); }
.ba label{ position:absolute; top:14px; padding:6px 14px; font-family:var(--f-ui); font-weight:700;
  font-size:.72rem; text-transform:uppercase; letter-spacing:.1em; color:#fff; }
.ba .lbl-before{ left:14px; background:var(--ink); }
.ba .lbl-after{ right:14px; background:var(--accent); }
.ba__range{ position:absolute; inset:0; width:100%; margin:0; opacity:0; cursor:ew-resize; z-index:3; }
.ba__handle{ position:absolute; top:0; bottom:0; left:var(--pos,50%); width:3px; background:#fff;
  transform:translateX(-50%); pointer-events:none; z-index:2; box-shadow:0 0 0 1px rgba(0,0,0,.15); }
.ba__handle::after{ content:""; position:absolute; top:50%; left:50%; width:46px; height:46px;
  transform:translate(-50%,-50%); background:#fff; border-radius:50%; box-shadow:var(--sh-2);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none' stroke='%23EA580C' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M9 6 3 12l6 6M15 6l6 6-6 6'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:center; background-size:22px; }

/* ---------- GALLERY ---------- */
.filters{ display:flex; gap:10px; flex-wrap:wrap; margin-bottom:var(--s-6); }
.gallery{ display:grid; gap:var(--s-4); grid-template-columns:repeat(2,1fr); }
@media (min-width:760px){ .gallery{ grid-template-columns:repeat(3,1fr); } }
.gallery__item{ position:relative; overflow:hidden; }
.gallery__item image-slot{ width:100%; aspect-ratio:4/3; }
.gallery__item .tag{ position:absolute; left:0; bottom:0; background:var(--accent); color:#fff;
  font-family:var(--f-ui); font-weight:700; font-size:.78rem; padding:8px 14px; text-transform:uppercase;
  letter-spacing:.06em; clip-path:polygon(0 0,100% 0,calc(100% - 12px) 100%,0 100%); pointer-events:none; }

/* ---------- FORM ---------- */
.form-card{ background:#fff; border:1px solid var(--line); padding:clamp(20px,3vw,40px);
  box-shadow:var(--sh-2); }
.section--dark .form-card{ background:#fff; color:var(--ink); }
.field{ margin-bottom:var(--s-4); }
.field label{ display:block; font-family:var(--f-ui); font-weight:600; font-size:.85rem;
  margin-bottom:7px; color:var(--anthracite); }
.field label .req{ color:var(--accent); }
.input,.select,.textarea{ width:100%; font-family:var(--f-body); font-size:1rem; color:var(--ink);
  padding:13px 14px; border:1.5px solid var(--line); border-radius:var(--r-1); background:#fff;
  transition:border-color var(--t-fast), box-shadow var(--t-fast); }
.input:focus,.select:focus,.textarea:focus{ outline:none; border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(234,88,12,.14); }
.textarea{ min-height:120px; resize:vertical; }
.select{ appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' fill='none' stroke='%235B6470' stroke-width='2'%3E%3Cpath d='m5 8 5 5 5-5'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 12px center; padding-right:38px; }
.field-grid{ display:grid; gap:var(--s-4); grid-template-columns:1fr; }
@media (min-width:560px){ .field-grid--2{ grid-template-columns:1fr 1fr; } }
.form-note{ font-size:.82rem; color:var(--text-muted); display:flex; gap:10px; align-items:flex-start; margin-top:6px; }
.form-note input{ margin-top:4px; flex:none; }
.form-msg{ padding:14px 16px; border-radius:var(--r-1); background:rgba(34,197,94,.12);
  color:#15803d; font-weight:600; display:none; margin-top:var(--s-4); }
.form-msg.is-on{ display:block; }

/* step chips for booking */
.steps{ display:flex; gap:8px; flex-wrap:wrap; margin-bottom:var(--s-6); counter-reset:step; }
.steps li{ display:flex; align-items:center; gap:10px; font-family:var(--f-ui); font-weight:600;
  font-size:.85rem; color:var(--text-muted); }
.steps li::before{ counter-increment:step; content:counter(step); width:28px; height:28px;
  display:grid; place-items:center; border-radius:50%; background:var(--gray-100); color:var(--text-muted);
  font-family:var(--f-display); }
.steps li[aria-current]::before{ background:var(--accent); color:#fff; }
.steps li:not(:last-child)::after{ content:""; width:20px; height:2px; background:var(--line); }

/* ---------- TESTIMONIALS ---------- */
.quote{ background:rgba(255,255,255,.04); border:1px solid var(--line-dark); padding:var(--s-6);
  position:relative; }
.quote .mark{ font-family:var(--f-display); font-size:3.4rem; color:var(--accent); line-height:.6;
  display:block; height:24px; }
.quote p{ font-size:1.02rem; color:#DCE0E6; }
.quote .who{ display:flex; align-items:center; gap:14px; margin-top:var(--s-4); }
.quote .who image-slot{ width:52px; height:52px; flex:none; }
.quote .who b{ font-family:var(--f-ui); display:block; color:#fff; }
.quote .who span{ font-size:.82rem; color:var(--gray-400); }
.stars{ display:inline-flex; gap:2px; color:var(--yellow); margin-bottom:14px; }
.stars svg{ width:18px; height:18px; }

/* ---------- PRICING / OFFERTE ---------- */
.price-card{ background:#fff; border:1px solid var(--line); padding:var(--s-6); text-align:center;
  position:relative; transition:transform var(--t-med), box-shadow var(--t-med); }
.price-card:hover{ transform:translateY(-6px); box-shadow:var(--sh-3); }
.price-card--feat{ border-color:var(--accent); box-shadow:var(--sh-accent); }
.price-card--feat::before{ content:"Più richiesto"; position:absolute; top:0; left:50%; transform:translate(-50%,-50%);
  background:var(--accent); color:#fff; font-family:var(--f-ui); font-weight:700; font-size:.7rem;
  letter-spacing:.1em; text-transform:uppercase; padding:6px 14px; }
.price-card h3{ margin-bottom:6px; }
.price-card .price{ font-family:var(--f-display); font-size:3rem; color:var(--accent); line-height:1; margin:10px 0; }
.price-card .price small{ font-size:1rem; color:var(--text-muted); }
.price-card ul{ text-align:left; margin:var(--s-5) 0; }
.price-card ul li{ display:flex; gap:10px; padding:7px 0; border-bottom:1px dashed var(--line); font-size:.92rem; }
.price-card ul svg{ width:18px; height:18px; color:var(--accent); flex:none; }

/* offerta stagionale banner */
.offer{ display:grid; gap:var(--s-5); align-items:center; background:var(--anthracite); color:#fff;
  padding:clamp(24px,4vw,48px); position:relative; overflow:hidden; }
.offer::before{ content:""; position:absolute; inset:0 0 0 auto; width:45%; background:var(--accent);
  opacity:.14; clip-path:polygon(30% 0,100% 0,100% 100%,0 100%); }
.offer__tag{ display:inline-block; background:var(--yellow); color:var(--ink); font-family:var(--f-display);
  font-size:1.1rem; padding:6px 14px; transform:skewX(-8deg); margin-bottom:14px; }
@media (min-width:760px){ .offer{ grid-template-columns:1.4fr 1fr; } }

/* ---------- PROCESS STEPS ---------- */
.process{ display:grid; gap:var(--s-5); grid-template-columns:1fr; counter-reset:proc; }
@media (min-width:680px){ .process{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:1000px){ .process{ grid-template-columns:repeat(4,1fr); } }
.process__step{ position:relative; padding:var(--s-6) var(--s-5); background:#fff; border:1px solid var(--line); }
.process__step .num{ font-family:var(--f-display); font-size:3rem; color:var(--gray-100); line-height:.8;
  position:absolute; top:16px; right:18px; }
.process__step .ico{ width:56px; height:56px; display:grid; place-items:center; color:#fff;
  background:var(--accent); margin-bottom:var(--s-4); clip-path:polygon(0 0,100% 0,100% 72%,72% 100%,0 100%); }
.process__step .ico svg{ width:28px; height:28px; }
.process__step h4{ font-family:var(--f-display); font-size:1.2rem; margin-bottom:8px; }
.process__step p{ font-size:.9rem; color:var(--text-muted); margin:0; }

/* ---------- FAQ ---------- */
.faq{ max-width:820px; margin-inline:auto; }
.faq__item{ border:1px solid var(--line); margin-bottom:12px; background:#fff; }
.faq__q{ list-style:none; cursor:pointer; width:100%; text-align:left; display:flex; justify-content:space-between; align-items:center;
  gap:16px; padding:20px 22px; background:none; border:none; font-family:var(--f-ui); font-weight:600;
  font-size:1.02rem; color:var(--ink); }
.faq__q .pm{ width:26px; height:26px; flex:none; position:relative; }
.faq__q .pm::before,.faq__q .pm::after{ content:""; position:absolute; top:50%; left:50%; background:var(--accent);
  transition:transform var(--t-fast); }
.faq__q .pm::before{ width:14px; height:2.5px; transform:translate(-50%,-50%); }
.faq__q .pm::after{ width:2.5px; height:14px; transform:translate(-50%,-50%); }
.faq__item[open] .pm::after{ transform:translate(-50%,-50%) scaleY(0); }
.faq__a{ padding:0 22px; max-height:0; overflow:hidden; transition:max-height var(--t-med), padding var(--t-med); }
.faq__item[open] .faq__a{ padding:0 22px 22px; max-height:400px; }
.faq__a p{ color:var(--text-muted); margin:0; }
.faq__q::-webkit-details-marker{ display:none; }
.faq__item[open] .faq__a{ animation:faq-in .28s ease; }
@keyframes faq-in{ from{ opacity:0; } to{ opacity:1; } }

/* ---------- CTA BAND ---------- */
.ctaband{ background:var(--accent); color:#fff; position:relative; overflow:hidden; }
.ctaband::before{ content:""; position:absolute; inset:0 auto 0 0; width:40%; background:#000; opacity:.08;
  clip-path:polygon(0 0,70% 0,100% 100%,0 100%); }
.ctaband .container{ position:relative; z-index:2; display:grid; gap:var(--s-5); align-items:center;
  padding-block:var(--s-8); }
.ctaband h2{ color:#fff; }
.ctaband p{ color:rgba(255,255,255,.9); margin:0; }
.ctaband .btn--ghost{ border-color:#fff; color:#fff; }
.ctaband .btn--ghost:hover{ background:#fff; color:var(--accent); }
@media (min-width:820px){ .ctaband .container{ grid-template-columns:1.6fr auto; } }

/* ---------- FOOTER ---------- */
.footer{ background:var(--ink); color:#AEB4BE; font-size:.92rem; }
.footer .container{ padding-block:var(--s-8) var(--s-6); }
.footer__grid{ display:grid; gap:var(--s-6); grid-template-columns:1fr; }
@media (min-width:680px){ .footer__grid{ grid-template-columns:1.4fr 1fr 1fr; } }
@media (min-width:980px){ .footer__grid{ grid-template-columns:1.6fr 1fr 1fr 1.3fr; } }
.footer h4{ color:#fff; font-family:var(--f-display); font-size:1.05rem; letter-spacing:.04em; margin-bottom:18px; }
.footer a{ color:#AEB4BE; } .footer a:hover{ color:var(--accent-300); }
.footer__links li{ padding:5px 0; }
.footer .brand{ color:#fff; margin-bottom:16px; }
.footer__hours li{ display:flex; justify-content:space-between; gap:12px; padding:5px 0;
  border-bottom:1px solid var(--line-dark); }
.footer__social{ display:flex; gap:10px; margin-top:18px; }
.footer__social a{ width:40px; height:40px; display:grid; place-items:center; border:1px solid var(--line-dark);
  color:#fff; transition:all var(--t-fast); }
.footer__social a:hover{ background:var(--accent); border-color:var(--accent); }
.footer__social svg{ width:18px; height:18px; }
.footer__bar{ border-top:1px solid var(--line-dark); margin-top:var(--s-7); padding-top:var(--s-5);
  display:flex; justify-content:space-between; gap:var(--s-3) var(--s-4); flex-wrap:wrap; align-items:center;
  font-size:.84rem; color:#7C828C; }
.footer__bar a{ color:#7C828C; }
.footer__credit{ flex-basis:100%; order:3; text-align:center; padding-top:14px; margin-top:6px;
  border-top:1px solid var(--line-dark); color:#7C828C; letter-spacing:.02em; }
.footer__credit a{ color:var(--accent-300); font-weight:600; }
.footer__credit a:hover{ color:#fff; }

/* ---------- WHATSAPP FLOAT ---------- */
.wa-float{ position:fixed; right:18px; bottom:18px; z-index:80; width:60px; height:60px;
  border-radius:50%; background:#25D366; color:#fff; display:grid; place-items:center;
  box-shadow:0 8px 24px rgba(0,0,0,.25); transition:transform var(--t-fast); }
.wa-float:hover{ transform:scale(1.06); }
.wa-float svg{ width:32px; height:32px; }
.wa-float::after{ content:""; position:absolute; inset:0; border-radius:50%; background:#25D366;
  z-index:-1; animation:wa-pulse 2.2s ease-out infinite; }
.wa-float .wa-tip{ position:absolute; right:72px; top:50%; transform:translateY(-50%);
  background:#fff; color:var(--ink); font-family:var(--f-ui); font-weight:600; font-size:.85rem;
  white-space:nowrap; padding:9px 14px; border-radius:var(--r-1); box-shadow:var(--sh-2);
  opacity:0; pointer-events:none; transition:opacity var(--t-fast); }
.wa-float .wa-tip::after{ content:""; position:absolute; right:-6px; top:50%; transform:translateY(-50%);
  border:6px solid transparent; border-left-color:#fff; }
.wa-float:hover .wa-tip{ opacity:1; }
@keyframes wa-pulse{ 0%{ transform:scale(1); opacity:.55; } 70%{ transform:scale(1.55); opacity:0; } 100%{ opacity:0; } }
@media (prefers-reduced-motion:reduce){ .wa-float::after{ animation:none; } html{ scroll-behavior:auto; } }
@media (max-width:600px){ .wa-float{ right:14px; bottom:14px; width:56px; height:56px; } .wa-float .wa-tip{ display:none; } }

/* sticky mobile call bar */
.callbar{ display:none; }
@media (max-width:600px){
  .callbar{ display:grid; grid-template-columns:1fr 1fr; position:fixed; left:0; right:0; bottom:0; z-index:75;
    background:#fff; border-top:1px solid var(--line); box-shadow:0 -4px 16px rgba(0,0,0,.08); }
  .callbar a{ display:flex; align-items:center; justify-content:center; gap:8px; padding:14px;
    font-family:var(--f-ui); font-weight:700; font-size:.9rem; text-transform:uppercase; letter-spacing:.04em; }
  .callbar a:first-child{ color:var(--ink); } .callbar a:last-child{ background:var(--accent); color:#fff; }
  .callbar svg{ width:18px; height:18px; }
  .wa-float{ bottom:74px; }
  body{ padding-bottom:54px; }
}

/* ---------- COOKIE BANNER ---------- */
.cookie{ position:fixed; left:50%; bottom:18px; transform:translateX(-50%); z-index:90;
  width:min(720px,calc(100vw - 28px)); background:#fff; border:1px solid var(--line);
  box-shadow:var(--sh-3); padding:20px 22px; display:none; }
.cookie.is-on{ display:block; }
.cookie h4{ font-family:var(--f-display); margin-bottom:8px; }
.cookie p{ font-size:.88rem; color:var(--text-muted); margin-bottom:14px; }
.cookie__row{ display:flex; gap:10px; flex-wrap:wrap; }
@media (max-width:600px){ .cookie{ bottom:60px; } }

/* ---------- UTILITIES ---------- */
.split{ display:grid; gap:var(--s-7); align-items:center; grid-template-columns:1fr; }
@media (min-width:880px){ .split{ grid-template-columns:1fr 1fr; } .split--media-first > .split__media{ order:-1; } }
.split__media image-slot,.split__media .ph{ width:100%; }
.divider-angle{ height:0; border-bottom:60px solid var(--bg-alt); border-left:100vw solid transparent; }
.reveal{ transition:opacity .6s ease, transform .6s ease; }
.reveal.armed{ opacity:0; transform:translateY(24px); }
.reveal.armed.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){ .reveal,.reveal.armed{ opacity:1; transform:none; } }
.hide{ display:none !important; }
.mt-0{ margin-top:0; } .mb-0{ margin-bottom:0; }

/* image-slot baseline so placeholders look intentional */
image-slot{ background:var(--gray-100);
  background-image:linear-gradient(135deg, var(--gray-100), var(--gray-50)); }
.section--dark image-slot{ background:rgba(255,255,255,.06); }

/* ===== WaaS officine overrides ===== */
/* real hero photo fits the diagonal cut (matches design) */
.hero__media img{ width:100%; aspect-ratio:5/4; object-fit:cover; object-position:center;
  clip-path:polygon(12% 0, 100% 0, 100% 100%, 0 100%); box-shadow:var(--sh-3); display:block; }
/* brand logo in header — dark chip so light/white logos read on the white header */
.brand img.brand-logo{ height:40px; width:auto; display:block; }
.header .brand.brand--logo{ background:var(--anthracite); padding:7px 13px; border-radius:var(--r-2); }
.footer .brand img{ height:40px; width:auto; }
/* footer logo on light chip when logo is dark-toned */
.footer .brand.brand--logo-light{ background:#fff; padding:7px 13px; border-radius:var(--r-2); display:inline-flex; }
/* gallery real photos */
.gallery__item img{ width:100%; height:100%; object-fit:cover; display:block; }
/* hero photo BIGGER, fills the diagonal cut on the right */
.hero__media img{ aspect-ratio:4/3; clip-path:polygon(8% 0, 100% 0, 100% 100%, 0 100%); }
@media (min-width:880px){
  .hero .container{ grid-template-columns:1fr 1.18fr; }
  .hero__media{ align-self:stretch; }
  .hero__media img{ aspect-ratio:auto; height:100%; min-height:480px; }
}
/* real photos on inner pages (services/contatti) */
img.waas-fill{ width:100%; height:auto; max-height:520px; object-fit:cover; border-radius:var(--r-3); display:block; box-shadow:var(--sh-2); }
