/* navbar.css — Estilos TopAppBar y Sidebar móvil */

/* ── Navbar ── */
#navbar {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 80px;
  z-index: 40;
  background: rgba(255, 255, 255, 0.9);
  border-bottom: 1px solid rgba(21, 101, 192, 0.1);
  box-shadow: 0 1px 4px rgba(0,0,0,0.06);
  transition: var(--transition-base);
}

.navbar-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 100%;
}

/* Marca */
.navbar-brand {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--color-primary-dark);
}

.brand-logo {
  height: 40px;
  width: auto;
  object-fit: contain;
  display: block;
}
.brand-name { font-family: var(--font-headline); font-size: 1.875rem; letter-spacing: 0.15em; padding-top: 4px; }

/* Links de escritorio */
.navbar-links {
  display: none;
  align-items: center;
  gap: 32px;
}

@media (min-width: 768px) {
  .navbar-links { display: flex; }
}

.nav-link {
  font-family: var(--font-body);
  font-weight: 600;
  color: var(--color-on-surface-variant);
  padding: 4px 8px;
  border-radius: 4px;
  transition: var(--transition-base);
}

.nav-link:hover    { color: var(--color-primary); background: rgba(21,101,192,0.05); }
.nav-link.active   { color: var(--color-primary); border-bottom: 2px solid var(--color-primary); padding-bottom: 2px; }

/* Botón hamburguesa */
.menu-toggle {
  display: flex;
  padding: 8px;
  color: var(--color-primary);
  border-radius: 50%;
  transition: var(--transition-base);
}

.menu-toggle:hover { background: rgba(21,101,192,0.05); }

@media (min-width: 768px) {
  .menu-toggle { display: none; }
}

/* ── Sidebar Móvil ── */
.mobile-sidebar {
  position: fixed;
  inset-block: 0;
  right: 0;
  width: 256px;
  background: white;
  box-shadow: -4px 0 24px rgba(0,0,0,0.12);
  z-index: 50;
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform 0.3s ease-in-out;
}

.mobile-sidebar.is-open { transform: translateX(0); }

.sidebar-header {
  display: flex;
  justify-content: flex-end;
  padding: 16px;
  border-bottom: 1px solid #f3f4f6;
}

.close-btn {
  padding: 8px;
  color: var(--color-primary-dark);
  border-radius: 50%;
  transition: var(--transition-base);
}
.close-btn:hover { background: #f3f4f6; }

.sidebar-links {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 24px;
  flex: 1;
}

.sidebar-link {
  font-family: var(--font-body);
  font-weight: 600;
  color: var(--color-on-surface-variant);
  padding: 12px 0;
  border-bottom: 1px solid #f3f4f6;
  transition: color 0.2s;
}
.sidebar-link:hover { color: var(--color-primary); }

.sidebar-footer-info {
  padding: 24px;
  background: var(--color-surface-low);
  text-align: center;
}
.sidebar-footer-label { font-size: 0.875rem; color: var(--color-on-surface-variant); }
.sidebar-footer-phone  { font-weight: 700; color: var(--color-primary); }

/* ── Overlay ── */
.menu-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.3);
  z-index: 40;
  transition: opacity 0.3s;
}
.menu-overlay.hidden { display: none; }
