/* ════════════════════════════════════════════════════════════
   nav.css — Navbar, search, theme toggle
   Geo Aerial Consulting
   ════════════════════════════════════════════════════════════ */

.nav{
  position:sticky;top:0;z-index:200;
  background:var(--bg-dark);height:66px;
  display:flex;align-items:center;
  box-shadow:0 1px 0 rgba(255,255,255,.06);
  transition:background .25s;
}
.nav-inner{display:flex;align-items:center;width:100%;max-width:1160px;margin:0 auto;padding:0 40px;gap:8px}

/* Logo */
.nav-logo{display:flex;align-items:center;flex-shrink:0;margin-right:28px}
.nav-logo img{height:36px;width:auto;object-fit:contain;filter:brightness(0) invert(1)}
.nav-logo-fallback{display:none;font-size:15px;font-weight:800;color:#fff;letter-spacing:-.2px}

/* Links */
.nav-links{display:flex;align-items:center;gap:2px;flex-wrap:nowrap}
.nav-link{font-size:13.5px;font-weight:500;color:rgba(255,255,255,.62);padding:6px 10px;border-radius:6px;transition:all .15s;white-space:nowrap;flex-shrink:0}
.nav-link:hover,.nav-link.active{color:#fff;background:rgba(255,255,255,.09)}

/* Search */
.nav-search-wrap{position:relative;margin-left:auto;display:flex;align-items:center}
.nav-search-input{
  width:0;opacity:0;overflow:hidden;
  background:var(--search-bg);border:1.5px solid transparent;
  border-radius:8px;padding:0;font-size:13.5px;color:var(--search-text);
  font-family:inherit;outline:none;transition:all .25s ease;
}
.nav-search-input::placeholder{color:var(--search-placeholder)}
.nav-search-input.open{width:220px;opacity:1;padding:7px 36px 7px 14px;border-color:var(--search-border)}
.nav-search-btn{
  position:absolute;right:8px;top:50%;transform:translateY(-50%);
  color:rgba(255,255,255,.55);padding:4px;border-radius:5px;
  transition:color .15s;display:flex;align-items:center;
}
.nav-search-input.open~.nav-search-btn,
.nav-search-btn:hover{color:rgba(255,255,255,.9)}
.nav-search-btn svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* Search trigger (when input is closed) */
.nav-search-icon-btn{
  display:flex;align-items:center;justify-content:center;
  width:36px;height:36px;border-radius:8px;
  border:1px solid rgba(255,255,255,.18);
  color:rgba(255,255,255,.65);
  transition:all .15s;flex-shrink:0;
}
.nav-search-icon-btn:hover{background:rgba(255,255,255,.1);color:#fff;border-color:rgba(255,255,255,.35)}
.nav-search-icon-btn svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.nav-search-icon-btn.hidden{display:none}

/* Search dropdown results */
.search-dropdown{
  position:absolute;top:calc(100% + 8px);right:0;width:360px;
  background:var(--bg-dark);border:1px solid rgba(255,255,255,.12);
  border-radius:12px;padding:8px;box-shadow:0 16px 48px rgba(0,0,0,.4);
  display:none;z-index:300;
}
.search-dropdown.visible{display:block}
.search-result-item{
  display:flex;align-items:center;gap:12px;
  padding:10px 12px;border-radius:8px;cursor:pointer;
  transition:background .15s;
}
.search-result-item:hover{background:rgba(255,255,255,.08)}
.search-result-item.hidden{display:none}
.search-result-icon{
  width:32px;height:32px;border-radius:7px;
  background:rgba(255,255,255,.08);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.search-result-icon svg{width:15px;height:15px;stroke:rgba(255,255,255,.6);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.search-result-title{font-size:13.5px;font-weight:600;color:#fff}
.search-result-type{font-size:11px;color:rgba(255,255,255,.38);margin-top:1px}
.search-divider{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:rgba(255,255,255,.28);padding:8px 12px 4px}
.search-divider.hidden{display:none}
.search-empty{font-size:13px;color:rgba(255,255,255,.4);padding:14px 12px;text-align:center;display:none}
.search-empty.show{display:block}

/* Right side of nav */
.nav-right{display:flex;align-items:center;gap:8px;flex-shrink:0;margin-left:12px}

/* Theme toggle */
.theme-toggle{
  display:flex;align-items:center;background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14);border-radius:8px;padding:3px;gap:1px;
}
.theme-toggle-btn{
  width:28px;height:28px;border-radius:6px;
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.45);transition:all .15s;
}
.theme-toggle-btn svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.theme-toggle-btn.active{background:rgba(255,255,255,.18);color:#fff}
.theme-toggle-btn:hover:not(.active){color:rgba(255,255,255,.75);background:rgba(255,255,255,.08)}

.nav-map-btn{
  display:flex;align-items:center;gap:6px;
  font-size:13px;font-weight:600;color:rgba(255,255,255,.72);
  border:1px solid rgba(255,255,255,.18);border-radius:7px;
  padding:7px 14px;transition:all .15s;
}
.nav-map-btn:hover{color:#fff;border-color:rgba(255,255,255,.4);background:rgba(255,255,255,.07)}
.nav-map-btn svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}

/* Mobile menu toggle (hamburger) */
.nav-menu-btn{display:none;width:38px;height:38px;border-radius:8px;border:1px solid rgba(255,255,255,.18);color:#fff;align-items:center;justify-content:center;flex-shrink:0}
.nav-menu-btn svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* CTAs that live inside the mobile hamburger menu — hidden on desktop */
.nav-mobile-cta{display:none}

/* ─── NAV DROPDOWN (ESRI Suite) ──────────────────────────── */
.nav-dropdown{position:relative}
.nav-dd-toggle{display:inline-flex;align-items:center;gap:5px;background:none;cursor:pointer}
.nav-caret{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:transform .2s}
.nav-dropdown:hover .nav-caret,.nav-dropdown.open .nav-caret{transform:rotate(180deg)}
.nav-dd-menu{
  position:absolute;top:calc(100% + 10px);left:0;width:300px;
  background:var(--bg-dark);border:1px solid rgba(255,255,255,.12);
  border-radius:12px;padding:8px;box-shadow:0 16px 48px rgba(0,0,0,.4);
  display:none;z-index:300;
}
.nav-dropdown:hover .nav-dd-menu,.nav-dropdown.open .nav-dd-menu{display:block}
.nav-dd-head{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:rgba(255,255,255,.4);padding:8px 12px 6px}
.nav-dd-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;transition:background .15s}
.nav-dd-item:hover{background:rgba(255,255,255,.08)}
.nav-dd-ic{width:32px;height:32px;border-radius:7px;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.nav-dd-ic svg{width:15px;height:15px;stroke:rgba(255,255,255,.7);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.nav-dd-tx{display:flex;flex-direction:column;gap:1px}
.nav-dd-t{font-size:13.5px;font-weight:600;color:#fff}
.nav-dd-s{font-size:11px;color:rgba(255,255,255,.42)}

/* ─── RESPONSIVE ─────────────────────────────────────────── */
/* Free up space for the 8 nav items on mid-size desktops */
@media(max-width:1120px){ .nav-map-btn{display:none} }
@media(max-width:960px){
  .nav-inner{padding:0 16px}
  .nav-search-input.open{width:180px}
  .nav-map-btn{display:none}
  .nav-menu-btn{display:flex}
  /* Declutter the top bar so the hamburger always fits on screen:
     the in-bar "Get a Quote" moves into the menu (see .nav-mobile-cta). */
  .nav-right .btn-cta{display:none}
  .nav-links{
    position:absolute;top:66px;left:0;right:0;
    flex-direction:column;align-items:stretch;gap:0;
    background:var(--bg-dark);border-top:1px solid rgba(255,255,255,.08);
    padding:8px;display:none;box-shadow:0 16px 32px rgba(0,0,0,.4);
    max-height:calc(100vh - 66px);overflow-y:auto;
  }
  .nav-links.open{display:flex}
  .nav-link{padding:12px 14px;border-radius:8px;font-size:14.5px}
  /* Order a Map + Get a Quote inside the opened menu */
  .nav-mobile-cta{display:flex;flex-direction:column;gap:8px;margin-top:8px;padding:10px 6px 4px;border-top:1px solid rgba(255,255,255,.08)}
  .nav-mobile-cta .nav-map{display:none}
  .nav-mobile-map{display:flex;align-items:center;gap:8px}
  .nav-mobile-map svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
  .nav-mobile-cta .btn-cta{display:block;text-align:center;padding:12px 14px;font-size:14.5px}
  /* Dropdown becomes an inline accordion on mobile */
  .nav-dd-toggle{width:100%;justify-content:space-between}
  .nav-dd-menu{position:static;width:auto;box-shadow:none;border:none;background:rgba(255,255,255,.04);margin:2px 0 6px;padding:6px}
  .nav-dropdown:hover .nav-dd-menu{display:none}
  .nav-dropdown.open .nav-dd-menu{display:block}
}
