/* ============================================================
   o Drone. — style.css
   CORREÇÕES: menu desktop, responsividade, galeria, contato
   ============================================================ */

:root{
  --bg-primary:#000;
  --bg-secondary:#121317;
  --text-primary:#F1EFE7;
  --text-secondary:#B8B6AE;
  --accent:#fff;
  --navbar-height:85px;
}

*{
  margin:0;
  padding:0;
  box-sizing:border-box;
  font-family:'Inter',sans-serif;
}

html{
  scroll-behavior:smooth;
}

body{
  background:#000;
  color:var(--text-primary);
  overflow-x:hidden;
}

/* ============================================================
   NAVBAR
   ============================================================ */

.navbar{
  position:fixed;
  top:0;
  left:0;
  width:100%;
  height:var(--navbar-height);
  background:#000;
  display:flex;
  align-items:center;
  z-index:1000;
  overflow:visible; /* ← permite dropdown de serviços */
  transition:all .4s ease;
}

.navbar.scrolled{
  background:rgba(0,0,0,0.88);
  backdrop-filter:blur(12px);
  box-shadow:0 8px 25px rgba(0,0,0,0.4);
  height:64px;
}

/* CONTAINER */
.nav-container{
  max-width:1200px;
  width:100%;
  margin:auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 30px;
  position:relative;
}

/* LOGO */
.logo{
  color:#fff;
  font-size:20px;
  font-weight:600;
  letter-spacing:0.12em;
  flex-shrink:0;
}

.logo-img{
  height:60px;
  width:auto;
  display:block;
}

/* ============================================================
   NAV LINKS — DESKTOP (padrão, sem media query)
   ============================================================ */

.nav-links{
  display:flex;
  align-items:center;
  gap:34px;
  /* RESET: remove estilos de mobile que vazavam para desktop */
  position:static;
  width:auto;
  height:auto;
  background:transparent;
  backdrop-filter:none;
  flex-direction:row;
  justify-content:flex-end;
  padding:0;
  right:auto;
  top:auto;
  transform:none;
  transition:none;
  z-index:auto;
}

.nav-links a{
  color:#aaa;
  text-decoration:none;
  font-size:15px;
  font-weight:500;
  letter-spacing:.05em;
  position:relative;
  transition:.3s;
  opacity:1;         /* ← era 0, deixava links invisíveis */
  transform:none;    /* ← era translateX(20px) */
  animation:none;    /* ← remove animação que bloqueava visibilidade */
}

.nav-links a:hover{
  color:#fff;
  transform:translateY(-1px);
}

/* underline animado */
.nav-links a::after{
  content:"";
  position:absolute;
  left:0;
  bottom:-8px;
  width:0;
  height:2px;
  background:#fff;
  transition:width .35s ease;
}

.nav-links a:hover::after{
  width:100%;
}

.nav-links a.active{
  color:#fff;
}

/* CTA mobile — esconde no desktop */
.mobile-only{
  display:none !important;
}

/* CTA desktop */
.desktop-cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 20px;
  border:1px solid rgba(255,255,255,.25);
  border-radius:30px;
  font-size:13px;
  font-weight:500;
  color:#fff;
  text-decoration:none;
  white-space:nowrap;
  letter-spacing:.04em;
  transition:.3s;
  flex-shrink:0;
}

.desktop-cta:hover{
  background:#fff;
  color:#000;
  border-color:#fff;
}

/* HAMBURGUER — esconde no desktop */
.menu-toggle{
  display:none;
  flex-direction:column;
  justify-content:center;
  gap:5px;
  cursor:pointer;
  z-index:1200;
  position:relative;
  background:none;
  border:none;
  padding:4px;
}

.menu-toggle span{
  width:24px;
  height:2px;
  background:#fff;
  display:block;
  transition:.4s;
}

/* animação X */
.menu-toggle.active span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.menu-toggle.active span:nth-child(2){ opacity:0; }
.menu-toggle.active span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* SCANNER ANIMATION */
.nav-scanner{
  position:absolute;
  top:0;
  left:-30%;
  width:30%;
  height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,0.1),transparent);
  animation:navScanner 8s linear infinite;
  pointer-events:none;
}

@keyframes navScanner{
  0%  { left:-30%; }
  100%{ left:130%; }
}

/* TELEMETRY LINE */
.nav-telemetry{
  position:absolute;
  bottom:0;
  left:0;
  width:100%;
  height:2px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);
  opacity:.5;
  pointer-events:none;
}

/* OVERLAY ESCURO (mobile) */
.nav-overlay{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,0.6);
  backdrop-filter:blur(6px);
  opacity:0;
  pointer-events:none;
  transition:.3s;
  z-index:1040;
}

.nav-overlay.active{
  opacity:1;
  pointer-events:auto;
}

/* SERVICE PREVIEW DROPDOWN */
.nav-service{
  position:relative;
}

.service-preview{
  position:absolute;
  top:40px;
  left:0;
  background:#111;
  border:1px solid rgba(255,255,255,.08);
  border-radius:12px;
  padding:16px;
  width:240px;
  opacity:0;
  transform:translateY(10px);
  transition:.35s;
  pointer-events:none;
  z-index:1100;
}

.preview-item{
  color:#aaa;
  font-size:14px;
  padding:6px 0;
}

.preview-item:last-child{
  padding-bottom:0;
}

.nav-service:hover .service-preview{
  opacity:1;
  transform:translateY(0);
  pointer-events:auto;
}

/* ============================================================
   MOBILE NAV — dentro de media query
   ============================================================ */

@media(max-width:768px){

  /* Mostra hamburguer */
  .menu-toggle{
    display:flex !important;
  }

  /* Esconde CTA desktop */
  .desktop-cta{
    display:none !important;
  }

  /* Mostra CTA mobile dentro do menu */
  .mobile-only{
    display:inline-flex !important;
  }

  /* Menu lateral */
  .nav-links{
    position:fixed;
    top:0;
    right:-100%;
    width:75%;
    max-width:320px;
    height:100vh;
    background:rgba(0,0,0,0.96);
    backdrop-filter:blur(20px);
    flex-direction:column;
    justify-content:center;
    align-items:flex-start;
    padding:40px 36px;
    gap:0;
    transition:.45s cubic-bezier(.77,0,.18,1);
    z-index:1050;
    overflow-y:auto;
  }

  .nav-links.open{
    right:0;
  }

  /* Links dentro do menu mobile */
  .nav-links a{
    font-size:20px;
    font-weight:500;
    color:#fff;
    padding:14px 0;
    border-bottom:1px solid rgba(255,255,255,.06);
    width:100%;
    opacity:0;
    transform:translateX(20px);
  }

  .nav-links a::after{
    display:none;
  }

  .nav-links.open a{
    animation:navItemIn .55s forwards;
  }

  .nav-links.open a:nth-child(1){ animation-delay:.08s; }
  .nav-links.open a:nth-child(2){ animation-delay:.15s; }
  .nav-links.open a:nth-child(3){ animation-delay:.22s; }
  .nav-links.open a:nth-child(4){ animation-delay:.29s; }
  .nav-links.open a:nth-child(5){ animation-delay:.36s; }
  .nav-links.open a:nth-child(6){ animation-delay:.43s; }

  @keyframes navItemIn{
    to{ opacity:1; transform:translateX(0); }
  }

  /* Dropdown de serviços no mobile */
  .nav-service{
    width:100%;
  }

  .service-preview{
    position:static;
    opacity:1;
    transform:none;
    pointer-events:auto;
    background:rgba(255,255,255,.04);
    border:none;
    border-radius:8px;
    padding:8px 12px;
    width:100%;
    margin-top:4px;
    transition:none;
  }

  .preview-item{
    font-size:13px;
    padding:5px 0;
  }

}

/* ============================================================
   HERO
   ============================================================ */

.hero{
  position:relative;
  height:100vh;
  min-height:600px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  overflow:hidden;
}

/* MAPA — absolute dentro do hero, não fixed */
#hero-map{
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
  z-index:0;
  background:#F1EFE7;
  pointer-events:auto;
}

#hero-map .leaflet-container{
  background:#F1EFE7;
}

#hero-map .leaflet-tile{
  filter:grayscale(100%) brightness(0.65) contrast(350%) saturate(0);
  mix-blend-mode:multiply;
}

.leaflet-control-attribution{
  display:none;
}

.leaflet-container img{
  max-width:none !important;
}

/* VIDEO */
.hero-video{
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
  object-fit:cover;
  z-index:1;
  pointer-events:none;
  transform:translate3d(0,0,0);
}

/* OVERLAY */
.hero-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(to bottom, rgba(255,255,255,0.2), rgba(255,255,255,0.6));
  z-index:2;
  pointer-events:none;
}

/* HERO CONTENT */
.hero-content{
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%,-50%);
  text-align:center;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  max-width:720px;
  width:90%;
  z-index:10;
  will-change:transform;
  backface-visibility:hidden;
}

.hero-content h1{
  font-size:clamp(36px, 5vw, 64px);
  font-weight:500;
  letter-spacing:-0.02em;
  line-height:1.1;
  color:#000;
  margin-bottom:22px;
  text-rendering:optimizeLegibility;
}

.hero-content p{
  font-size:clamp(16px, 2vw, 18px);
  line-height:1.7;
  color:#222;
  max-width:560px;
  margin-bottom:34px;
  font-weight:400;
}

/* BUTTONS */
.btn-primary{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:14px 32px;
  border-radius:40px;
  background:#000;
  color:#fff;
  font-size:15px;
  font-weight:500;
  letter-spacing:0.04em;
  text-transform:uppercase;
  text-decoration:none;
  transition:all .35s ease;
  box-shadow:0 8px 25px rgba(0,0,0,0.12);
}

.btn-primary:hover{
  background:#222;
  transform:translateY(-2px);
  box-shadow:0 14px 35px rgba(0,0,0,0.18);
}

.btn-nav{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:12px 20px;
  border-radius:30px;
  font-size:14px;
  font-weight:500;
  color:#fff;
  text-decoration:none;
  white-space:nowrap;
  background:#111;
  border:1px solid rgba(255,255,255,.2);
  transition:.3s;
}

.btn-nav:hover{
  background:#fff;
  color:#000;
}

/* RADAR */
.map-radar{
  position:absolute;
  inset:0;
  z-index:4;
  pointer-events:none;
}

.radar-center{
  position:absolute;
  left:50%;
  top:50%;
  width:8px;
  height:8px;
  background:#000;
  border-radius:50%;
  transform:translate(-50%,-50%);
}

.map-radar .radar-sweep{
  position:absolute;
  left:50%;
  top:50%;
  width:60vw;
  height:60vw;
  transform:translate(-50%,-50%);
  border-radius:50%;
  background:conic-gradient(rgba(0,0,0,0.12),rgba(0,0,0,0.04),transparent);
  animation:radarSweep 6s linear infinite;
}

@keyframes radarSweep{
  0%  { transform:translate(-50%,-50%) rotate(0deg); }
  100%{ transform:translate(-50%,-50%) rotate(360deg); }
}

.radar-ping{
  position:absolute;
  left:50%;
  top:50%;
  width:12px;
  height:12px;
  border:2px solid #000;
  border-radius:50%;
  transform:translate(-50%,-50%);
  animation:ping 5s infinite;
  opacity:0;
}

.radar-ping:nth-child(2){ animation-delay:1.5s; }
.radar-ping:nth-child(3){ animation-delay:3s; }

@keyframes ping{
  0%  { opacity:0.8; transform:translate(-50%,-50%) scale(0.3); }
  70% { opacity:0;   transform:translate(-50%,-50%) scale(8); }
  100%{ opacity:0; }
}

/* SCANNER LINE */
.scanner-line{
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:3px;
  background:linear-gradient(90deg,transparent,rgba(0,0,0,0.3),transparent);
  animation:scannerMove 4s linear infinite;
  z-index:5;
  pointer-events:none;
}

@keyframes scannerMove{
  0%  { top:0; }
  100%{ top:100%; }
}

/* HUD */
.hud{
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
  pointer-events:none;
  z-index:20;
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  padding:calc(var(--navbar-height) + 16px) 40px 40px;
  font-family:Inter,sans-serif;
  color:#000;
}

.hud-left, .hud-right{
  display:flex;
  flex-direction:column;
  gap:16px;
}

.hud-left{ align-items:flex-start; }
.hud-right{ align-items:flex-end; }

.hud-item{
  position:relative;
  padding:6px 0;
  font-size:12px;
  letter-spacing:.12em;
}

.hud-label{
  display:block;
  font-size:9px;
  letter-spacing:.18em;
  opacity:.5;
  margin-bottom:2px;
}

.hud-item span:last-child{
  font-weight:600;
  font-size:13px;
  letter-spacing:.08em;
}

/* ============================================================
   SECTIONS
   ============================================================ */

.section{
  padding:120px 0;
  background:#000;
}

.container{
  width:92%;
  max-width:1400px;
  margin:auto;
}

/* ============================================================
   ABOUT
   ============================================================ */

.about{
  background:#0c0c0c;
}

.about-grid{
  display:grid;
  grid-template-columns:1.2fr 1fr;
  gap:100px;
  align-items:center;
}

.about-text h2{
  font-size:clamp(28px, 3vw, 40px);
  margin-bottom:24px;
  line-height:1.2;
}

.about-text p{
  color:#B8B6AE;
  line-height:1.8;
  margin-bottom:18px;
  font-size:16px;
}

.about-stats{
  display:grid;
  grid-template-columns:1fr;
  gap:40px;
}

.stat h3{
  font-size:clamp(32px, 4vw, 42px);
  margin-bottom:8px;
}

.stat span{
  font-size:14px;
  color:#B8B6AE;
}

/* ============================================================
   SERVICES
   ============================================================ */

.services{
  background:#000;
}

.section-title{
  text-align:center;
  font-size:clamp(28px, 3vw, 40px);
  margin-bottom:80px;
  letter-spacing:-0.02em;
}

.services-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:24px;
}

.service-card{
  padding:36px 32px;
  border:1px solid rgba(255,255,255,.08);
  border-radius:20px;
  background:#0d0d0d;
  transition:.4s;
  display:flex;
  flex-direction:column;
  gap:0;
}

.service-card:hover{
  transform:translateY(-8px);
  border-color:rgba(255,255,255,.2);
  box-shadow:0 20px 60px rgba(0,0,0,.5);
}

.service-icon{
  font-size:28px;
  margin-bottom:16px;
}

.service-card h3{
  margin-bottom:14px;
  font-size:18px;
  font-weight:600;
}

.service-card p{
  color:#B8B6AE;
  line-height:1.7;
  font-size:14px;
  flex:1;
}

.service-link{
  display:inline-block;
  margin-top:20px;
  color:#fff;
  font-size:13px;
  font-weight:500;
  text-decoration:none;
  letter-spacing:.04em;
  opacity:.6;
  transition:.3s;
}

.service-link:hover{
  opacity:1;
}

/* ============================================================
   GALLERY
   ============================================================ */

.gallery{
  background:#000;
  position:relative;
  overflow:hidden;
}

.gallery-overlay{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.9);
  backdrop-filter:blur(10px);
  opacity:0;
  pointer-events:none;
  transition:.4s;
  z-index:998;
}

.gallery-overlay.active{
  opacity:1;
  pointer-events:auto;
}

.gallery-header{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  max-width:900px;
  margin:0 auto 60px auto;
  padding:0 20px;
}

.gallery-title{
  font-size:clamp(32px, 4vw, 52px);
  font-weight:500;
  letter-spacing:-0.03em;
  line-height:1.1;
  margin-bottom:14px;
  background:linear-gradient(180deg, #fff, #aaa);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}

.gallery-subtitle{
  font-size:16px;
  line-height:1.7;
  color:rgba(255,255,255,0.55);
  max-width:540px;
  letter-spacing:0.01em;
}

/* FILTROS */
.gallery-filter{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
  margin:0 auto 60px auto;
  padding:0 20px;
}

.filter-btn{
  padding:10px 18px;
  border-radius:30px;
  font-size:11px;
  letter-spacing:.12em;
  border:1px solid rgba(255,255,255,.15);
  background:transparent;
  color:#aaa;
  cursor:pointer;
  transition:all .35s cubic-bezier(.2,.8,.2,1);
  font-family:inherit;
}

.filter-btn:hover{
  color:#fff;
  border-color:#fff;
  transform:translateY(-2px);
}

.filter-btn.active{
  background:#fff;
  color:#000;
  border-color:#fff;
  box-shadow:0 6px 20px rgba(255,255,255,0.15);
}

/* GRID GALERIA */
.gallery-grid{
  column-count:3;
  column-gap:16px;
  padding:0 40px;
}

.gallery-item{
  break-inside:avoid;
  margin-bottom:16px;
  cursor:pointer;
  border-radius:14px;
  overflow:hidden;
  position:relative;
  transition:opacity .4s, transform .4s;
}

.gallery-item img{
  width:100%;
  display:block;
  transition:transform .6s ease;
}

.gallery-item-label{
  position:absolute;
  bottom:0;
  left:0;
  right:0;
  padding:28px 16px 14px;
  font-size:12px;
  font-weight:600;
  letter-spacing:.1em;
  color:#fff;
  background:linear-gradient(transparent, rgba(0,0,0,.7));
  opacity:0;
  transition:.3s;
  pointer-events:none;
}

.gallery-item:hover .gallery-item-label{
  opacity:1;
}

/* Efeito hover cinematic */
.gallery-grid:hover .gallery-item:not(:hover){
  opacity:.3;
  transform:scale(.97);
}

.gallery-item:hover{
  z-index:2;
}

.gallery-item:hover img{
  transform:scale(1.06);
}

/* POI highlight */
.gallery-item.poi-highlight{
  box-shadow:0 0 0 3px #fff;
  transform:scale(1.03);
  z-index:3;
  opacity:1 !important;
}

/* HIDE filtered */
.gallery-item.hide{
  display:none;
}

/* ACTIVE (lightbox pré-animação) */
.gallery-item.active{
  position:fixed;
  top:50%;
  left:50%;
  width:85vw;
  height:85vh;
  transform:translate(-50%,-50%);
  z-index:999;
  border-radius:20px;
  overflow:hidden;
}

.gallery-item.active img{
  width:100%;
  height:100%;
  object-fit:cover;
}

/* ============================================================
   LIGHTBOX
   ============================================================ */

.lightbox{
  position:fixed;
  inset:0;
  z-index:9999;
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:0;
  pointer-events:none;
  transition:.4s;
}

.lightbox.active{
  opacity:1;
  pointer-events:auto;
}

.lightbox-overlay{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.95);
  backdrop-filter:blur(10px);
}

.lightbox-content{
  position:relative;
  width:90vw;
  height:90vh;
  display:flex;
  align-items:center;
  justify-content:center;
}

.lightbox-image{
  max-width:100%;
  max-height:100%;
  object-fit:contain;
  border-radius:8px;
  transition:transform .4s ease;
  position:relative;
  z-index:1;
}

.lightbox-prev,
.lightbox-next{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  background:none;
  border:none;
  color:#fff;
  font-size:60px;
  cursor:pointer;
  z-index:2;
  opacity:.5;
  transition:.3s;
  line-height:1;
}

.lightbox-prev:hover,
.lightbox-next:hover{
  opacity:1;
}

.lightbox-prev{ left:20px; }
.lightbox-next{ right:20px; }

/* ============================================================
   MAP POI
   ============================================================ */

.poi{
  position:absolute;
  transform:translate(-50%, -50%);
  pointer-events:auto;
  cursor:pointer;
}

.poi-radar{
  position:relative;
  width:12px;
  height:12px;
  background:#000;
  border-radius:50%;
  box-shadow:0 0 0 2px rgba(0,0,0,.3);
}

.poi-radar::before,
.poi-radar::after{
  content:"";
  position:absolute;
  top:50%;
  left:50%;
  width:12px;
  height:12px;
  border-radius:50%;
  border:2px solid #000;
  transform:translate(-50%,-50%);
  animation:poiPulse 2.6s infinite;
}

.poi-radar::after{
  animation-delay:1.3s;
}

@keyframes poiPulse{
  0%  { transform:translate(-50%,-50%) scale(0.5); opacity:.8; }
  70% { transform:translate(-50%,-50%) scale(3);   opacity:0; }
  100%{ opacity:0; }
}

/* MAP POPUP */
.leaflet-popup-content-wrapper{
  border-radius:14px;
  box-shadow:0 20px 40px rgba(0,0,0,0.25);
  padding:0;
  overflow:hidden;
  background:#F1EFE7;
}

.leaflet-popup-tip{
  background:#F1EFE7;
}

.map-card{
  width:200px;
  font-family:Inter, sans-serif;
}

.map-card-img{
  width:100%;
  height:120px;
  object-fit:cover;
  display:block;
}

.map-card-title{
  padding:10px;
  font-size:13px;
  font-weight:600;
  color:#000;
  text-align:center;
}

/* ZOOM CONTROLS */
.leaflet-control-zoom{
  border:none !important;
  background:transparent !important;
  display:flex;
  flex-direction:column;
  gap:6px;
  margin:20px !important;
}

.leaflet-control-zoom a{
  width:40px;
  height:40px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:18px;
  font-weight:500;
  color:#000 !important;
  background:rgba(255,255,255,.8) !important;
  backdrop-filter:blur(10px);
  border-radius:10px !important;
  border:none !important;
  box-shadow:0 4px 12px rgba(0,0,0,.15) !important;
  transition:all .25s ease;
  text-decoration:none;
}

.leaflet-control-zoom a:hover{
  background:#000 !important;
  color:#fff !important;
  transform:translateY(-2px);
}

/* ============================================================
   CONTACT SECTION
   ============================================================ */

.contact{
  background:#0c0c0c;
}

.contact-grid{
  display:grid;
  grid-template-columns:1fr 1.3fr;
  gap:80px;
  align-items:start;
}

.contact-text h2{
  font-size:clamp(28px, 3vw, 40px);
  margin-bottom:20px;
  line-height:1.2;
}

.contact-text p{
  color:#B8B6AE;
  line-height:1.8;
  font-size:16px;
  margin-bottom:28px;
}

.contact-info{
  display:flex;
  flex-direction:column;
  gap:12px;
  font-size:15px;
  color:#B8B6AE;
}

.contact-info a{
  color:#B8B6AE;
  text-decoration:none;
  transition:.3s;
}

.contact-info a:hover{
  color:#fff;
}

/* FORM */
.contact-form{
  display:flex;
  flex-direction:column;
  gap:20px;
}

.form-group{
  display:flex;
  flex-direction:column;
  gap:8px;
}

.form-group label{
  font-size:12px;
  letter-spacing:.1em;
  color:#888;
  text-transform:uppercase;
}

.form-group input,
.form-group select,
.form-group textarea{
  padding:14px 16px;
  background:#111;
  border:1px solid rgba(255,255,255,.1);
  border-radius:10px;
  color:#fff;
  font-size:15px;
  font-family:inherit;
  outline:none;
  transition:.3s;
  -webkit-appearance:none;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus{
  border-color:rgba(255,255,255,.35);
  background:#181818;
}

.form-group select option{
  background:#111;
  color:#fff;
}

.form-group textarea{
  resize:vertical;
  min-height:120px;
}

.btn-submit{
  align-self:flex-start;
  cursor:pointer;
  border:none;
}

/* ============================================================
   FOOTER
   ============================================================ */

.footer{
  background:#000;
  color:#B8B6AE;
  padding:120px 0 50px;
  position:relative;
  border-top:1px solid rgba(255,255,255,.08);
  overflow:hidden;
}

.footer-grid-overlay{
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.02) 1px, transparent 1px);
  background-size:80px 80px;
  pointer-events:none;
}

.footer-glow{
  position:absolute;
  width:400px;
  height:400px;
  background:radial-gradient(circle, rgba(255,255,255,0.06), transparent 70%);
  pointer-events:none;
  top:0;
  left:0;
  transform:translate(-50%, -50%);
  transition:left .1s, top .1s;
}

.footer-container{
  max-width:1200px;
  margin:auto;
  display:grid;
  grid-template-columns:1.5fr 1fr 1fr;
  gap:60px;
  padding:0 40px;
  position:relative;
  z-index:2;
}

.footer-logo{
  font-size:20px;
  letter-spacing:.18em;
  color:#fff;
  margin-bottom:20px;
}

.footer-left p{
  line-height:1.7;
  max-width:320px;
  font-size:14px;
}

.footer-hud{
  margin-top:20px;
  display:flex;
  gap:20px;
  font-size:11px;
  letter-spacing:.14em;
  opacity:.5;
}

.footer-title{
  display:block;
  font-size:11px;
  letter-spacing:.2em;
  margin-bottom:18px;
  color:#fff;
  text-transform:uppercase;
}

.footer-center a{
  display:block;
  margin-bottom:10px;
  text-decoration:none;
  color:#B8B6AE;
  font-size:14px;
  transition:.3s;
  position:relative;
}

.footer-center a:hover{
  color:#fff;
}

.footer-right span{
  display:block;
  margin-bottom:10px;
  font-size:14px;
}

.footer-right a{
  color:#B8B6AE;
  text-decoration:none;
  transition:.3s;
}

.footer-right a:hover{
  color:#fff;
}

.footer-bottom{
  margin-top:80px;
  text-align:center;
  font-size:12px;
  opacity:.4;
}

/* Footer scanner */
.footer::before{
  content:"";
  position:absolute;
  top:0;
  left:-30%;
  width:30%;
  height:2px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,0.4),transparent);
  animation:footerScanner 6s linear infinite;
}

@keyframes footerScanner{
  0%  { left:-30%; }
  100%{ left:130%; }
}

/* ============================================================
   RESPONSIVIDADE GLOBAL
   ============================================================ */

/* TABLET */
@media(max-width:1100px){

  .services-grid{
    grid-template-columns:repeat(2,1fr);
  }

  .about-grid{
    grid-template-columns:1fr;
    gap:60px;
  }

  .contact-grid{
    grid-template-columns:1fr;
    gap:60px;
  }

}

/* TABLET PEQUENO */
@media(max-width:900px){

  .footer-container{
    grid-template-columns:1fr;
    gap:40px;
    text-align:center;
    padding:0 24px;
  }

  .footer-left p{
    margin:auto;
  }

  .footer-hud{
    justify-content:center;
  }

  .gallery-grid{
    column-count:2;
    padding:0 24px;
  }

}

/* MOBILE */
@media(max-width:768px){

  .section{
    padding:80px 0;
  }

  .hero{
    min-height:100svh;
  }

  .hero-content{
    width:92%;
    padding:0 8px;
  }

  .hud{
    padding:calc(var(--navbar-height) + 8px) 16px 16px;
  }

  .hud-item{
    font-size:9px;
  }

  .hud-item span:last-child{
    font-size:10px;
  }

  .hud-label{
    font-size:7px;
  }

  .about-text h2{
    font-size:28px;
  }

  .about-stats{
    grid-template-columns:repeat(3,1fr);
    gap:20px;
    text-align:center;
  }

  .gallery-filter{
    padding:0 16px;
  }

  .gallery-grid{
    column-count:1;
    padding:0 16px;
  }

  .contact-grid{
    grid-template-columns:1fr;
    gap:40px;
  }

  .btn-submit{
    align-self:stretch;
    text-align:center;
  }

  .footer{
    padding:80px 0 40px;
  }

  .footer-container{
    grid-template-columns:1fr;
    gap:40px;
    padding:0 20px;
    text-align:center;
  }

  .lightbox-prev{ left:10px; }
  .lightbox-next{ right:10px; }

}

/* MOBILE PEQUENO */
@media(max-width:480px){

  .services-grid{
    grid-template-columns:1fr;
  }

  .about-stats{
    grid-template-columns:1fr;
  }

}
