:root{
  --bg:#f4f4f1;
  --surface:#ffffff;
  --surface-2:#ecece8;
  --text:#111214;
  --muted:#666a70;
  --muted-2:#6a6e74;
  --line:#ddddda;
  --dark:#0d0d10;
  --dark-2:#15161a;
  --accent:#b6171c;
  --accent-dark:#8e1115;
  --accent-soft:#f2d6d7;
  --accent-glow:rgba(182,23,28,.15);
  --accent-border:rgba(182,23,28,.3);
  --green:#1e8d55;
  --whatsapp:#25d366;
  --radius:28px;
  --radius-sm:20px;
  --shadow:0 18px 50px rgba(0,0,0,.08);
  --shadow-soft:0 10px 26px rgba(0,0,0,.05);
  --max:1260px;
  --section:110px;
  --ease:cubic-bezier(.22,1,.36,1);
  --ease-soft:cubic-bezier(.16,.84,.32,1);
  --ease-glide:cubic-bezier(.25,.8,.25,1);
  --ease-spring:cubic-bezier(.34,1.4,.64,1);
  --ease-out-quart:cubic-bezier(.165,.84,.44,1);
  --display:'Barlow Condensed', 'Inter', system-ui, sans-serif;
  --body:'DM Sans', system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--body);
  background:var(--bg);
  color:var(--text);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
button{font-family:inherit}

/* Page loader */
.page-loader{
  position:fixed;
  inset:0;
  background:var(--dark);
  z-index:10000;
  transition:opacity .55s ease .1s;
}
.page-loader.done{opacity:0;pointer-events:none}

/* Scroll progress bar */
.scroll-bar{
  position:fixed;
  top:0;
  left:0;
  height:2px;
  background:var(--accent);
  z-index:9999;
  width:100%;
  transform:scaleX(0);
  transform-origin:left center;
  transition:transform .1s linear;
  pointer-events:none;
  will-change:transform;
}

/* Custom cursor (desktop, fine pointer) */
.custom-cursor{display:none}
@media (pointer: fine){
  body{cursor:none}
  input,textarea,select,[contenteditable]{cursor:text}
  iframe{cursor:auto}
  .custom-cursor{
    display:block;
    position:fixed;
    top:0;
    left:0;
    width:36px;
    height:36px;
    background:var(--accent);
    border-radius:50%;
    pointer-events:none;
    z-index:9998;
    transform:translate3d(var(--cursor-x, 0), var(--cursor-y, 0), 0) translate(-50%,-50%) scale(.333);
    transition:background .25s var(--ease), opacity .25s var(--ease), border-color .25s var(--ease), --cursor-scale .25s var(--ease);
    will-change:transform;
    border:1.5px solid transparent;
  }
  body:has(a:hover) .custom-cursor,
  body:has(button:hover) .custom-cursor,
  body:has(.faq-q:hover) .custom-cursor,
  body:has(.fab:hover) .custom-cursor{
    transform:translate3d(var(--cursor-x, 0), var(--cursor-y, 0), 0) translate(-50%,-50%) scale(1);
    background:rgba(182,23,28,.18);
    border-color:var(--accent);
  }
}

/* Skip link */
.skip-link{
  position:absolute;
  top:16px;
  left:16px;
  z-index:1000;
  padding:12px 18px;
  background:var(--accent);
  color:#fff;
  font-weight:700;
  border-radius:12px;
  letter-spacing:.06em;
  transform:translateY(-200%);
  transition:transform .25s var(--ease);
}
.skip-link:focus{transform:translateY(0);outline:2px solid #fff;outline-offset:2px}

:focus-visible{
  outline:2px solid var(--accent);
  outline-offset:3px;
  border-radius:6px;
}

.container{width:min(var(--max), calc(100% - 64px));margin:0 auto}
.section{padding:var(--section) 0}
.section-tight{padding:74px 0}

/* Typography — premium hierarchy */
.kicker{
  font-family:var(--display);
  display:inline-flex;
  align-items:center;
  gap:10px;
  margin-bottom:18px;
  font-size:13px;
  font-weight:700;
  letter-spacing:.3em;
  text-transform:uppercase;
  color:#5e6166;
}
.kicker::before{
  content:"";
  width:24px;
  height:1.5px;
  background:var(--accent);
  border-radius:2px;
  flex-shrink:0;
}
.hero .kicker::before{ background:var(--accent); opacity:.85 }
.section-dark .kicker::before,
.manifesto-section .kicker::before{ background:var(--accent) }
/* Hero kicker — always white/light on dark image background */
.hero .kicker{
  color:rgba(255,255,255,.58);
  letter-spacing:.28em;
}
.title-xl{
  font-family:var(--display);
  font-size:clamp(40px, 9vw, 116px);
  line-height:.92;
  font-weight:900;
  letter-spacing:.01em;
  text-transform:uppercase;
}
.title-lg{
  font-family:var(--display);
  font-size:clamp(36px, 5.4vw, 78px);
  line-height:.92;
  font-weight:900;
  letter-spacing:.01em;
  text-transform:uppercase;
}
.title-md{
  font-family:var(--display);
  font-size:clamp(28px, 3.2vw, 44px);
  line-height:.95;
  font-weight:900;
  letter-spacing:.01em;
  text-transform:uppercase;
}
.lead{
  font-size:clamp(17px, 1.8vw, 22px);
  color:var(--muted);
  max-width:760px;
  line-height:1.55;
}
.text{
  font-size:17px;
  color:var(--muted);
  line-height:1.6;
}
.text + .text{margin-top:16px}

/* line-accent — animated underline on section titles */
.line-accent{
  display:block;
  width:84px;
  height:3px;
  background:var(--accent);
  margin-top:18px;
  border-radius:2px;
  transform:scaleX(0);
  transform-origin:left center;
  transition:transform .95s var(--ease-soft) .35s;
}
.section-head.visible .line-accent,
.reveal.visible .line-accent,
.section-head .reveal.visible .line-accent{transform:scaleX(1)}

.header{
  position:sticky;
  top:0;
  z-index:100;
  background:rgba(13,13,16,.96);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(255,255,255,.06);
  transition:.28s var(--ease);
}
.nav{
  min-height:88px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
}
.brand{
  display:inline-flex;
  align-items:center;
  gap:12px;
}
.brand-logo{
  display:block;
  height:34px;
  width:auto;
  max-width:220px;
  object-fit:contain;
}
@media (max-width: 640px){
  .brand-logo{ height:28px; }
}
.mobile-menu-top .brand-logo{ height:30px; }
footer .brand-logo{ height:42px; max-width:260px; }
.brand-sub-pill--header{
  align-self:center;
}
.brand-text b{
  font-family:var(--display);
  display:block;
  color:#fff;
  font-size:26px;
  line-height:1;
  font-weight:900;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.brand-line{
  display:inline-flex;
  align-items:center;
  gap:8px;
}
/* Sub-brand pill — used on Centro vetri page to mark "Glass" */
.brand-sub-pill{
  display:inline-flex;
  align-items:center;
  padding:3px 9px;
  font-family:var(--display);
  font-size:11px;
  font-weight:900;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:#fff;
  background:var(--accent);
  border-radius:5px;
  line-height:1.2;
  position:relative;
  top:-1px;
  box-shadow:0 4px 10px rgba(182,23,28,.35);
}
.brand--glass .brand-text small{ color:#cfd0d4 }
.brand-text small{
  display:block;
  margin-top:6px;
  color:#bfc0c6;
  font-size:11px;
  letter-spacing:.24em;
  text-transform:uppercase;
}

/* Open/closed badge (injected by JS) */
.status-badge{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:4px 11px;
  border-radius:999px;
  font-family:var(--display);
  font-size:11px;
  font-weight:700;
  letter-spacing:.16em;
  text-transform:uppercase;
}
.status-badge .dot{
  width:7px;
  height:7px;
  border-radius:50%;
}

.links{
  display:flex;
  align-items:center;
  gap:30px;
  flex-wrap:wrap;
}
.links a{
  position:relative;
  color:#d7d7dc;
  font-size:13px;
  font-weight:600;
  letter-spacing:.18em;
  text-transform:uppercase;
  transition:color .25s var(--ease);
}
.links a::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:-7px;
  height:2px;
  background:var(--accent);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .35s var(--ease);
}
.links a:hover{color:#fff}
.links a:hover::after,
.links a.active::after{transform:scaleX(1)}
.links a.active{color:#fff}

/* Header phone link (desktop) */
.header-tel{display:none}
@media (min-width:981px){
  .header-tel{
    display:flex;
    align-items:center;
    gap:8px;
    color:#cdcfd5;
    font-size:13px;
    font-weight:600;
    letter-spacing:.06em;
    transition:color .25s var(--ease), transform .25s var(--ease);
    white-space:nowrap;
    padding-left:8px;
    border-left:1px solid rgba(255,255,255,.08);
  }
  .header-tel:hover{color:#fff;transform:translateX(-1px)}
  .header-tel i{width:14px;height:14px}
}

/* Old .hero rules superseded by Hero rebuild section below */
.hero .lead{
  color:#dadbdf;
  margin-top:24px;
  max-width:710px;
}
.hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:16px;
  margin-top:34px;
}

.btn{
  font-family:var(--body);
  display:inline-flex;
  align-items:center;
  gap:14px;
  padding:18px 26px;
  border-radius:999px;
  font-weight:600;
  font-size:15px;
  letter-spacing:.02em;
  cursor:pointer;
  border:none;
  transition:transform .28s var(--ease), box-shadow .28s var(--ease), background .28s var(--ease);
}
.btn:hover{transform:translateY(-3px)}
.btn-primary{
  background:#fff;
  color:#111;
  box-shadow:0 14px 30px rgba(0,0,0,.18);
}
.btn-primary:hover{box-shadow:0 18px 36px rgba(0,0,0,.22)}
.btn-secondary{
  color:#111;
  border:1px solid #ddd;
  background:#fff;
}
.btn-accent{
  background:var(--accent);
  color:#fff;
  box-shadow:0 14px 30px rgba(182,23,28,.28);
}
.btn-accent:hover{
  background:var(--accent-dark);
  box-shadow:0 18px 38px rgba(182,23,28,.34);
}
.circle{
  width:36px;
  height:36px;
  border-radius:50%;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:var(--accent);
  color:#fff;
}
.btn-secondary .circle{background:#fff;color:#111}
.btn-accent .circle{background:#fff;color:var(--accent)}

.trust-band{
  position:relative;
  z-index:4;
  margin-top:-38px;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.trust-item{
  padding:24px;
  background:rgba(255,255,255,.96);
  border:1px solid rgba(255,255,255,.55);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border-radius:24px;
  box-shadow:var(--shadow);
  will-change:transform, box-shadow, border-color;
  transition:transform .45s var(--ease), box-shadow .45s var(--ease), border-color .45s var(--ease), background .45s var(--ease);
}
.trust-item:hover{
  transform:translateY(-8px);
  box-shadow:0 22px 56px rgba(0,0,0,.12);
}
.trust-item strong{
  font-family:var(--display);
  display:block;
  font-size:21px;
  font-weight:900;
  letter-spacing:.01em;
  text-transform:uppercase;
  margin-bottom:8px;
}
.trust-item p{
  font-size:15px;
  color:var(--muted);
}

.grid-2{
  display:grid;
  grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);
  gap:34px;
  align-items:stretch;
}
.panel{
  padding:38px;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow-soft);
}
.media-card{
  position:relative;
  overflow:hidden;
  border-radius:var(--radius);
  border:1px solid var(--line);
  background:var(--surface);
  box-shadow:var(--shadow);
}
.media-card img{
  width:100%;
  height:100%;
  min-height:520px;
  object-fit:cover;
  transition:transform 1.1s var(--ease-soft);
}
.media-card:hover img{transform:scale(1.05)}
.media-overlay{
  position:absolute;
  left:22px;
  right:22px;
  bottom:22px;
  padding:18px 20px;
  border-radius:18px;
  background:rgba(10,10,12,.45);
  color:#fff;
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
}
.media-overlay strong{
  font-family:var(--display);
  display:block;
  font-size:17px;
  font-weight:900;
  letter-spacing:.06em;
  text-transform:uppercase;
}
.media-overlay span{
  display:block;
  margin-top:4px;
  font-size:14px;
  color:#dadbe0;
}

.section-head{
  display:flex;
  justify-content:space-between;
  align-items:end;
  gap:32px;
  margin-bottom:48px;
  padding-bottom:6px;
  position:relative;
}
.section-head .text{max-width:580px;flex:0 1 580px}
.section-head > div:first-child{flex:1 1 auto;min-width:0}
.section-head h2{margin-bottom:0}

/* Decorative section divider — sits between major blocks for visual breath */
.section-divider{
  display:flex;
  align-items:center;
  justify-content:center;
  padding:22px 0;
  gap:14px;
}
.section-divider::before,
.section-divider::after{
  content:"";
  display:block;
  width:64px;
  height:1px;
  background:linear-gradient(to right, transparent, var(--line), transparent);
}
.section-divider .dot{
  width:6px;
  height:6px;
  border-radius:50%;
  background:var(--accent);
  opacity:.7;
}

/* Smooth section transitions — gradient bands soften light↔dark borders */
.section-dark + .section,
.section + .section-dark,
.section-tight + .section-dark,
.section-dark + .section-tight,
.value-strip + .section-dark,
.section-dark + .manifesto-section,
.manifesto-section + .section-tight,
.manifesto-section + .section{
  position:relative;
}

.gallery-grid,.review-grid,.process-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.card,.review-card,.process-card{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:28px;
  box-shadow:var(--shadow-soft);
  transition:transform .4s var(--ease), box-shadow .4s var(--ease), border-color .4s var(--ease);
}
.card:hover{
  transform:translateY(-6px);
  box-shadow:0 28px 60px rgba(0,0,0,.13);
}
.review-card:hover,.process-card:hover{
  transform:translateY(-7px);
  box-shadow:var(--shadow);
  border-color:var(--accent-border);
}
.card{overflow:hidden}
.card img{
  width:100%;
  aspect-ratio:16/11;
  object-fit:cover;
  transition:transform .6s var(--ease);
  will-change:transform;
}
.card:hover img{transform:scale(1.05)}
.card h3,.process-card h3{
  font-family:var(--display);
  font-size:28px;
  line-height:1;
  font-weight:900;
  letter-spacing:.01em;
  text-transform:uppercase;
}
.card p,.review-card p,.process-card p{
  font-size:16px;
  color:var(--muted);
  line-height:1.6;
}
.badge{
  font-family:var(--display);
  display:inline-flex;
  align-items:center;
  padding:8px 12px;
  border-radius:999px;
  background:var(--accent-soft);
  color:var(--accent);
  font-size:12px;
  font-weight:700;
  letter-spacing:.16em;
  text-transform:uppercase;
}
.section-dark{
  background:var(--dark);
  background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.015'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
  color:#fff;
}
.section-dark .kicker{color:#b8b9be}
.sinistri-wrap{
  display:grid;
  grid-template-columns:minmax(0,1.06fr) minmax(0,.94fr);
  gap:34px;
  align-items:stretch;
}
.sinistri-card{
  padding:42px;
  background:linear-gradient(180deg,#17181b 0%, #101013 100%);
  background-image:
    url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.018'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E"),
    linear-gradient(180deg,#17181b 0%, #101013 100%);
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius);
  box-shadow:0 24px 60px rgba(0,0,0,.28);
}
.sinistri-card .lead{color:#d3d4d9;margin-top:22px}
.sinistri-list{
  list-style:none;
  display:grid;
  gap:16px;
  margin-top:26px;
}
.sinistri-list li{
  display:grid;
  grid-template-columns:52px 1fr;
  gap:16px;
  padding:18px;
  border-radius:22px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.06);
}
.sinistri-list .mini{
  width:52px;
  height:52px;
  border-radius:16px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(182,23,28,.2);
  color:#fff;
}
.sinistri-list strong{
  font-family:var(--display);
  display:block;
  font-size:19px;
  font-weight:900;
  letter-spacing:.01em;
  text-transform:uppercase;
  margin-bottom:4px;
}
.sinistri-list span{
  display:block;
  font-size:15px;
  color:#cbccd2;
}
.stats-box{
  margin-top:22px;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
}
.stat{
  padding:18px;
  border-radius:20px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.06);
}
.stat strong{
  font-family:var(--display);
  display:block;
  font-size:30px;
  line-height:1;
  font-weight:900;
  letter-spacing:.01em;
}
.stat span{
  display:block;
  margin-top:8px;
  font-size:13px;
  color:#c6c7cc;
}

.process-card{padding:28px}
.step-num{
  font-family:var(--display);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:48px;
  height:48px;
  border-radius:14px;
  background:var(--accent);
  color:#fff;
  font-weight:900;
  font-size:18px;
  margin-bottom:16px;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease);
}
.process-card:hover .step-num{
  transform:translateY(-2px) scale(1.04);
  box-shadow:0 10px 20px rgba(181,22,27,.22);
}

.gallery-item{
  position:relative;
  overflow:hidden;
  border-radius:28px;
  box-shadow:var(--shadow-soft);
  border:1px solid var(--line);
  background:var(--surface);
  transition:transform .45s var(--ease), box-shadow .45s var(--ease);
}
.gallery-item:hover{
  transform:translateY(-6px);
  box-shadow:0 28px 60px rgba(0,0,0,.13);
}
.gallery-item img{
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
  transition:transform 1s var(--ease-soft);
}
.gallery-item:hover img{transform:scale(1.05)}
.caption{
  position:absolute;
  left:18px;
  right:18px;
  bottom:18px;
  padding:16px 18px;
  border-radius:18px;
  background:rgba(9,9,10,.72);
  color:#fff;
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
.caption strong{
  font-family:var(--display);
  display:block;
  font-size:16px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.06em;
}
.caption span{
  display:block;
  margin-top:4px;
  color:#dadce1;
  font-size:14px;
}

.review-card{padding:26px;position:relative}
.review-card::before{
  content:"";
  position:absolute;
  inset:0 0 auto 0;
  height:3px;
  background:linear-gradient(90deg, transparent, rgba(181,22,27,.7), transparent);
  opacity:0;
  transition:opacity .35s var(--ease);
}
.review-card:hover::before{opacity:1}
.person{
  display:flex;
  align-items:center;
  gap:14px;
  margin-bottom:18px;
}
.avatar{
  font-family:var(--display);
  width:54px;
  height:54px;
  border-radius:50%;
  background:var(--accent-soft);
  color:var(--accent);
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
  font-size:22px;
}
.person strong{
  font-family:var(--display);
  display:block;
  font-size:21px;
  font-weight:900;
  letter-spacing:.01em;
  text-transform:uppercase;
}
.person span{
  display:block;
  color:#6a6c72;
  font-size:13px;
}
.stars{
  display:flex;
  gap:6px;
  color:var(--accent);
  margin-bottom:14px;
}

.cta-panel{
  padding:42px;
  background:linear-gradient(135deg, rgba(182,23,28,.08), rgba(255,255,255,.92));
  background-image:
    url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23b6171c' fill-opacity='0.025'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E"),
    linear-gradient(135deg, rgba(182,23,28,.08), rgba(255,255,255,.92));
  border:1px solid rgba(182,23,28,.14);
  border-radius:var(--radius);
  box-shadow:var(--shadow-soft);
}
.cta-panel .lead{margin-top:18px;max-width:620px}

.footer{
  margin-top:80px;
  background:var(--dark);
  color:#fff;
}
.footer-main{
  padding:72px 0 26px;
  display:grid;
  grid-template-columns:1.15fr .75fr .9fr;
  gap:34px;
}
.footer h4{
  font-family:var(--display);
  margin-bottom:18px;
  color:#d5d5da;
  font-size:14px;
  font-weight:700;
  letter-spacing:.22em;
  text-transform:uppercase;
}
.footer p,.footer a{
  color:#b5b6bb;
  font-size:15px;
}
.footer-nav{
  display:grid;
  gap:12px;
}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.07);
  padding:18px 0 30px;
  display:flex;
  justify-content:space-between;
  gap:18px;
  flex-wrap:wrap;
}
.footer-bottom a,.footer-bottom span{
  color:#cfd0d4;
  font-size:13px;
}
.footer-social{
  display:flex;
  gap:10px;
  margin-top:18px;
}
.footer-social a{
  width:40px;
  height:40px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:12px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.08);
  color:#fff;
  transition:transform .25s var(--ease), background .25s var(--ease);
}
.footer-social a:hover{
  transform:translateY(-2px);
  background:var(--accent);
  border-color:var(--accent);
}
.footer a{transition:color .25s var(--ease)}
.footer a:hover{color:#fff}

/* Reveal — premium accompanied scroll feel
   - Longer, softer timings
   - Blur-clear adds depth without weight
   - Stagger via data-delay applies to all variants */
.reveal{
  opacity:0;
  transform:translateY(38px);
  filter:blur(4px);
  transition:opacity .95s var(--ease-soft), transform 1s var(--ease-soft), filter .85s var(--ease-soft);
}
.reveal.visible{opacity:1;transform:none;filter:blur(0)}

.reveal-left{
  opacity:0;
  transform:translateX(-44px);
  filter:blur(4px);
  transition:opacity 1s var(--ease-soft), transform 1.05s var(--ease-soft), filter .9s var(--ease-soft);
}
.reveal-left.visible{opacity:1;transform:none;filter:blur(0)}

.reveal-right{
  opacity:0;
  transform:translateX(44px);
  filter:blur(4px);
  transition:opacity 1s var(--ease-soft), transform 1.05s var(--ease-soft), filter .9s var(--ease-soft);
}
.reveal-right.visible{opacity:1;transform:none;filter:blur(0)}

.reveal-scale{
  opacity:0;
  transform:scale(.94) translateY(18px);
  filter:blur(6px);
  transition:opacity 1.05s var(--ease-soft), transform 1.15s var(--ease-soft), filter 1s var(--ease-soft);
}
.reveal-scale.visible{opacity:1;transform:none;filter:blur(0)}

/* Stagger via data-delay — applies to ALL reveal variants */
.reveal[data-delay="1"],.reveal-left[data-delay="1"],.reveal-right[data-delay="1"],.reveal-scale[data-delay="1"]{transition-delay:.12s}
.reveal[data-delay="2"],.reveal-left[data-delay="2"],.reveal-right[data-delay="2"],.reveal-scale[data-delay="2"]{transition-delay:.24s}
.reveal[data-delay="3"],.reveal-left[data-delay="3"],.reveal-right[data-delay="3"],.reveal-scale[data-delay="3"]{transition-delay:.36s}
.reveal[data-delay="4"],.reveal-left[data-delay="4"],.reveal-right[data-delay="4"],.reveal-scale[data-delay="4"]{transition-delay:.48s}

@media (max-width:1180px){
  .grid-2,.sinistri-wrap,.footer-main{grid-template-columns:1fr}
  .trust-band,.gallery-grid,.review-grid,.process-grid,.stats-box{grid-template-columns:1fr 1fr}
}
@media (max-width:840px){
  /* Nav stays single-row between 841-980px */
  .nav{padding:0;align-items:center;flex-direction:row;justify-content:space-between;min-height:64px}
  .section-head{flex-direction:column;align-items:flex-start}
}

.media-card img{filter:brightness(1.06) contrast(1.04)}

/* Hero motion — premium entrance with subtle blur clear and longer settle */
.hero h1.reveal.visible{animation:heroRise 1.25s var(--ease-soft) both}
@keyframes heroRise{
  0%{opacity:0;transform:translateY(48px) scale(.985);filter:blur(8px)}
  55%{filter:blur(0)}
  100%{opacity:1;transform:translateY(0) scale(1);filter:blur(0)}
}
.hero .lead.reveal.visible{animation:heroLeadRise 1.1s var(--ease-soft) both .25s}
@keyframes heroLeadRise{
  0%{opacity:0;transform:translateY(22px);filter:blur(4px)}
  100%{opacity:1;transform:translateY(0);filter:blur(0)}
}
.hero .hero-actions.reveal.visible{animation:heroActionsRise 1s var(--ease-soft) both .42s}
@keyframes heroActionsRise{
  0%{opacity:0;transform:translateY(18px)}
  100%{opacity:1;transform:translateY(0)}
}
.hero .kicker.reveal.visible{animation:heroKickerFade .9s var(--ease-soft) both .1s}
@keyframes heroKickerFade{
  0%{opacity:0;transform:translateY(10px);letter-spacing:.4em}
  100%{opacity:.8;transform:translateY(0);letter-spacing:.28em}
}

.card,.review-card,.process-card,.panel,.sinistri-card,.cta-panel{
  will-change:transform, box-shadow, border-color;
}

.btn{position:relative;overflow:hidden}
.btn::after{
  content:"";
  position:absolute;
  inset:-120% auto auto -20%;
  width:40%;
  height:300%;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.38), transparent);
  transform:translateX(-180%) rotate(18deg);
  transition:transform 1s var(--ease-out-quart);
  pointer-events:none;
}
.btn:hover::after{transform:translateX(340%) rotate(18deg)}
.btn .circle{transition:transform .45s var(--ease-spring), background .25s var(--ease)}
.btn:hover .circle{transform:translateX(3px) rotate(-6deg)}

.media-overlay{transition:transform .4s var(--ease), background .4s var(--ease)}
.media-card:hover .media-overlay{
  transform:translateY(-4px);
  background:rgba(10,10,12,.58);
}

.sinistri-list li{transition:transform .35s var(--ease), background .35s var(--ease), border-color .35s var(--ease)}
.sinistri-list li:hover{
  transform:translateX(4px);
  background:rgba(255,255,255,.06);
  border-color:rgba(255,255,255,.11);
}
.sinistri-list .mini{transition:transform .35s var(--ease), background .35s var(--ease)}
.sinistri-list li:hover .mini{
  transform:scale(1.06);
  background:rgba(182,23,28,.32);
}

/* Internal pages */
.page-hero{
  padding:130px 0 70px;
  background:linear-gradient(180deg, #0d0d10 0%, #15161a 100%);
  background-image:
    url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.015'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E"),
    linear-gradient(180deg, #0d0d10 0%, #15161a 100%);
  color:#fff;
}
.page-hero .kicker{color:#b9bbc1}
.page-hero .lead{color:#d9dade;max-width:760px}
.page-hero-grid{
  display:grid;
  grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);
  gap:34px;
  align-items:end;
}
.page-hero-card{
  position:relative;
  overflow:hidden;
  border-radius:var(--radius);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 24px 60px rgba(0,0,0,.26);
  min-height:420px;
}
.page-hero-card img{
  width:100%;
  height:100%;
  min-height:420px;
  object-fit:cover;
  transition:transform .9s var(--ease);
}
.page-hero-card:hover img{transform:scale(1.04)}
.page-hero-card .media-overlay{background:rgba(10,10,12,.56)}

.breadcrumbs{
  display:flex;
  align-items:center;
  gap:8px;
  margin-bottom:14px;
  color:#9b9da4;
  font-size:13px;
  letter-spacing:.04em;
  flex-wrap:wrap;
}
.breadcrumbs a{
  color:#cfd0d4;
  transition:color .25s var(--ease);
}
.breadcrumbs a:hover{color:#fff}
.breadcrumbs span{color:#9b9da4}

.faq-wrap{display:grid;gap:16px}
.faq-item{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:24px;
  box-shadow:var(--shadow-soft);
  overflow:hidden;
  transition:border-color .28s var(--ease), box-shadow .28s var(--ease), transform .28s var(--ease);
}
.faq-item:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 34px rgba(0,0,0,.06);
}
.faq-q{
  width:100%;
  border:none;
  background:transparent;
  padding:22px 24px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
  cursor:pointer;
  text-align:left;
  transition:background .25s var(--ease);
  font-family:inherit;
}
.faq-q:hover{background:rgba(0,0,0,.015)}
.faq-q strong{
  font-family:var(--display);
  font-size:22px;
  line-height:1.1;
  font-weight:900;
  letter-spacing:.01em;
  text-transform:uppercase;
  transition:color .25s var(--ease);
}
.faq-item.open .faq-q strong{color:var(--accent)}
.faq-q .icon-box{
  width:46px;
  height:46px;
  margin:0;
  flex-shrink:0;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:14px;
  background:var(--accent-soft);
  color:var(--accent);
  transition:transform .35s var(--ease), background .25s var(--ease), box-shadow .25s var(--ease);
}
.faq-a{
  max-height:0;
  overflow:hidden;
  opacity:0;
  padding:0 24px;
  transition:max-height .45s var(--ease), opacity .3s var(--ease), padding .3s var(--ease);
}
.faq-a p{
  color:var(--muted);
  font-size:16px;
  line-height:1.6;
  transform:translateY(-6px);
  transition:transform .35s var(--ease);
}
.faq-item.open .faq-a{max-height:280px;opacity:1;padding:0 24px 22px 24px}
.faq-item.open .faq-a p{transform:translateY(0)}
.faq-item.open .faq-q .icon-box{
  transform:rotate(45deg) scale(1.04);
  background:#fff;
  color:var(--accent);
  border:1px solid rgba(181,22,27,.3);
}
.faq-item.open{border-color:rgba(181,22,27,.22)}

.policy{
  padding:42px;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow-soft);
}
.policy h2{
  font-family:var(--display);
  font-size:24px;
  font-weight:900;
  letter-spacing:.01em;
  text-transform:uppercase;
  margin-top:30px;
  margin-bottom:10px;
}
.policy h2:first-child{margin-top:0}
.policy p,.policy li{
  color:var(--muted);
  font-size:16px;
  line-height:1.6;
}
.policy p + p{margin-top:12px}
.policy ul{margin-top:10px;margin-left:20px;display:grid;gap:8px}

@media (max-width:1180px){
  .page-hero-grid{grid-template-columns:1fr}
}
/* page-hero 840px: handled in main 980px block */

/* Contact page */
.contact-page-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:26px;
}
.contact-box{
  padding:32px;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow-soft);
}
.contact-box h3{
  font-family:var(--display);
  font-size:30px;
  line-height:1;
  font-weight:900;
  letter-spacing:.01em;
  text-transform:uppercase;
  margin-bottom:10px;
}
.contact-box p{font-size:16px;color:var(--muted);line-height:1.6}
.contact-stack{display:grid;gap:16px;margin-top:22px}
.contact-row{
  display:grid;
  grid-template-columns:62px 1fr;
  gap:16px;
  align-items:start;
  padding:16px 0;
  border-bottom:1px solid #ecece8;
}
.contact-row:last-child{border-bottom:0;padding-bottom:0}
.contact-row .icon-box{
  margin:0;
  width:62px;
  height:62px;
  border-radius:20px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:var(--accent-soft);
  color:var(--accent);
  transition:transform .3s var(--ease), background .3s var(--ease);
}
.contact-row:hover .icon-box{
  transform:scale(1.04);
  background:var(--accent);
  color:#fff;
}
.contact-row span{
  font-family:var(--display);
  display:block;
  color:var(--muted-2);
  font-size:12px;
  font-weight:700;
  margin-bottom:6px;
  letter-spacing:.18em;
  text-transform:uppercase;
}
.contact-row strong{
  font-family:var(--display);
  display:block;
  font-size:22px;
  font-weight:700;
  line-height:1.22;
  letter-spacing:.01em;
}
.contact-map{
  overflow:hidden;
  border-radius:22px;
  border:1px solid var(--line);
  margin-top:22px;
  box-shadow:var(--shadow-soft);
}
.contact-map iframe{
  width:100%;
  height:280px;
  border:0;
  display:block;
  filter:grayscale(1) contrast(1.02);
  transition:filter .35s var(--ease);
}
.contact-map:hover iframe{filter:grayscale(0) contrast(1)}
.contact-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:22px}

/* Contact form */
.contact-form{display:grid;gap:14px;margin-top:18px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field{display:grid;gap:6px}
.field label{
  font-family:var(--display);
  font-size:12px;
  font-weight:700;
  color:var(--text);
  letter-spacing:.18em;
  text-transform:uppercase;
}
.field label .req{color:var(--accent);margin-left:2px}
.field input,
.field select,
.field textarea{
  width:100%;
  padding:14px 16px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:14px;
  font-family:var(--body);
  font-size:16px;
  color:var(--text);
  transition:border-color .25s var(--ease), box-shadow .25s var(--ease), background .25s var(--ease);
}
.field textarea{resize:vertical;min-height:120px;line-height:1.5}
.field input:focus,
.field select:focus,
.field textarea:focus{
  outline:none;
  border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(182,23,28,.12);
  background:#fff;
}
.field.has-error input,
.field.has-error select,
.field.has-error textarea{border-color:var(--accent);background:#fff7f7}
.field .err-msg{
  font-size:12px;
  color:var(--accent);
  font-weight:600;
  display:none;
}
.field.has-error .err-msg{display:block}
.field-checkbox{
  display:flex;
  align-items:flex-start;
  gap:10px;
  font-size:14px;
  color:var(--muted);
  cursor:pointer;
  user-select:none;
}
.field-checkbox input{
  width:18px;
  height:18px;
  margin-top:2px;
  accent-color:var(--accent);
}
.field-checkbox a{color:var(--accent);text-decoration:underline}
.form-status{
  display:none;
  padding:14px 18px;
  border-radius:14px;
  font-size:15px;
  font-weight:600;
}
.form-status.show{display:block}
.form-status.ok{
  background:#e7f5ec;
  color:#0e6b3b;
  border:1px solid #b9e1c7;
}
.form-status.err{
  background:#fdecec;
  color:#8c1014;
  border:1px solid #f5c5c7;
}

@media (max-width:1180px){.contact-page-grid{grid-template-columns:1fr}}
@media (max-width:640px){.form-row{grid-template-columns:1fr}}

/* ====================================================================
   HERO REBUILD (desktop)
   ==================================================================== */
.hero{
  position:relative;
  height:100vh;
  height:100svh;
  display:flex;
  align-items:center;
  background:var(--dark);
  color:#fff;
  overflow:hidden;
}
.hero-media{
  position:absolute;
  inset:0;
  background:url('img/index.hero.webp') center 35%/cover no-repeat;
  transform:scale(1.03);
  z-index:0;
  will-change:transform;
}
.hero-media::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(to top, rgba(9,9,11,.95) 0%, rgba(9,9,11,.6) 38%, rgba(9,9,11,.18) 76%, transparent 100%),
    linear-gradient(to right, rgba(9,9,11,.55) 0%, transparent 60%);
  z-index:1;
}
.hero-rule{
  position:absolute;
  top:104px;
  left:0;
  width:100%;
  height:1px;
  background:linear-gradient(to right, transparent, rgba(255,255,255,.16) 22%, rgba(255,255,255,.16) 78%, transparent);
  z-index:2;
}
.hero-corner{
  position:absolute;
  top:124px;
  left:max(32px, calc((100vw - var(--max)) / 2));
  display:inline-flex;
  align-items:center;
  gap:12px;
  color:rgba(255,255,255,.78);
  font-family:var(--display);
  font-size:11px;
  font-weight:700;
  letter-spacing:.26em;
  text-transform:uppercase;
  z-index:3;
}
.live-dot{
  width:8px;
  height:8px;
  border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 0 4px rgba(182,23,28,.22);
  animation:pulseDot 2s ease-in-out infinite;
  flex-shrink:0;
  transition:background .35s var(--ease-soft), box-shadow .35s var(--ease-soft);
}
@keyframes pulseDot{
  0%,100%{box-shadow:0 0 0 4px rgba(182,23,28,.22);transform:scale(1)}
  50%{box-shadow:0 0 0 9px rgba(182,23,28,.04);transform:scale(1.08)}
}
/* Closed state — silenced dot, slightly muted text */
.hero-corner.is-closed{ color:rgba(255,255,255,.6) }
.hero-corner.is-closed .live-dot{
  background:rgba(255,255,255,.45);
  box-shadow:none;
  animation:none;
  transform:scale(.92);
}
.hero-stage{
  position:relative;
  z-index:3;
  width:100%;
}
.hero-inner{
  max-width:920px;
  padding:60px 0 30px;
}
.accent-word{
  position:relative;
  color:var(--accent);
  display:inline-block;
}
/* Squiggle underline under "COME ERA" — minimal & elegant: 2 soft humps, thinner stroke */
.title-xl .accent-word::after{
  content:"";
  position:absolute;
  left:-1.5%;
  right:-1.5%;
  bottom:-0.14em;
  height:0.22em;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 240 10' preserveAspectRatio='none'><path d='M2 5 C 60 1, 120 9, 180 5 S 234 3, 238 5' fill='none' stroke='%23b6171c' stroke-width='2.2' stroke-linecap='round'/></svg>");
  background-repeat:no-repeat;
  background-size:100% 100%;
  background-position:center;
  pointer-events:none;
  transform-origin:left center;
  transform:scaleX(0);
  transition:transform 1.1s var(--ease-soft);
  opacity:.92;
  will-change:transform;
}
.hero h1.reveal.visible .accent-word::after{
  transform:scaleX(1);
  transition-delay:.55s;
}
.hero-quote{
  position:absolute;
  right:max(32px, calc((100vw - var(--max)) / 2));
  bottom:140px;
  z-index:4;
  width:300px;
  padding:20px 22px;
  border-radius:22px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.14);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  color:#fff;
}
.hero-quote .stars{
  color:var(--accent);
  margin-bottom:8px;
}
.hero-quote .stars i{ width:14px; height:14px }
.hero-quote p{
  font-family:var(--display);
  font-size:16px;
  font-weight:700;
  line-height:1.28;
  margin-bottom:14px;
  letter-spacing:.005em;
}
.hero-quote .who{
  display:flex;
  align-items:center;
  gap:10px;
  border-top:1px solid rgba(255,255,255,.14);
  padding-top:12px;
  font-size:12px;
  color:rgba(255,255,255,.78);
  letter-spacing:.04em;
}
.hero-quote .who-avatar{
  width:30px;
  height:30px;
  border-radius:50%;
  background:rgba(182,23,28,.78);
  color:#fff;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-family:var(--display);
  font-size:13px;
  font-weight:900;
}
.hero-quote .who-text{
  font-family:var(--body);
  letter-spacing:.04em;
  font-weight:500;
}
.hero-scroll-cue{
  position:absolute;
  bottom:110px;
  left:max(32px, calc((100vw - var(--max)) / 2));
  z-index:4;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
  color:rgba(255,255,255,.55);
  font-family:var(--display);
  font-size:10px;
  font-weight:700;
  letter-spacing:.3em;
  text-transform:uppercase;
}
.hero-scroll-cue .line{
  display:block;
  width:1px;
  height:42px;
  background:linear-gradient(to bottom, rgba(255,255,255,.55), transparent);
  animation:scrollLine 1.6s ease-in-out infinite;
}
@keyframes scrollLine{
  0%,100%{transform:scaleY(.4);transform-origin:top}
  50%{transform:scaleY(1);transform-origin:top}
}
.hero-marquee{
  position:absolute;
  bottom:0;
  left:0;
  width:100%;
  z-index:4;
  background:linear-gradient(to top, rgba(0,0,0,.62), transparent);
  padding:18px 0;
  overflow:hidden;
  -webkit-mask-image:linear-gradient(to right, transparent 0%, #000 5%, #000 95%, transparent 100%);
  mask-image:linear-gradient(to right, transparent 0%, #000 5%, #000 95%, transparent 100%);
}
.marquee-track{
  display:flex;
  gap:0;
  width:max-content;
  animation:marquee 38s linear infinite;
}
.marquee-track > div{
  display:flex;
  align-items:center;
  gap:30px;
  padding-right:30px;
  font-family:var(--display);
  font-size:13px;
  font-weight:700;
  color:rgba(255,255,255,.7);
  letter-spacing:.22em;
  text-transform:uppercase;
  flex-shrink:0;
}
.marquee-track i{
  font-style:normal;
  color:var(--accent);
  font-size:11px;
}
@keyframes marquee{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}

/* ====================================================================
   COUNTER BAND
   ==================================================================== */
.counter-band{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}
.counter{
  padding:30px 24px;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow-soft);
  text-align:center;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), border-color .35s var(--ease);
}
.counter:hover{
  transform:translateY(-4px);
  border-color:var(--accent-border);
  box-shadow:0 0 0 1px var(--accent-border), 0 14px 30px var(--accent-glow);
}
.counter strong{
  font-family:var(--display);
  display:block;
  font-size:clamp(34px, 4vw, 56px);
  font-weight:900;
  line-height:1;
  letter-spacing:.01em;
  color:var(--accent);
  transition:transform .45s var(--ease-spring);
}
.counter:hover strong{ transform:translateY(-2px) scale(1.02) }
.counter strong em{ font-style:normal }
.counter span{
  display:block;
  margin-top:12px;
  font-size:14px;
  color:var(--muted);
  letter-spacing:.02em;
  line-height:1.5;
}

/* ====================================================================
   BENTO SERVICES (home)
   ==================================================================== */
.bento-services{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  grid-auto-rows:minmax(240px, auto);
  gap:18px;
}
.bento-tile{
  position:relative;
  overflow:hidden;
  border-radius:var(--radius);
  background:var(--surface);
  border:1px solid var(--line);
  box-shadow:var(--shadow-soft);
  display:flex;
  flex-direction:column;
  transition:transform .4s var(--ease), box-shadow .4s var(--ease), border-color .4s var(--ease);
}
.bento-tile:hover{
  transform:translateY(-6px);
  box-shadow:0 24px 60px rgba(0,0,0,.13);
  border-color:var(--accent-border);
}
.bento-hero{
  grid-column:span 2;
  grid-row:span 2;
  min-height:520px;
  background:var(--dark);
  border-color:rgba(255,255,255,.08);
  color:#fff;
}
.bento-bg{
  position:absolute;
  inset:0;
  z-index:0;
}
.bento-bg img{
  width:100%;
  height:100%;
  object-fit:cover;
  filter:brightness(.5) saturate(1.05);
  transition:transform .9s var(--ease);
}
.bento-hero:hover .bento-bg img{ transform:scale(1.06) }
.bento-hero::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(13,13,16,.36) 0%, rgba(13,13,16,.86) 100%);
  z-index:1;
}
.bento-content{
  position:relative;
  z-index:2;
  padding:36px;
  display:flex;
  flex-direction:column;
  gap:14px;
  height:100%;
  justify-content:flex-end;
}
.bento-num{
  font-family:var(--display);
  font-size:11px;
  font-weight:700;
  color:rgba(255,255,255,.55);
  letter-spacing:.26em;
  text-transform:uppercase;
}
.bento-num-small{
  font-family:var(--display);
  font-size:11px;
  font-weight:700;
  color:var(--muted-2);
  letter-spacing:.22em;
  text-transform:uppercase;
  margin-bottom:4px;
}
.bento-badge{
  align-self:flex-start;
  background:rgba(255,255,255,.08);
  color:#fff;
  border:1px solid rgba(255,255,255,.16);
}
.bento-tile h3{
  font-family:var(--display);
  font-size:clamp(28px, 3.3vw, 50px);
  font-weight:900;
  line-height:.92;
  letter-spacing:.01em;
  text-transform:uppercase;
  color:#fff;
}
.bento-small h3{
  color:var(--text);
  font-size:clamp(22px, 2.2vw, 30px);
}
.bento-tile p{
  color:rgba(255,255,255,.85);
  font-size:16px;
  line-height:1.55;
  max-width:480px;
}
.bento-small p{
  color:var(--muted);
  font-size:15px;
  line-height:1.6;
}
.bento-list{
  list-style:none;
  display:grid;
  gap:8px;
  margin:6px 0;
}
.bento-list li{
  display:flex;
  align-items:center;
  gap:10px;
  color:rgba(255,255,255,.95);
  font-size:15px;
}
.bento-list li i{ width:16px; height:16px; color:var(--accent); flex-shrink:0 }
.bento-link{
  align-self:flex-start;
  display:inline-flex;
  align-items:center;
  gap:6px;
  color:#fff;
  font-weight:600;
  font-size:14px;
  letter-spacing:.04em;
  margin-top:8px;
  transition:gap .25s var(--ease), color .25s var(--ease);
}
.bento-link i{ width:16px; height:16px }
.bento-link:hover{ gap:12px }
.bento-small .bento-link{ color:var(--accent) }
.bento-small .bento-link:hover{ color:var(--accent-dark) }
.bento-icon{
  width:54px;
  height:54px;
  border-radius:16px;
  background:var(--accent-soft);
  color:var(--accent);
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:10px;
  transition:transform .35s var(--ease), background .35s var(--ease);
}
.bento-tile:hover .bento-icon{
  transform:rotate(-6deg) scale(1.06);
  background:var(--accent);
  color:#fff;
}
.bento-small{
  grid-column:span 2;
  grid-row:span 1;
  background:var(--surface);
  padding:30px;
  min-height:240px;
  gap:8px;
}
.bento-wide{
  grid-column:span 4;
  grid-row:span 1;
  background:var(--dark);
  color:#fff;
  border-color:rgba(255,255,255,.08);
  padding:30px 38px;
  min-height:auto;
}
.bento-wide h4{
  font-family:var(--display);
  font-size:clamp(20px, 2.4vw, 28px);
  font-weight:900;
  line-height:1.05;
  letter-spacing:.01em;
  text-transform:uppercase;
  color:#fff;
}
.bento-wide p{
  color:rgba(255,255,255,.78);
  font-size:15px;
  margin-top:6px;
}
.bento-cta-content{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  height:100%;
}

/* ====================================================================
   SERVICE ROWS (servizi page)
   ==================================================================== */
.service-rows{
  display:grid;
  gap:90px;
}
.service-row,
.service-row-reverse{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:48px;
  align-items:center;
}
.service-row-reverse .service-row-content{ order:2 }
.service-row-reverse .service-row-media{ order:1 }
.service-row-media{
  position:relative;
  overflow:hidden;
  border-radius:var(--radius);
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  aspect-ratio:4/3;
}
.service-row-media img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .8s var(--ease);
}
.service-row-media:hover img{ transform:scale(1.04) }
.service-row-media-tag{
  position:absolute;
  bottom:18px;
  left:18px;
  display:inline-flex;
  align-items:center;
  padding:8px 14px;
  border-radius:999px;
  background:rgba(13,13,16,.78);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  color:#fff;
  font-family:var(--display);
  font-size:11px;
  font-weight:700;
  letter-spacing:.22em;
  text-transform:uppercase;
}
.service-row-num{
  font-family:var(--display);
  font-size:11px;
  font-weight:700;
  color:var(--accent);
  letter-spacing:.26em;
  text-transform:uppercase;
  margin-bottom:14px;
}
.service-row-content h3{
  font-family:var(--display);
  font-size:clamp(28px, 3.6vw, 52px);
  font-weight:900;
  line-height:.92;
  letter-spacing:.01em;
  text-transform:uppercase;
  margin-bottom:20px;
}
.service-row-content p{
  font-size:17px;
  color:var(--muted);
  line-height:1.6;
}
.service-row-list{
  list-style:none;
  margin-top:22px;
  display:grid;
  gap:10px;
}
.service-row-list li{
  display:flex;
  align-items:center;
  gap:12px;
  font-size:15px;
  color:var(--text);
}
.service-row-list li i{
  width:18px;
  height:18px;
  color:var(--accent);
  flex-shrink:0;
}

/* ====================================================================
   SERVICE MINI (other services on servizi page)
   ==================================================================== */
.service-mini-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:22px;
}
.service-mini{
  padding:30px;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow-soft);
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), border-color .35s var(--ease);
}
.service-mini:hover{
  transform:translateY(-4px);
  border-color:var(--accent-border);
  box-shadow:0 0 0 1px var(--accent-border), 0 18px 40px var(--accent-glow);
}
.service-mini-icon{
  width:54px;
  height:54px;
  border-radius:16px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:var(--accent-soft);
  color:var(--accent);
  margin-bottom:16px;
  transition:transform .35s var(--ease);
}
.service-mini:hover .service-mini-icon{
  transform:rotate(-6deg) scale(1.06);
  background:var(--accent);
  color:#fff;
}
.service-mini-num{
  font-family:var(--display);
  font-size:11px;
  font-weight:700;
  color:var(--accent);
  letter-spacing:.22em;
  text-transform:uppercase;
  margin-bottom:6px;
}
.service-mini h3{
  font-family:var(--display);
  font-size:24px;
  line-height:1.05;
  font-weight:900;
  letter-spacing:.01em;
  text-transform:uppercase;
  margin-bottom:10px;
}
.service-mini p{
  font-size:15px;
  color:var(--muted);
  line-height:1.6;
}

/* ====================================================================
   FAB GROUP (floating action buttons)
   ==================================================================== */
.fab-group{
  position:fixed;
  bottom:28px;
  right:28px;
  z-index:940;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.fab{
  width:54px;
  height:54px;
  border-radius:50%;
  border:none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  cursor:pointer;
  box-shadow:0 14px 30px rgba(0,0,0,.20);
  transition:transform .25s var(--ease), background .25s var(--ease), box-shadow .25s var(--ease);
}
.fab:hover{ transform:translateY(-3px) }
.fab i{ width:22px; height:22px }
.fab-whatsapp{ background:var(--whatsapp) }
.fab-whatsapp:hover{ background:#1ebe5a }
.fab-call{
  background:var(--accent);
  display:none;
}
.fab-call:hover{ background:var(--accent-dark) }
.fab-top{
  background:rgba(13,13,16,.92);
  opacity:0;
  pointer-events:none;
  transform:translateY(15px);
  transition:opacity .3s var(--ease), transform .3s var(--ease), background .25s var(--ease);
}
.fab-top.show{
  opacity:1;
  pointer-events:auto;
  transform:translateY(0);
}
.fab-top:hover{ background:var(--accent) }

/* ====================================================================
   COOKIE BANNER
   ==================================================================== */
.cookie-banner{
  position:fixed;
  left:24px;
  bottom:24px;
  width:min(440px, calc(100% - 48px));
  z-index:950;
  padding:22px 24px;
  background:rgba(255,255,255,.985);
  border:1px solid var(--line);
  border-radius:22px;
  box-shadow:0 22px 60px rgba(0,0,0,.18);
  transform:translateY(20px);
  opacity:0;
  pointer-events:none;
  transition:transform .4s var(--ease), opacity .4s var(--ease);
}
.cookie-banner.show{
  transform:translateY(0);
  opacity:1;
  pointer-events:auto;
}
.cookie-banner h4{
  font-family:var(--display);
  font-size:16px;
  font-weight:900;
  letter-spacing:.06em;
  text-transform:uppercase;
  margin-bottom:6px;
  color:var(--text);
}
.cookie-banner p{
  font-size:14px;
  color:var(--muted);
  line-height:1.55;
  margin-bottom:14px;
}
.cookie-banner a{
  color:var(--accent);
  text-decoration:underline;
}
.cookie-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.cookie-actions .btn{
  padding:12px 18px;
  font-size:14px;
  flex:1;
  justify-content:center;
  min-height:auto;
}

/* ====================================================================
   ERROR PAGE (404)
   ==================================================================== */
.error-page{
  background:linear-gradient(180deg, #0d0d10, #15161a);
  background-image:
    url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.018'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E"),
    linear-gradient(180deg, #0d0d10, #15161a);
  color:#fff;
  min-height:80vh;
  display:flex;
  align-items:center;
  padding:120px 0;
}
.error-page .kicker{ color:rgba(255,255,255,.6) }
.error-page .lead{ color:rgba(255,255,255,.78); margin-top:18px; max-width:620px }
.error-page .hero-actions{ margin-top:34px }
.error-code{
  font-family:var(--display);
  display:block;
  font-size:clamp(80px, 16vw, 220px);
  font-weight:900;
  line-height:.9;
  letter-spacing:-.02em;
  background:linear-gradient(180deg, rgba(182,23,28,.95), rgba(182,23,28,.18));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  margin-top:14px;
}
.error-inner{ max-width:780px }

/* ====================================================================
   VALUE STRIP — quick promises grid
   ==================================================================== */
.value-strip{
  padding:60px 0;
  background:linear-gradient(180deg, var(--bg) 0%, #efefea 100%);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.value-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:18px;
}
.value-item{
  position:relative;
  padding:26px 24px;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:22px;
  box-shadow:var(--shadow-soft);
  transition:transform .4s var(--ease-soft), box-shadow .4s var(--ease-soft), border-color .4s var(--ease-soft);
}
.value-item::before{
  content:"";
  position:absolute;
  top:0;left:0;
  width:42px;
  height:3px;
  background:var(--accent);
  border-radius:0 0 4px 0;
  transform-origin:left;
  transform:scaleX(.4);
  transition:transform .5s var(--ease-soft);
}
.value-item:hover{
  transform:translateY(-5px);
  border-color:var(--accent-border);
  box-shadow:0 0 0 1px var(--accent-border), 0 18px 42px var(--accent-glow);
}
.value-item:hover::before{ transform:scaleX(1) }
.value-icon{
  width:48px;
  height:48px;
  border-radius:14px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:var(--accent-soft);
  color:var(--accent);
  margin-bottom:14px;
  transition:transform .35s var(--ease-spring), background .25s var(--ease);
}
.value-item:hover .value-icon{ transform:rotate(-6deg) scale(1.05) }
.value-item strong{
  font-family:var(--display);
  display:block;
  font-size:18px;
  font-weight:900;
  letter-spacing:.01em;
  text-transform:uppercase;
  margin-bottom:6px;
}
.value-item p{
  font-size:14px;
  color:var(--muted);
  line-height:1.55;
}

/* ====================================================================
   MANIFESTO — editorial quote section
   ==================================================================== */
.manifesto-section{
  padding:80px 0;
  background:var(--dark);
  background-image:
    url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.018'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E"),
    var(--dark);
  color:#fff;
  position:relative;
  overflow:hidden;
}
.manifesto-section::before{
  content:"";
  position:absolute;
  top:-120px;
  right:-120px;
  width:380px;
  height:380px;
  background:radial-gradient(circle, rgba(182,23,28,.18), transparent 70%);
  pointer-events:none;
}
.manifesto{
  position:relative;
  max-width:880px;
  margin:0 auto;
  text-align:center;
}
.manifesto-mark{
  width:48px !important;
  height:48px !important;
  color:var(--accent);
  margin:0 auto 24px;
  display:inline-block;
  opacity:.85;
}
.manifesto h2{
  color:#fff;
  font-family:var(--display);
  font-size:clamp(28px, 4.6vw, 58px);
  font-weight:900;
  line-height:1.04;
  letter-spacing:.01em;
  text-transform:uppercase;
  margin-bottom:22px;
}
.manifesto h2 em{
  font-style:normal;
  color:var(--accent);
  position:relative;
  display:inline-block;
}
.manifesto .lead{
  color:rgba(255,255,255,.78);
  font-size:clamp(16px, 1.6vw, 19px);
  line-height:1.65;
  margin:0 auto;
  max-width:640px;
}
.manifesto-attribution{
  margin-top:28px;
  display:inline-flex;
  align-items:center;
  gap:14px;
  color:rgba(255,255,255,.55);
  font-family:var(--display);
  font-size:11px;
  font-weight:700;
  letter-spacing:.28em;
  text-transform:uppercase;
}
.manifesto-attribution::before,
.manifesto-attribution::after{
  content:"";
  display:inline-block;
  width:36px;
  height:1px;
  background:rgba(255,255,255,.3);
}

/* ====================================================================
   PRINCIPLES — values grid with icons
   ==================================================================== */
.principles-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:20px;
}
.principle-card{
  position:relative;
  padding:32px 28px;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:24px;
  box-shadow:var(--shadow-soft);
  overflow:hidden;
  transition:transform .4s var(--ease-soft), box-shadow .4s var(--ease-soft), border-color .4s var(--ease-soft);
}
.principle-card::after{
  content:"";
  position:absolute;
  bottom:-60px;
  right:-60px;
  width:140px;
  height:140px;
  border-radius:50%;
  background:radial-gradient(circle, var(--accent-glow), transparent 70%);
  opacity:0;
  transition:opacity .5s var(--ease-soft);
  pointer-events:none;
}
.principle-card:hover{
  transform:translateY(-6px);
  border-color:var(--accent-border);
  box-shadow:0 0 0 1px var(--accent-border), 0 22px 50px var(--accent-glow);
}
.principle-card:hover::after{ opacity:1 }
.principle-num{
  font-family:var(--display);
  display:block;
  font-size:11px;
  font-weight:700;
  color:var(--accent);
  letter-spacing:.26em;
  text-transform:uppercase;
  margin-bottom:18px;
}
.principle-icon{
  width:54px;
  height:54px;
  border-radius:16px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:var(--accent-soft);
  color:var(--accent);
  margin-bottom:18px;
  transition:transform .4s var(--ease-spring), background .25s var(--ease);
}
.principle-card:hover .principle-icon{
  transform:rotate(-6deg) scale(1.06);
  background:var(--accent);
  color:#fff;
}
.principle-card h3{
  font-family:var(--display);
  font-size:21px;
  line-height:1.05;
  font-weight:900;
  letter-spacing:.01em;
  text-transform:uppercase;
  margin-bottom:10px;
}
.principle-card p{
  font-size:15px;
  color:var(--muted);
  line-height:1.6;
}

/* ====================================================================
   MILESTONES — vertical timeline (chi siamo)
   ==================================================================== */
.milestones{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:0;
  position:relative;
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:var(--surface);
  overflow:hidden;
  box-shadow:var(--shadow-soft);
}
.milestone{
  padding:36px 28px;
  position:relative;
  border-right:1px solid var(--line);
  transition:background .35s var(--ease-soft);
}
.milestone:last-child{ border-right:none }
.milestone:hover{ background:#fafaf6 }
.milestone-year{
  font-family:var(--display);
  font-size:13px;
  font-weight:900;
  letter-spacing:.22em;
  color:var(--accent);
  text-transform:uppercase;
  margin-bottom:14px;
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.milestone-year::before{
  content:"";
  width:8px;
  height:8px;
  background:var(--accent);
  border-radius:50%;
  display:inline-block;
}
.milestone strong{
  font-family:var(--display);
  display:block;
  font-size:20px;
  font-weight:900;
  line-height:1.1;
  letter-spacing:.01em;
  text-transform:uppercase;
  margin-bottom:10px;
  color:var(--text);
}
.milestone p{
  font-size:14px;
  color:var(--muted);
  line-height:1.55;
}

/* ====================================================================
   SERVICE ROW DECORATIONS (servizi visual upgrades)
   ==================================================================== */
.service-row-stat{
  display:inline-flex;
  align-items:center;
  gap:12px;
  margin-top:24px;
  padding:14px 18px;
  background:var(--accent-soft);
  border-radius:14px;
  color:var(--accent);
}
.service-row-stat strong{
  font-family:var(--display);
  font-size:24px;
  font-weight:900;
  line-height:1;
  letter-spacing:.01em;
}
.service-row-stat span{
  font-size:13px;
  color:var(--accent-dark);
  line-height:1.3;
  max-width:180px;
}

/* ====================================================================
   FORM SPINNER
   ==================================================================== */
.spinner{
  display:inline-block;
  width:14px;
  height:14px;
  border:2px solid rgba(255,255,255,.3);
  border-top-color:#fff;
  border-radius:50%;
  margin-left:6px;
  vertical-align:middle;
  animation:spin .8s linear infinite;
}
@keyframes spin{ to{ transform:rotate(360deg) } }

/* ====================================================================
   MOBILE SYSTEM — Complete responsive rules (Luxury Optimized)
   Viewport references: 390×844 (iPhone 14), 430×932 (iPhone 14 Plus), 375×667 (iPhone SE)
   Breakpoints: 980 · 840 · 760 · 640 · 560 · 480 · 400
   ==================================================================== */

/* ---- 980px: tablet / large phone ---- */
@media (max-width:980px){
  .container{width:min(var(--max),calc(100% - 40px))}
  .section{padding:36px 0}
  .section-tight{padding:24px 0}
  .nav{min-height:64px;padding:0;flex-direction:row;align-items:center;justify-content:space-between;gap:0}
  .brand-text small{display:none}
  .brand-text b{font-size:21px}
  .brand-mark span{width:8px;height:8px}
  .brand{gap:10px}
  .title-lg{font-size:clamp(28px,8vw,48px);line-height:.94}
  .title-md{font-size:clamp(22px,6.5vw,32px);line-height:.98}
  .lead{font-size:17px;line-height:1.62;max-width:100%}
  .text{font-size:16px;line-height:1.62}
  .kicker{font-size:11px;letter-spacing:.24em;margin-bottom:10px;gap:8px}
  .kicker::before{width:18px;height:1px}
  .hero{height:100svh;align-items:center}
  .hero-media{
    background:url('img/index.hero.webp') center 35%/cover no-repeat;
    animation:none;
    transform:none;
  }
  .hero-media::after{
    background:
      linear-gradient(to top, rgba(9,9,11,.99) 0%, rgba(9,9,11,.9) 26%, rgba(9,9,11,.55) 56%, rgba(9,9,11,.14) 84%, transparent 100%),
      linear-gradient(to right, rgba(9,9,11,.68) 0%, transparent 68%);
  }
  .hero-rule{display:none}
  .hero-corner{top:16px;left:20px;font-size:9px;letter-spacing:.2em;gap:8px}
  .hero-inner{max-width:100%;padding:76px 0 22px}
  .hero .kicker{font-size:10px;letter-spacing:.22em;margin-bottom:10px;color:rgba(255,255,255,.55)}
  .hero .title-xl{font-size:clamp(40px,11vw,62px);line-height:.92}
  .hero .lead{margin-top:14px;font-size:17px;line-height:1.62;max-width:100%}
  .hero-actions{margin-top:20px;display:grid;grid-template-columns:1fr 1fr;gap:10px}
  .hero-actions .btn:first-child{grid-column:1/-1}
  .hero-quote{display:none}
  .hero-scroll-cue{display:none}
  .hero-marquee{padding:12px 0}
  .marquee-track > div{font-size:11px;letter-spacing:.17em;gap:22px;padding-right:22px}
  .page-hero{padding:78px 0 40px}
  .page-hero .lead{font-size:17px;line-height:1.62;max-width:100%}
  .page-hero-grid{grid-template-columns:1fr;gap:22px}
  .page-hero-card{min-height:230px}
  .page-hero-card img{min-height:230px}
  .grid-2,.sinistri-wrap,.page-hero-grid,.process-grid,.gallery-grid,.review-grid,
  .contact-page-grid,
  .value-grid,.principles-grid,.milestones{grid-template-columns:1fr;gap:14px}
  .value-strip{padding:24px 0}
  .value-item{padding:18px 18px}
  .value-item strong{font-size:16px}
  .manifesto-section{padding:32px 0}
  .manifesto-mark{width:36px !important;height:36px !important;margin-bottom:16px}
  .manifesto h2{font-size:clamp(22px,7.5vw,36px);line-height:1.06;margin-bottom:16px}
  .manifesto-attribution{margin-top:18px;font-size:10px;letter-spacing:.22em;gap:10px}
  .manifesto-attribution::before,.manifesto-attribution::after{width:24px}
  .principle-card{padding:22px 20px;border-radius:18px}
  .principle-card h3{font-size:18px}
  .milestones{border-radius:18px}
  .milestone{padding:22px 20px;border-right:none;border-bottom:1px solid var(--line)}
  .milestone:last-child{border-bottom:none}
  .trust-band{grid-template-columns:1fr;gap:10px;margin-top:0}
  .trust-item{padding:16px 18px;border-radius:18px}
  .trust-item strong{font-size:17px;margin-bottom:4px}
  .trust-item p{font-size:14px;line-height:1.5}
  .stats-box{grid-template-columns:repeat(3,1fr);gap:9px}
  .stat{padding:12px 8px;border-radius:14px;text-align:center}
  .stat strong{font-size:21px;line-height:1}
  .stat span{font-size:10px;margin-top:4px;letter-spacing:.02em}
  .counter-band{grid-template-columns:1fr 1fr;gap:12px}
  .counter{padding:22px 14px;border-radius:20px}
  .panel,.review-card,.process-card,.cta-panel,
  .contact-box,.policy{padding:20px}
  .sinistri-card{padding:22px}
  .media-card,.page-hero-card,.gallery-item,.card,.review-card,.process-card,
  .faq-item,.contact-box{border-radius:20px}
  .media-card img,.page-hero-card img{min-height:230px}
  .card img,.gallery-item img{aspect-ratio:16/9}
  .media-overlay,.caption{left:12px;right:12px;bottom:12px;padding:12px 14px;border-radius:14px}
  .media-overlay strong,.caption strong{font-size:13px}
  .media-overlay span,.caption span{font-size:12px;line-height:1.4}
  .card p,.review-card p,.process-card p,
  .contact-box p,.faq-a p,.policy p,.policy li{font-size:15px;line-height:1.62}
  .btn{min-height:50px;padding:14px 20px;font-size:15px}
  .circle{width:30px;height:30px}
  .field input, .field select, .field textarea { 
    padding: 16px 20px; 
    border-radius: 16px; 
    font-size: 16px !important; 
    background: #fafafa;
  }
  .section-head{margin-bottom:10px;gap:0;flex-direction:column;align-items:flex-start;padding-bottom:0}
  /* Reset flex-basis on flex-column children — desktop uses 580px which becomes height on mobile */
  .section-head > div:first-child{flex:initial;min-width:0;width:100%}
  .section-head p,.section-head .text{max-width:100%;margin-top:8px;flex:initial}
  /* Tighter line-accent spacing on mobile — desktop uses 18px */
  .line-accent{margin-top:8px}
  /* Title-lg margin reset inside headings */
  .section-head h2{margin-top:0}
  .card h3,.process-card h3,.contact-box h3{font-size:20px}
  .faq-q strong{font-size:19px}
  .badge{font-size:11px;padding:6px 10px;letter-spacing:.1em}
  .sinistri-list{gap:10px}
  .sinistri-list li{grid-template-columns:40px 1fr;gap:10px;padding:13px;border-radius:15px}
  .sinistri-list .mini{width:40px;height:40px;border-radius:12px}
  .sinistri-list strong{font-size:16px;line-height:1.1}
  .sinistri-list span{font-size:13px;line-height:1.45}
  .step-num{width:40px;height:40px;border-radius:11px;margin-bottom:10px;font-size:15px}
  .faq-q{padding:16px 18px}
  .faq-q .icon-box{width:36px;height:36px;border-radius:11px}
  .faq-a,.faq-item.open .faq-a{padding-left:18px;padding-right:18px}
  .faq-item.open .faq-a{padding-bottom:16px}
  .contact-row{grid-template-columns:48px 1fr;gap:12px;padding:12px 0}
  .contact-row .icon-box{width:48px;height:48px;border-radius:14px}
  .contact-row span{font-size:10px;letter-spacing:.14em}
  .contact-row strong{font-size:17px;line-height:1.25}
  .contact-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}
  .contact-map iframe{height:215px;min-height:215px}
  .cta-panel .hero-actions{display:grid;grid-template-columns:1fr;gap:10px}
  .service-rows{gap:50px}
  .service-row,.service-row-reverse{grid-template-columns:1fr;gap:20px}
  .service-row-reverse .service-row-media{order:0}
  .service-row-reverse .service-row-content{order:0}
  .footer{margin-top:24px}
  .footer-main{grid-template-columns:1fr;padding:28px 0 14px;gap:16px}
  .footer p,.footer a{font-size:14px;line-height:1.6}
  .footer-bottom{padding:12px 0 18px;gap:8px}
  /* Mobile reveals — kept active, distance & duration reduced.
     Specificity raised to avoid clash with .visible without !important. */
  .js-ready .reveal:not(.visible){transform:translateY(16px);filter:blur(2px);transition-duration:.65s}
  .js-ready .reveal-left:not(.visible){transform:translateX(-22px);filter:blur(2px);transition-duration:.7s}
  .js-ready .reveal-right:not(.visible){transform:translateX(22px);filter:blur(2px);transition-duration:.7s}
  .js-ready .reveal-scale:not(.visible){transform:scale(.97) translateY(10px);filter:blur(3px);transition-duration:.7s}
  .fab-call{display:inline-flex}
  .fab-group{right:14px;bottom:100px;gap:10px}
  .fab{width:50px;height:50px}
  .fab i{width:20px;height:20px}
}

/* ---- 560px: standard phones ---- */
@media (max-width:560px){
  .container{width:min(var(--max),calc(100% - 24px))}
  .title-xl{font-size:clamp(32px,11vw,44px);line-height:.95}
  .title-lg{font-size:clamp(26px,9.5vw,36px);line-height:.98}
  .title-md{font-size:clamp(20px,7.5vw,28px);line-height:1}
  .kicker{font-size:10px;letter-spacing:0.15em;margin-bottom:6px}
  .lead, .text{font-size:16px;line-height:1.7;letter-spacing:-0.01em}
  .brand-text b{font-size:18px}
  .section{padding:30px 0}
  .section-tight{padding:20px 0}
  .section-head{margin-bottom:6px;gap:0}
  .section-head p,.section-head .text{margin-top:6px}
  .line-accent{margin-top:6px}
  .hero{height:100svh;align-items:center;justify-content:flex-start}
  .hero-media{background-position:center 20%}
  .hero-corner{display:none}
  .hero-inner{padding:0;margin-bottom:24px}
  .hero .kicker{font-size:9px;letter-spacing:.18em}
  .hero .lead{font-size:15px;margin-top:12px}
  .hero-actions{margin-top:16px;grid-template-columns:1fr;gap:12px}
  .hero-actions .btn:first-child{grid-column:auto}
  .hero-actions .btn{min-height:54px}
  .mobile-menu-inner{
    background:rgba(13, 13, 16, 0.85); 
    backdrop-filter:blur(25px); 
    -webkit-backdrop-filter:blur(25px);
  }
  .mobile-menu-nav{overflow-y:auto; padding-bottom:20px;}
  .mobile-menu-nav a{font-size:32px;padding:18px 0}
  .page-hero{padding:60px 0 26px}
  .page-hero .title-lg{font-size:clamp(22px,9.5vw,32px)}
  .page-hero-card{display:none}
  .breadcrumbs{font-size:11px;margin-bottom:10px}
  .panel, .review-card, .process-card, .cta-panel,
  .contact-box, .policy { padding:24px 20px; border-radius:20px; }
  .sinistri-card{padding:16px}
  .trust-item{padding:13px 15px}
  .stats-box{gap:6px}
  .stat{padding:10px 6px;border-radius:12px}
  .stat strong{font-size:17px}
  .stat span{font-size:9px}
  .counter-band{gap:10px}
  .counter{padding:16px 10px;border-radius:16px}
  .counter strong{font-size:clamp(24px,8.5vw,38px)}
  .counter span{font-size:11px;margin-top:5px}
  .service-rows{gap:36px}
  .service-row,.service-row-reverse{gap:16px}
  .process-card h3{font-size:18px}
  .step-num{width:36px;height:36px;border-radius:10px;font-size:14px;margin-bottom:8px}
  .faq-q{padding:14px 16px}
  .faq-q strong{font-size:16px}
  .faq-q .icon-box{width:34px;height:34px;border-radius:10px}
  .faq-a p{font-size:14px}
  .faq-item.open .faq-a{padding-bottom:14px}
  .contact-box h3{font-size:20px}
  .contact-actions{grid-template-columns:1fr}
  .contact-map{margin-top:12px}
  .contact-map iframe{height:185px;min-height:185px}
  .hero-actions .btn,
  .cta-panel .hero-actions .btn,
  .contact-actions .btn{width:100%;justify-content:center}
  .footer-main{padding:28px 0 12px;gap:16px}
  .footer-bottom{flex-direction:column;text-align:center;gap:5px;font-size:12px}
  .footer-social a{width:38px;height:38px}
  .cookie-banner{left:8px;right:8px;bottom:8px;padding:15px}
  .cookie-actions .btn{width:100%}
}

@media (max-width:480px){
  .counter-band{grid-template-columns:1fr 1fr;gap:8px}
}

/* Tablet: value-grid 2 columns */
@media (max-width:1180px) and (min-width:761px){
  .value-grid{grid-template-columns:1fr 1fr}
  .principles-grid{grid-template-columns:1fr 1fr}
  .milestones{grid-template-columns:1fr 1fr}
  .milestone{border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
  .milestone:nth-child(2n){border-right:none}
  .milestone:nth-last-child(-n+2){border-bottom:none}
}

@media (max-width:400px){
  .container{width:calc(100% - 20px)}
  .brand-text b{font-size:16px}
  .hero .title-xl{font-size:clamp(30px,13vw,44px)}
  .title-lg{font-size:clamp(22px,10vw,32px)}
}

/* Menu Toggle & Mobile Menu logic */
.menu-toggle{
  display:none;
  width:52px;
  height:52px;
  border:none;
  border-radius:16px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:6px;
  cursor:pointer;
  transition:transform .25s var(--ease), background .25s var(--ease), border-color .25s var(--ease);
}
.menu-toggle:hover{
  transform:translateY(-1px);
  background:rgba(255,255,255,.09);
  border-color:rgba(255,255,255,.18);
}
.menu-toggle span{
  display:block;
  width:18px;
  height:2px;
  border-radius:999px;
  background:#fff;
}

.mobile-menu{
  position:fixed;
  inset:0;
  z-index:999;
  opacity:0;
  pointer-events:none;
  background:rgba(8,8,10,.78);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  transition:opacity .35s var(--ease);
}
.mobile-menu.open{opacity:1;pointer-events:auto}
.mobile-menu-inner{
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,#0d0d10 0%, #15161a 100%);
  transform:translateY(-18px);
  opacity:0;
  transition:transform .4s var(--ease), opacity .4s var(--ease);
  display:flex;
  flex-direction:column;
  padding:20px;
}
.mobile-menu.open .mobile-menu-inner{transform:translateY(0);opacity:1}
.mobile-menu-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
}
.mobile-close{
  width:52px;
  height:52px;
  border:none;
  border-radius:16px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  position:relative;
  cursor:pointer;
}
.mobile-close span{
  position:absolute;
  left:50%;
  top:50%;
  width:18px;
  height:2px;
  border-radius:999px;
  background:#fff;
}
.mobile-close span:first-child{transform:translate(-50%,-50%) rotate(45deg)}
.mobile-close span:last-child{transform:translate(-50%,-50%) rotate(-45deg)}

.mobile-menu-nav{display:grid;gap:8px;margin-top:44px}
.mobile-menu-nav a{
  font-family:var(--display);
  color:#fff;
  font-size:38px;
  line-height:1;
  font-weight:900;
  letter-spacing:.01em;
  text-transform:uppercase;
  padding:14px 0;
  border-bottom:1px solid rgba(255,255,255,.08);
  opacity:0;
  transform:translateY(14px);
  transition:opacity .45s var(--ease-soft), transform .55s var(--ease-soft), color .25s var(--ease);
}
.mobile-menu.open .mobile-menu-nav a{opacity:1;transform:none}
.mobile-menu.open .mobile-menu-nav a:nth-child(1){transition-delay:.14s}
.mobile-menu.open .mobile-menu-nav a:nth-child(2){transition-delay:.22s}
.mobile-menu.open .mobile-menu-nav a:nth-child(3){transition-delay:.30s}
.mobile-menu.open .mobile-menu-nav a:nth-child(4){transition-delay:.38s}
.mobile-menu-nav a:hover{opacity:.85;transform:translateX(4px)}
.mobile-menu-foot{margin-top:auto;display:grid;gap:12px;opacity:0;transform:translateY(14px);transition:opacity .45s var(--ease-soft) .42s, transform .55s var(--ease-soft) .42s}
.mobile-menu.open .mobile-menu-foot{opacity:1;transform:none}
.mobile-menu-foot .btn{width:100%;justify-content:center}

@media (max-width: 980px){
  .menu-toggle{display:flex}
  .links{display:none}
  .header-tel{display:none !important}
}
@media (min-width: 981px){
  .mobile-menu{display:none}
}

/* Lenis */
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto !important}
.lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain}
.lenis.lenis-stopped{overflow:hidden}
.lenis.lenis-scrolling iframe{pointer-events:none}

/* Reveal fallback */
.reveal,.reveal-left,.reveal-right,.reveal-scale{opacity:1;transform:none}
.js-ready .reveal{opacity:0;transform:translateY(28px)}
.js-ready .reveal-left{opacity:0;transform:translateX(-36px)}
.js-ready .reveal-right{opacity:0;transform:translateX(36px)}
.js-ready .reveal-scale{opacity:0;transform:scale(.94)}
.js-ready .reveal.visible,.js-ready .reveal-left.visible,
.js-ready .reveal-right.visible,.js-ready .reveal-scale.visible{opacity:1;transform:none}

.mobile-menu:not(.open){opacity:0;pointer-events:none}

/* Horizontal scroll (Showcase) */
.horizontal-showcase{
  position:relative;
  min-height:var(--horizontal-height, 180vh);
  background:linear-gradient(180deg,#0d0d10 0%, #16171b 100%);
  background-image:
    url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.018'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E"),
    linear-gradient(180deg,#0d0d10 0%, #16171b 100%);
  color:#fff;
  overflow:clip;
  --h-progress:0;
}
/* Background parallax glow — drifts across the section as user scrolls through it */
.horizontal-showcase::before{
  content:"";
  position:absolute;
  top:50%;
  left:15%;
  width:min(520px, 80vw);
  height:min(520px, 80vw);
  margin-top:-260px;
  margin-left:-260px;
  background:radial-gradient(circle, rgba(182,23,28,.18), transparent 65%);
  pointer-events:none;
  z-index:0;
  transform:translate3d(calc(var(--h-progress, 0) * 60vw), 0, 0);
  transition:transform .15s linear;
  will-change:transform;
}
.horizontal-sticky{
  position:sticky;
  top:0;
  min-height:100vh;
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:94px 0 74px;
  z-index:1;
}
.horizontal-head{
  display:flex;
  justify-content:space-between;
  align-items:end;
  gap:28px;
  margin-bottom:34px;
}
.horizontal-head .kicker{color:#b9bbc1}
.horizontal-head .text{max-width:560px;color:#d9dade}
.horizontal-viewport{width:100%;overflow:visible;contain:layout paint}
.horizontal-track{
  display:flex;
  gap:24px;
  width:max-content;
  padding-left:max(32px, calc((100vw - var(--max)) / 2));
  padding-right:max(32px, calc((100vw - var(--max)) / 2));
  transform:translate3d(0,0,0);
  will-change:transform;
}
.h-card{
  flex:0 0 clamp(300px, 34vw, 470px);
  min-height:360px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding:30px;
  border-radius:var(--radius);
  background:linear-gradient(145deg, rgba(255,255,255,.11), rgba(255,255,255,.045));
  border:1px solid rgba(255,255,255,.11);
  box-shadow:0 24px 60px rgba(0,0,0,.25);
  overflow:hidden;
  /* Transform/opacity NOT transitioned — they're driven by JS spotlight every frame.
     Adding a transition would lag the parallax behind the swipe. */
  transition:border-color .35s var(--ease), box-shadow .35s var(--ease);
  will-change:transform, opacity;
}
.h-card span,
.h-card h3,
.h-card p{
  transition:transform .15s linear;
  will-change:transform;
}
.h-card:hover{
  border-color:var(--accent-border);
  box-shadow:0 0 0 1px var(--accent-border), 0 24px 60px var(--accent-glow);
}
.h-card span{
  font-family:var(--display);
  display:inline-flex;
  width:60px;
  height:60px;
  align-items:center;
  justify-content:center;
  margin-bottom:auto;
  border-radius:18px;
  background:rgba(182,23,28,.22);
  color:#fff;
  font-weight:900;
  font-size:18px;
  letter-spacing:.04em;
}
.h-card h3{
  font-family:var(--display);
  margin-top:58px;
  font-size:clamp(30px,4vw,58px);
  line-height:.92;
  font-weight:900;
  letter-spacing:.01em;
  text-transform:uppercase;
}
.h-card p{
  margin-top:16px;
  max-width:380px;
  color:#d3d4d9;
  font-size:17px;
  line-height:1.55;
}
.h-card-final{
  background:linear-gradient(145deg, rgba(182,23,28,.32), rgba(255,255,255,.06));
  border-color:rgba(255,255,255,.18);
}

/* Horizontal scroll mobile — same scrolljack as desktop (vertical scroll → horizontal track).
   Card sizing/spacing adapted for small viewports. */
@media (max-width:760px){
  .horizontal-showcase::before{ width:300px; height:300px; margin-top:-150px; margin-left:-150px; left:30% }
  .horizontal-sticky{ padding:48px 0 56px }
  .horizontal-head{display:block;margin-bottom:24px}
  .horizontal-head .text{margin-top:12px}
  .horizontal-viewport{ overflow:visible; contain:layout paint }
  .horizontal-track{
    gap:14px;
    padding-left:20px;
    padding-right:20px;
  }
  .h-card{
    flex:0 0 65vw;
    min-width:240px;
    max-width:300px;
    min-height:300px;
    padding:24px;
  }
  .h-card span{width:46px;height:46px;border-radius:14px;font-size:14px}
  .h-card h3{margin-top:34px;font-size:clamp(24px,7vw,34px)}
  .h-card p{font-size:15px;margin-top:10px}
  .fab-call{display:inline-flex}
  .fab-group{right:14px;bottom:100px;gap:10px}
  .fab{width:50px;height:50px}
  /* Hide decorative section dividers on mobile — they add unnecessary vertical air */
  .section-divider{display:none}
}

/* Bento services mobile overrides */
@media (max-width:980px){
  .bento-services{grid-template-columns:1fr 1fr}
  .bento-hero{grid-column:span 2;grid-row:span 1;min-height:360px}
  .bento-wide{grid-column:span 2;padding:20px}
  .bento-cta-content{flex-direction:column;align-items:flex-start;gap:14px}
  .bento-hero .bento-content{padding:24px}
}
@media (max-width:640px){
  .bento-services{grid-template-columns:1fr;gap:12px}
  .bento-hero,.bento-wide{grid-column:span 1}
  .bento-hero{min-height:300px}
  .bento-hero .bento-content{padding:20px;gap:10px}
  .bento-tile.bento-small{padding:20px;min-height:auto}
  .bento-tile.bento-small h3{font-size:20px}
}

/* Service mini grid */
@media (max-width:760px){
  .service-mini-grid{grid-template-columns:1fr;gap:14px}
  .service-mini{padding:20px}
}

/* Contact map */
@media (max-width:500px){
  .contact-map iframe{height:185px;min-height:185px}
}

/* Footer bottom extra */
@media (max-width:480px){
  .footer-bottom{flex-direction:column;text-align:center;gap:5px}
}

/* Cookie banner */
@media (max-width:420px){
  .cookie-banner{left:8px;right:8px;bottom:8px;padding:15px}
}

/* FAB above cookie banner on mobile */
@media (max-width:560px){
  .fab-group{right:14px;bottom:100px}
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{
    animation-duration:0.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:0.01ms !important;
    scroll-behavior:auto !important;
  }
  .custom-cursor{display:none !important}
  body{cursor:auto !important}
}

/* ====================================================================
   CHAT WIDGET — floating AI assistant
   ==================================================================== */
.fab-chat{
  background:var(--dark);
  color:#fff;
  position:relative;
}
.fab-chat::after{
  content:"";
  position:absolute;
  top:6px;
  right:6px;
  width:9px;
  height:9px;
  border-radius:50%;
  background:#1e8d55;
  border:2px solid var(--dark);
  box-shadow:0 0 0 0 rgba(30,141,85,.6);
  animation:chatLive 2.4s ease-in-out infinite;
}
@keyframes chatLive{
  0%,100%{box-shadow:0 0 0 0 rgba(30,141,85,.6)}
  50%{box-shadow:0 0 0 6px rgba(30,141,85,0)}
}
.fab-chat:hover{ background:var(--accent) }
.fab-chat:hover::after{ border-color:var(--accent) }

.chat-widget{
  position:fixed;
  bottom:108px;
  right:28px;
  width:min(380px, calc(100vw - 32px));
  height:min(560px, calc(100vh - 160px));
  z-index:945;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:22px;
  box-shadow:0 28px 70px rgba(0,0,0,.22);
  display:flex;
  flex-direction:column;
  overflow:hidden;
  opacity:0;
  transform:translateY(16px) scale(.97);
  transform-origin:bottom right;
  pointer-events:none;
  transition:opacity .35s var(--ease-soft), transform .4s var(--ease-soft);
}
.chat-widget.open{
  opacity:1;
  transform:none;
  pointer-events:auto;
}

.chat-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:14px 16px;
  background:var(--dark);
  color:#fff;
  flex-shrink:0;
}
.chat-head-info{
  display:flex;
  align-items:center;
  gap:12px;
  min-width:0;
}
.chat-avatar{
  width:38px;
  height:38px;
  border-radius:50%;
  background:linear-gradient(135deg, var(--accent) 0%, var(--accent-dark) 100%);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  position:relative;
  font-family:var(--display);
  font-size:13px;
  font-weight:900;
  letter-spacing:.04em;
  color:#fff;
  flex-shrink:0;
}
.chat-avatar-dot{
  position:absolute;
  width:10px;
  height:10px;
  bottom:-1px;
  right:-1px;
  background:#1e8d55;
  border-radius:50%;
  border:2px solid var(--dark);
}
.chat-head-text{ min-width:0 }
.chat-head-text strong{
  font-family:var(--display);
  display:block;
  font-size:14px;
  font-weight:900;
  letter-spacing:.04em;
  text-transform:uppercase;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.chat-head-text small{
  display:block;
  font-size:11px;
  color:rgba(255,255,255,.65);
  margin-top:2px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.chat-close{
  width:32px;
  height:32px;
  border-radius:10px;
  border:none;
  background:rgba(255,255,255,.08);
  color:#fff;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  transition:background .25s var(--ease), transform .25s var(--ease);
  flex-shrink:0;
}
.chat-close:hover{ background:rgba(255,255,255,.16); transform:rotate(90deg) }
.chat-close i{ width:16px; height:16px }

.chat-messages{
  flex:1 1 auto;
  min-height:0; /* required for overflow to work inside a flex column */
  overflow-y:auto;
  -webkit-overflow-scrolling:touch; /* iOS momentum scroll */
  overscroll-behavior:contain; /* don't bubble scroll to page when reaching edges */
  padding:16px 14px 8px;
  background:var(--bg);
  display:flex;
  flex-direction:column;
  gap:10px;
  scroll-behavior:smooth;
  scrollbar-width:thin;
  scrollbar-color:var(--line) transparent;
}
.chat-messages::-webkit-scrollbar{ width:6px }
.chat-messages::-webkit-scrollbar-thumb{ background:var(--line); border-radius:3px }
.chat-msg{
  display:flex;
  max-width:88%;
  opacity:0;
  transform:translateY(6px);
  animation:chatMsgIn .35s var(--ease-soft) forwards;
}
@keyframes chatMsgIn{
  to{ opacity:1; transform:none }
}
.chat-msg-bot{ align-self:flex-start }
.chat-msg-user{ align-self:flex-end }
.chat-msg-bubble{
  padding:10px 14px;
  border-radius:16px;
  font-family:var(--body);
  font-size:14px;
  line-height:1.5;
  background:var(--surface);
  color:var(--text);
  border:1px solid var(--line);
  box-shadow:0 2px 8px rgba(0,0,0,.04);
  white-space:pre-wrap;
  word-wrap:break-word;
  overflow-wrap:break-word;
}
.chat-msg-user .chat-msg-bubble{
  background:var(--accent);
  color:#fff;
  border-color:var(--accent);
  border-bottom-right-radius:4px;
}
.chat-msg-bot .chat-msg-bubble{ border-bottom-left-radius:4px }
.chat-msg-typing .chat-msg-bubble{
  display:inline-flex;
  gap:5px;
  padding:14px 16px;
}
.chat-msg-typing span{
  width:6px;
  height:6px;
  border-radius:50%;
  background:var(--muted-2);
  animation:chatDot 1.2s ease-in-out infinite;
}
.chat-msg-typing span:nth-child(2){ animation-delay:.15s }
.chat-msg-typing span:nth-child(3){ animation-delay:.30s }
@keyframes chatDot{
  0%,80%,100%{ transform:scale(.6); opacity:.4 }
  40%{ transform:scale(1); opacity:1 }
}

.chat-form{
  display:flex;
  align-items:center;
  gap:8px;
  padding:10px 12px;
  background:var(--surface);
  border-top:1px solid var(--line);
  flex-shrink:0;
}
.chat-form input{
  flex:1;
  min-width:0;
  padding:11px 16px;
  border-radius:22px;
  border:1px solid var(--line);
  background:var(--bg);
  font-family:var(--body);
  font-size:15px;
  color:var(--text);
  outline:none;
  transition:border-color .25s var(--ease), box-shadow .25s var(--ease), background .25s var(--ease);
}
.chat-form input::placeholder{ color:var(--muted-2) }
.chat-form input:focus{
  border-color:var(--accent);
  background:var(--surface);
  box-shadow:0 0 0 3px rgba(182,23,28,.1);
}
.chat-send{
  width:40px;
  height:40px;
  border-radius:50%;
  background:var(--accent);
  color:#fff;
  border:none;
  cursor:pointer;
  flex-shrink:0;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  transition:transform .3s var(--ease-spring), background .25s var(--ease);
}
.chat-send:hover{ background:var(--accent-dark); transform:scale(1.06) }
.chat-send:disabled{ opacity:.5; cursor:not-allowed; transform:none }
.chat-send i{ width:16px; height:16px }

.chat-disclaimer{
  font-size:10.5px;
  color:var(--muted-2);
  text-align:center;
  padding:6px 12px 10px;
  background:var(--surface);
  border-top:1px solid var(--line);
  flex-shrink:0;
  letter-spacing:.02em;
}

/* Mobile: bottom sheet style */
@media (max-width:560px){
  .chat-widget{
    bottom:0;
    right:0;
    left:0;
    width:100%;
    height:78vh;
    max-height:none;
    border-radius:22px 22px 0 0;
    transform:translateY(100%);
  }
  .chat-widget.open{ transform:none }
  .chat-form input{ font-size:16px } /* prevent iOS zoom */
}

/* When chat is open on mobile, dim background */
.chat-widget.open ~ .chat-backdrop,
.chat-backdrop.show{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.45);
  z-index:944;
  opacity:1;
  transition:opacity .3s var(--ease);
}
.chat-backdrop{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.45);
  z-index:944;
  opacity:0;
  pointer-events:none;
  transition:opacity .3s var(--ease);
}
.chat-backdrop.show{ opacity:1; pointer-events:auto }
@media (min-width:561px){
  .chat-backdrop{ display:none }
}

/* ====================================================================
   MEDIA BANNER — wide cinematic image strip with text overlay
   Used on Centro vetri to bridge manifesto and process sections
   ==================================================================== */
.media-banner{
  position:relative;
  width:100%;
  height:clamp(320px, 42vw, 520px);
  overflow:hidden;
  margin:0;
}
.media-banner img{
  width:100%;
  height:100%;
  object-fit:cover;
  filter:brightness(.62) contrast(1.05);
  transform:scale(1.02);
  transition:transform 1.5s var(--ease-soft);
}
.media-banner:hover img{ transform:scale(1.06) }
.media-banner::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg, rgba(13,13,16,.78) 0%, rgba(13,13,16,.4) 55%, rgba(13,13,16,.2) 100%),
             linear-gradient(180deg, transparent 50%, rgba(13,13,16,.55) 100%);
  pointer-events:none;
}
.media-banner-overlay{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  z-index:1;
  color:#fff;
}
.media-banner-overlay .kicker{ color:rgba(255,255,255,.7) }
.media-banner-overlay .kicker::before{ background:var(--accent) }
.media-banner-overlay h3{
  font-family:var(--display);
  font-size:clamp(28px, 4.4vw, 56px);
  font-weight:900;
  line-height:.96;
  letter-spacing:.01em;
  text-transform:uppercase;
  margin-bottom:18px;
  max-width:780px;
}
.media-banner-overlay p{
  font-size:clamp(15px, 1.5vw, 18px);
  color:rgba(255,255,255,.82);
  line-height:1.6;
  max-width:560px;
}
@media (max-width:980px){
  .media-banner{ height:clamp(260px, 56vw, 380px) }
  .media-banner-overlay h3{ font-size:clamp(22px, 6.6vw, 34px); margin-bottom:12px }
  .media-banner-overlay p{ font-size:14px }
}
@media (max-width:560px){
  .media-banner{ height:280px }
}

/* ====================================================================
   PAGE: GLASS — secondary brand color is BLUE (scoped to centro-vetri.html)
   The rest of the site keeps the red --accent palette.
   ==================================================================== */
body.page-glass{
  --accent:#1e63d6;
  --accent-dark:#1850b0;
  --accent-soft:#dde6f7;
  --accent-glow:rgba(30,99,214,.15);
  --accent-border:rgba(30,99,214,.32);
}
/* Brand mark stays Italian flag (verde/bianco/rosso) on every page, including Glass.
   Only the surrounding accent (UI/typography) shifts to blue. */
/* Sub-brand "GLASS" pill — already uses var(--accent) for bg, just refresh shadow tint */
body.page-glass .brand-sub-pill{box-shadow:0 4px 10px rgba(30,99,214,.4)}
/* Buttons accent — replace hardcoded red rgba in shadows */
body.page-glass .btn-accent{box-shadow:0 14px 30px rgba(30,99,214,.28)}
body.page-glass .btn-accent:hover{box-shadow:0 18px 38px rgba(30,99,214,.34)}
/* Process step badge hover shadow */
body.page-glass .process-card:hover .step-num{box-shadow:0 10px 20px rgba(30,99,214,.22)}
/* Sinistri-list mini icon container background (blue tint) */
body.page-glass .sinistri-list .mini{background:rgba(30,99,214,.22)}
body.page-glass .sinistri-list li:hover .mini{background:rgba(30,99,214,.36)}
/* CTA panel gradient + border */
body.page-glass .cta-panel{
  background:linear-gradient(135deg, rgba(30,99,214,.09), rgba(255,255,255,.92));
  border-color:rgba(30,99,214,.16);
}
/* Manifesto section glow circle */
body.page-glass .manifesto-section::before{
  background:radial-gradient(circle, rgba(30,99,214,.18), transparent 70%);
}
/* FAB call button uses accent → auto blue. Reinforce hover shadow */
body.page-glass .fab-call{background:var(--accent)}
body.page-glass .fab-call:hover{background:var(--accent-dark)}
/* Form focus glow stays accent-driven; reinforce ring tint */
body.page-glass .field input:focus,
body.page-glass .field select:focus,
body.page-glass .field textarea:focus{
  box-shadow:0 0 0 3px rgba(30,99,214,.14);
}


/* ==========================================================================
   POST-AUDIT FIXES (footer-h, touch targets, chat-form mobile, AA tweaks)
   ========================================================================== */

/* FIX #4 — Footer headings (replace .footer h4 with .footer .footer-h)
   Inherit visual style from former h4 and apply when h4 still exists for cookie banner. */
.footer .footer-h{
  font-family:var(--display);
  font-size:14px;
  font-weight:700;
  letter-spacing:.22em;
  text-transform:uppercase;
  margin-bottom:18px;
  color:#fff;
}

/* FIX #12 — Touch target sizes */
.links a{
  padding:14px 0;
  display:inline-flex;
  align-items:center;
}
.footer-social a{
  width:44px;
  height:44px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.chat-send{
  width:44px;
  height:44px;
}
@media (max-width: 980px){
  .footer-nav a,
  .footer-bottom a,
  .breadcrumbs a{
    display:inline-block;
    padding:8px 0;
    min-height:44px;
    line-height:1.4;
  }
  /* FIX #13 — Chat form 16px font on full mobile range (anti-zoom iOS tablets too) */
  .chat-form input{ font-size:16px }
}

/* ====================================================================
   404 quicklinks (post-CTA footer of error page)
   ==================================================================== */
.error-quicklinks{
  margin-top:36px;
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:center;
  gap:12px;
  font-family:var(--display);
  font-weight:700;
  letter-spacing:.04em;
  text-transform:uppercase;
  font-size:14px;
  color:rgba(255,255,255,.6);
}
.error-quicklinks a{
  color:rgba(255,255,255,.85);
  text-decoration:none;
  border-bottom:1px solid rgba(255,255,255,.18);
  padding-bottom:2px;
  transition:color .2s var(--ease), border-color .2s var(--ease);
}
.error-quicklinks a:hover{
  color:#fff;
  border-bottom-color:var(--accent);
}

/* ====================================================================
   Footer address as clickable map link
   ==================================================================== */
.footer-address{
  display:block;
  color:inherit;
  text-decoration:none;
  line-height:1.6;
}
.footer-address small{
  display:inline-block;
  margin-top:6px;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:rgba(255,255,255,.5);
  border-bottom:1px solid rgba(255,255,255,.25);
  padding-bottom:1px;
  transition:color .2s var(--ease), border-color .2s var(--ease);
}
.footer-address:hover small{
  color:#fff;
  border-bottom-color:var(--accent);
}

/* ====================================================================
   Reviews CTA (link to Google Reviews under testimonial grid)
   ==================================================================== */
.reviews-cta .btn i{
  width:18px;
  height:18px;
  margin-left:8px;
  vertical-align:middle;
}

