/* ── ALARM VISION — Global Styles ── */
body { background:#fff; color:#0B0B0B; font-family:'Inter',sans-serif; margin:0; }

@media(max-width:639px){ main { padding-bottom:64px; } }

.bg-hero {
  background-image: url('https://img.freepik.com/photos-premium/technicien-installe-camera-cctv-facade-immeuble-residentiel_179755-25164.jpg?semt=ais_hybrid&w=740&q=80');
  background-size: cover;
  background-position: center 30%;
}

.leaflet-container { height:100%; width:100%; border-radius:1rem; z-index:1; }
.hide-scrollbar::-webkit-scrollbar { display:none; }
.hide-scrollbar { -ms-overflow-style:none; scrollbar-width:none; }

@keyframes pulse-dot { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.6;transform:scale(1.3)} }
.pulse-dot { animation: pulse-dot 1.5s ease-in-out infinite; }

@keyframes typing { 0%,100%{opacity:.3} 50%{opacity:1} }
.typing span { display:inline-block; width:6px; height:6px; border-radius:50%; background:#9ca3af; margin:0 1px; animation:typing 1s ease-in-out infinite; }
.typing span:nth-child(2){animation-delay:.2s}
.typing span:nth-child(3){animation-delay:.4s}

.hero-title { font-family:'Syne',sans-serif; font-weight:800; letter-spacing:-0.03em; }
.tagline { font-size:9px; letter-spacing:0.18em; margin-top:-1px; position:relative; top:-2px; }

@media(max-width:640px){
  .bg-hero { background-position:center center; }
  nav .logo-text { font-size:16px !important; }
}
