/* Globesp Skin
   Capa de pintura única sobre la estructura existente. SOLO override
   visual: tipografía, glassmorphism, colores, radios, sombras, hover
   states. NO toca lógica ni IDs. Si se desactiva quitando este link,
   la app vuelve al diseño anterior sin perder funcionalidad. */

:root {
  --gx-bg: #0a0e17;
  --gx-bg-elev: rgba(13, 18, 30, 0.92);
  --gx-bg-elev-2: rgba(20, 28, 42, 0.96);
  --gx-card-bg: rgba(12, 16, 24, 0.74);
  --gx-card-border: rgba(255, 255, 255, 0.08);
  --gx-card-border-strong: rgba(255, 255, 255, 0.14);
  --gx-fg: #e2e8f0;
  --gx-fg-strong: #f1f5f9;
  --gx-fg-dim: #94a3b8;
  --gx-fg-mute: #64748b;
  --gx-accent: #00d4aa;
  --gx-accent-2: #00b894;
  --gx-accent-soft: rgba(0, 212, 170, 0.14);
  --gx-accent-border: rgba(0, 212, 170, 0.32);
  --gx-danger: #ef4444;
  --gx-warn: #f59e0b;
  --gx-shadow: 0 14px 40px rgba(0, 0, 0, 0.45);
  --gx-shadow-soft: 0 6px 18px rgba(0, 0, 0, 0.25);
}

/* ============ Scrollbar coherente ============ */
*::-webkit-scrollbar { width: 6px; height: 6px; }
*::-webkit-scrollbar-thumb { background: rgba(255, 255, 255, 0.12); border-radius: 999px; }
*::-webkit-scrollbar-thumb:hover { background: rgba(255, 255, 255, 0.20); }
* { scrollbar-color: rgba(255,255,255,.12) transparent; scrollbar-width: thin; }

::selection { background: rgba(0, 212, 170, 0.32); color: var(--gx-fg-strong); }

/* ============ TOPBAR (la barra superior con Panel / Zoom / Centrar) ============ */
#appShell > div.absolute.top-2 {
  top: calc(env(safe-area-inset-top, 0px) + 8px) !important;
}
#openDrawerBtn,
#quick-center,
#ui-zoom-in, #ui-zoom-out {
  background: var(--gx-bg-elev) !important;
  border: 1px solid var(--gx-card-border) !important;
  color: var(--gx-fg) !important;
  border-radius: 12px !important;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  box-shadow: var(--gx-shadow-soft) !important;
  transition: background 0.14s ease, transform 0.1s ease, border-color 0.14s ease;
}
#openDrawerBtn:hover,
#quick-center:hover,
#ui-zoom-in:hover, #ui-zoom-out:hover {
  background: rgba(20, 28, 42, 0.96) !important;
  border-color: var(--gx-card-border-strong) !important;
}
#openDrawerBtn:active,
#quick-center:active,
#ui-zoom-in:active, #ui-zoom-out:active {
  transform: scale(0.96);
}
#openDrawerBtn {
  padding: 8px 12px !important;
  gap: 8px !important;
}
#openDrawerBtn span:not(.material-icons-round) {
  font: 700 12px/1 Inter, system-ui, sans-serif !important;
  letter-spacing: 0.2px;
}
#openDrawerBtn .material-icons-round { font-size: 18px !important; }
#quick-center .material-icons-round { font-size: 18px !important; }

/* Stack de zoom: que parezca un solo botón vertical */
#appShell .glass-panel.flex {
  background: var(--gx-bg-elev) !important;
  border: 1px solid var(--gx-card-border) !important;
  border-radius: 12px !important;
  overflow: hidden;
  box-shadow: var(--gx-shadow-soft) !important;
}
#ui-zoom-in, #ui-zoom-out {
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
  width: 36px;
  height: 36px;
  padding: 0 !important;
}
#ui-zoom-in:hover, #ui-zoom-out:hover {
  background: rgba(255, 255, 255, 0.05) !important;
}

/* ============ DRAWER (panel lateral) ============ */
#sidebarDrawer {
  background: var(--gx-bg-elev) !important;
  border: 1px solid var(--gx-card-border) !important;
  border-left: none !important;
  border-radius: 0 18px 18px 0 !important;
  backdrop-filter: blur(18px) !important;
  -webkit-backdrop-filter: blur(18px) !important;
  box-shadow: var(--gx-shadow) !important;
  padding: 14px !important;
}
#sidebarDrawer .glass-panel,
#sidebarDrawer:has(.glass-panel) { background: transparent !important; }

/* Header del drawer (logo + nombre + botones) */
#sidebarDrawer > div:first-child {
  padding-bottom: 12px !important;
  border-bottom: 1px solid var(--gx-card-border) !important;
  margin-bottom: 12px !important;
}
#sidebarDrawer > div:first-child .w-9.h-9 {
  border-radius: 12px !important;
  box-shadow: 0 6px 18px rgba(0, 212, 170, 0.32);
}
#sidebarDrawer h1 {
  letter-spacing: -0.2px;
  color: var(--gx-fg-strong) !important;
}

/* Botones del header (admin, logout, close drawer) */
#btn-admin, #btn-logout, #closeDrawerBtn {
  width: 32px !important;
  height: 32px !important;
  border-radius: 9px !important;
  border: 1px solid var(--gx-card-border) !important;
  background: rgba(255, 255, 255, 0.04) !important;
  color: var(--gx-fg-dim) !important;
  transition: all 0.14s ease !important;
}
#btn-admin:hover { background: rgba(251, 191, 36, 0.14) !important; color: #fbbf24 !important; border-color: rgba(251, 191, 36, 0.36) !important; }
#btn-logout { background: rgba(239, 71, 87, 0.10) !important; color: #ff6b7a !important; border-color: rgba(239, 71, 87, 0.22) !important; }
#btn-logout:hover { background: rgba(239, 71, 87, 0.20) !important; }
#closeDrawerBtn:hover { background: rgba(255, 255, 255, 0.08) !important; color: var(--gx-fg) !important; }

/* Etiquetas de sección (USUARIOS ACTIVOS, SALAS DE CHAT, etc.) */
#sidebarDrawer label {
  font: 700 10px/1 Inter, system-ui, sans-serif !important;
  letter-spacing: 0.10em !important;
  text-transform: uppercase;
  color: var(--gx-fg-dim) !important;
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 4px 2px;
}

/* Listas de usuarios y salas */
#users-list li, #rooms-list li {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px !important;
  border-radius: 10px !important;
  font: 600 12px/1.2 Inter, system-ui, sans-serif !important;
  background: transparent !important;
  border: 1px solid transparent !important;
  color: var(--gx-fg) !important;
  cursor: pointer;
  transition: background 0.12s ease, border-color 0.12s ease;
  margin-bottom: 2px;
}
#users-list li:hover, #rooms-list li:hover {
  background: rgba(255, 255, 255, 0.04) !important;
  border-color: var(--gx-card-border) !important;
}
#rooms-list li.active {
  background: var(--gx-accent-soft) !important;
  border-color: var(--gx-accent-border) !important;
  color: var(--gx-fg-strong) !important;
  font-weight: 700 !important;
}

/* ============ Botones principales del drawer ============ */
#btn-my-location {
  background: linear-gradient(135deg, var(--gx-accent) 0%, var(--gx-accent-2) 100%) !important;
  color: var(--gx-bg) !important;
  border: none !important;
  border-radius: 12px !important;
  padding: 11px 14px !important;
  font: 700 12px/1.2 Inter, system-ui, sans-serif !important;
  box-shadow: 0 6px 18px rgba(0, 212, 170, 0.32) !important;
  transition: filter 0.14s ease, transform 0.1s ease;
}
#btn-my-location:hover { filter: brightness(1.06); }
#btn-my-location:active { transform: scale(0.99); }

#btn-center-me {
  background: rgba(255, 255, 255, 0.04) !important;
  border: 1px solid var(--gx-card-border) !important;
  border-radius: 12px !important;
  color: var(--gx-fg) !important;
  padding: 9px 12px !important;
  font: 600 12px/1.2 Inter, system-ui, sans-serif !important;
}
#btn-center-me:hover { background: rgba(255, 255, 255, 0.08) !important; }

/* ============ Búsqueda ============ */
#btn-search-mode-address, #btn-search-mode-coords {
  font: 700 11px/1 Inter, system-ui, sans-serif !important;
  letter-spacing: 0.1px;
  border-radius: 8px !important;
  transition: all 0.14s ease;
}

#map-search-input {
  background: rgba(255, 255, 255, 0.04) !important;
  border: 1px solid var(--gx-card-border) !important;
  border-radius: 10px !important;
  color: var(--gx-fg) !important;
  font: 500 13px/1.3 Inter, system-ui, sans-serif !important;
  padding: 10px 12px !important;
  transition: border-color 0.14s ease, box-shadow 0.14s ease;
}
#map-search-input:focus {
  border-color: var(--gx-accent) !important;
  box-shadow: 0 0 0 3px rgba(0, 212, 170, 0.16) !important;
  outline: none !important;
}

#btn-map-search {
  background: var(--gx-accent-soft) !important;
  border: 1px solid var(--gx-accent-border) !important;
  color: var(--gx-accent) !important;
  border-radius: 10px !important;
  padding: 9px 12px !important;
  font: 700 12px/1 Inter, system-ui, sans-serif !important;
  transition: all 0.14s ease;
}
#btn-map-search:hover { background: rgba(0, 212, 170, 0.20) !important; }

#map-search-results {
  margin-top: 6px;
}
#map-search-results > * {
  background: rgba(255, 255, 255, 0.04) !important;
  border: 1px solid var(--gx-card-border) !important;
  border-radius: 9px !important;
  padding: 8px 10px !important;
  margin-bottom: 4px !important;
}

/* ============ Chat ============ */
#current-room-label {
  font: 700 10px/1 Inter, system-ui, sans-serif !important;
  letter-spacing: 0.10em !important;
  color: var(--gx-accent) !important;
}

#chat-messages {
  background: rgba(0, 0, 0, 0.18) !important;
  border-radius: 12px !important;
  border: 1px solid var(--gx-card-border) !important;
  padding: 8px !important;
  margin-bottom: 10px;
}

#chat-text {
  background: rgba(255, 255, 255, 0.04) !important;
  border: 1px solid var(--gx-card-border) !important;
  border-radius: 999px !important;
  color: var(--gx-fg) !important;
  font: 500 13px/1.3 Inter, system-ui, sans-serif !important;
  padding-right: 50px !important; /* espacio para el botón send dentro del input */
  transition: border-color 0.14s ease, box-shadow 0.14s ease;
}
#chat-text:focus {
  border-color: var(--gx-accent) !important;
  box-shadow: 0 0 0 3px rgba(0, 212, 170, 0.16) !important;
  outline: none !important;
}

.chat-icon-btn,
label.chat-icon-btn {
  width: 36px !important;
  height: 36px !important;
  border-radius: 50% !important;
  background: rgba(255, 255, 255, 0.04) !important;
  border: 1px solid var(--gx-card-border) !important;
  color: var(--gx-fg-dim) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer;
  transition: all 0.14s ease !important;
}
.chat-icon-btn:hover {
  background: rgba(255, 255, 255, 0.08) !important;
  color: var(--gx-fg) !important;
}
.chat-icon-btn .material-icons-round { font-size: 18px !important; }

/* Estado "grabando" del botón micrófono — rojo con halo pulsante.
   Esta regla debe vencer al CSS genérico de .chat-icon-btn (que es !important),
   por eso usa selectores más específicos y también !important. */
#chat-audio.recording,
.chat-icon-btn.recording {
  background: #dc2626 !important;
  border-color: #dc2626 !important;
  color: #ffffff !important;
  animation: gx-rec-pulse 1.4s ease-in-out infinite;
}
#chat-audio.recording .material-icons-round,
.chat-icon-btn.recording .material-icons-round {
  color: #ffffff !important;
}
@keyframes gx-rec-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(220, 38, 38, 0.55); }
  50%      { box-shadow: 0 0 0 7px rgba(220, 38, 38, 0); }
}

/* Botón de envío — posicionado dentro del input de chat, redondo, gradiente
   teal. Override total para que no quede descolocado por Tailwind ni por
   estilos previos. */
#chat-send {
  position: absolute !important;
  right: 4px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 32px !important;
  height: 32px !important;
  border-radius: 50% !important;
  background: linear-gradient(135deg, #00d4aa 0%, #00b894 100%) !important;
  border: none !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  box-shadow: 0 4px 14px rgba(0, 212, 170, 0.32) !important;
  transition: filter 0.14s ease, transform 0.1s ease !important;
  cursor: pointer;
  padding: 0 !important;
}
#chat-send:hover { filter: brightness(1.08) !important; }
#chat-send:active { transform: translateY(-50%) scale(0.94) !important; }
#chat-send .material-icons-round {
  font-size: 17px !important;
  color: #0a0e17 !important;
  display: block !important;
  line-height: 1 !important;
}

/* ============ LOGIN ============ */
#login-screen { font-family: Inter, system-ui, sans-serif; }
#login-screen .login-brand { animation: gx-fade-in 0.5s ease-out; }
#login-screen h1 { letter-spacing: -0.4px; }

#login-username, #login-password {
  background: rgba(255, 255, 255, 0.05) !important;
  border: 1px solid var(--gx-card-border) !important;
  border-radius: 12px !important;
  font: 500 13px/1.3 Inter, system-ui, sans-serif !important;
  transition: border-color 0.14s ease, box-shadow 0.14s ease, background 0.14s ease;
}
#login-username:focus, #login-password:focus {
  border-color: var(--gx-accent) !important;
  box-shadow: 0 0 0 3px rgba(0, 212, 170, 0.18) !important;
  background: rgba(255, 255, 255, 0.07) !important;
  outline: none !important;
}

#btn-login {
  background: linear-gradient(135deg, var(--gx-accent) 0%, var(--gx-accent-2) 100%) !important;
  color: var(--gx-bg) !important;
  font: 800 13px/1 Inter, system-ui, sans-serif !important;
  letter-spacing: 0.2px;
  border-radius: 12px !important;
  box-shadow: 0 8px 22px rgba(0, 212, 170, 0.32) !important;
  transition: filter 0.14s ease, transform 0.1s ease !important;
}
#btn-login:hover { filter: brightness(1.07); }
#btn-login:active { transform: scale(0.99); }

@keyframes gx-fade-in {
  from { opacity: 0; transform: translateY(6px); }
  to { opacity: 1; transform: translateY(0); }
}

/* ============ LEAFLET — controles dark-glass ============ */
.leaflet-control-zoom,
.leaflet-control-layers,
.leaflet-bar {
  background: var(--gx-bg-elev) !important;
  border: 1px solid var(--gx-card-border) !important;
  border-radius: 12px !important;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  box-shadow: var(--gx-shadow-soft) !important;
  overflow: hidden;
}
.leaflet-control-zoom a,
.leaflet-bar a,
.leaflet-bar a:focus,
.leaflet-bar a:hover {
  background: transparent !important;
  color: var(--gx-fg) !important;
  border-bottom: 1px solid var(--gx-card-border) !important;
  width: 34px !important;
  height: 34px !important;
  line-height: 34px !important;
  font: 700 16px/1 Inter, system-ui, sans-serif !important;
  transition: background 0.12s ease;
}
.leaflet-control-zoom a:last-child,
.leaflet-bar a:last-child { border-bottom: none !important; }
.leaflet-control-zoom a:hover,
.leaflet-bar a:hover { background: rgba(255, 255, 255, 0.07) !important; }

/* Control de capas Leaflet → glass-card oscuro */
.leaflet-control-layers {
  padding: 0 !important;
}
.leaflet-control-layers-toggle {
  background-image: none !important;
  background: var(--gx-bg-elev) !important;
  width: 38px !important;
  height: 38px !important;
  position: relative;
}
.leaflet-control-layers-toggle::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23e2e8f0'><path d='M12 2 1 8l11 6 11-6-11-6Zm0 8.18L4.21 8 12 4.18 19.79 8 12 10.18ZM1 16l11 6 11-6-2-1.09L12 19.82 3 14.91 1 16Zm0-4 11 6 11-6-2-1.09L12 15.82 3 10.91 1 12Z'/></svg>");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 22px 22px;
  pointer-events: none;
}
.leaflet-control-layers-expanded {
  padding: 12px !important;
  min-width: 220px;
  background: var(--gx-bg-elev-2) !important;
  color: var(--gx-fg) !important;
  font: 600 13px/1.3 Inter, system-ui, sans-serif !important;
}
.leaflet-control-layers-expanded .leaflet-control-layers-list {
  margin: 0;
}
.leaflet-control-layers-base label,
.leaflet-control-layers-overlays label {
  display: flex !important;
  align-items: center;
  gap: 8px;
  margin: 0 !important;
  padding: 7px 8px !important;
  border-radius: 8px;
  cursor: pointer;
  font: 600 12px/1.2 Inter, system-ui, sans-serif !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  color: var(--gx-fg) !important;
  transition: background 0.12s ease;
}
.leaflet-control-layers-base label:hover,
.leaflet-control-layers-overlays label:hover {
  background: rgba(255, 255, 255, 0.05) !important;
}
.leaflet-control-layers-base label input[type="radio"],
.leaflet-control-layers-overlays label input[type="checkbox"] {
  accent-color: var(--gx-accent);
  margin-right: 4px;
}
.leaflet-control-layers-base label span,
.leaflet-control-layers-overlays label span {
  color: var(--gx-fg) !important;
}
.leaflet-control-layers-separator {
  border-top-color: var(--gx-card-border) !important;
  margin: 8px 0 !important;
}

.leaflet-control-attribution {
  background: rgba(10, 14, 23, 0.78) !important;
  color: var(--gx-fg-dim) !important;
  border-radius: 8px 0 0 0 !important;
  padding: 4px 8px !important;
  font-size: 10px !important;
  border: 1px solid var(--gx-card-border) !important;
  border-right: none !important;
  border-bottom: none !important;
  backdrop-filter: blur(8px);
}
.leaflet-control-attribution a { color: var(--gx-accent) !important; }

/* Tooltips y popups de Leaflet: estilo dark-glass coherente. Aplica a
   todos (no solo .globesp-user-label) para cubrir cuadros que mostraban
   texto negro sobre fondo oscuro. */
.leaflet-tooltip,
.leaflet-tooltip.globesp-user-label {
  background: var(--gx-bg-elev-2) !important;
  border: 1px solid var(--gx-card-border) !important;
  color: var(--gx-fg) !important;
  border-radius: 9px !important;
  box-shadow: var(--gx-shadow-soft) !important;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  padding: 6px 10px !important;
  font: 600 11px/1.35 Inter, system-ui, sans-serif !important;
}
.leaflet-tooltip * {
  color: var(--gx-fg) !important;
}
.leaflet-tooltip strong, .leaflet-tooltip b {
  color: var(--gx-fg-strong) !important;
  font-weight: 700;
}
.leaflet-tooltip-top:before,
.leaflet-tooltip-bottom:before,
.leaflet-tooltip-left:before,
.leaflet-tooltip-right:before {
  border-top-color: var(--gx-bg-elev-2) !important;
  border-bottom-color: var(--gx-bg-elev-2) !important;
  border-left-color: var(--gx-bg-elev-2) !important;
  border-right-color: var(--gx-bg-elev-2) !important;
}

.leaflet-popup-content-wrapper {
  background: var(--gx-bg-elev-2) !important;
  border: 1px solid var(--gx-card-border) !important;
  color: var(--gx-fg) !important;
  border-radius: 12px !important;
  box-shadow: var(--gx-shadow) !important;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.leaflet-popup-content {
  color: var(--gx-fg) !important;
  font: 500 12px/1.4 Inter, system-ui, sans-serif !important;
  margin: 10px 14px !important;
}
.leaflet-popup-content * {
  color: var(--gx-fg) !important;
}
.leaflet-popup-content strong, .leaflet-popup-content b {
  color: var(--gx-fg-strong) !important;
}
.leaflet-popup-content a {
  color: var(--gx-accent) !important;
}
.leaflet-popup-tip {
  background: var(--gx-bg-elev-2) !important;
  border: 1px solid var(--gx-card-border) !important;
}
.leaflet-popup-close-button {
  color: var(--gx-fg-dim) !important;
}
.leaflet-popup-close-button:hover { color: var(--gx-fg) !important; }

/* ============ VIDEOLLAMADA — coherente con topbar ============ */
/* Mismo fondo glass-dark, blur y borde que la topbar (variables --gx-*).
   Minimizado: solo header con "Videollamada" + botón expandir.
   Expandido: panel cuadrado, controles en una fila, ancho fijo. */
#callPanel {
  background: var(--gx-bg-elev, rgba(13, 18, 30, 0.92)) !important;
  border: 1px solid var(--gx-card-border, rgba(255, 255, 255, 0.08)) !important;
  backdrop-filter: blur(14px) !important;
  -webkit-backdrop-filter: blur(14px) !important;
  box-shadow: var(--gx-shadow-soft, 0 6px 18px rgba(0, 0, 0, 0.25)) !important;
  border-radius: 14px !important;
  overflow: hidden;
}

/* MINIMIZADO: solo el header con el texto y el botón expandir.
   Ocultamos el footer redundante "Toca para expandir". */
#callPanel[data-min="true"] {
  width: auto !important;
  max-width: 200px !important;
  border-radius: 12px !important;
}
#callPanel[data-min="true"]:hover {
  border-color: var(--gx-card-border-strong, rgba(255, 255, 255, 0.14)) !important;
}
#callPanel[data-min="true"] #callMiniFooter { display: none !important; }
#callPanel[data-min="true"] > div:first-child { border-bottom: none !important; }

/* EXPANDIDO: ancho fijo, panel cuadrado-ish, ajustado a la pantalla. */
#callPanel:not([data-min="true"]) {
  width: min(320px, calc(100vw - 16px)) !important;
  max-width: 320px !important;
}

#callPanel > div:first-child {
  background: transparent !important;
  border-bottom: 1px solid var(--gx-card-border, rgba(255, 255, 255, 0.06)) !important;
  padding: 8px 12px !important;
}
#callMinBtn {
  background: rgba(255, 255, 255, 0.04) !important;
  border: 1px solid transparent !important;
  width: 26px !important;
  height: 26px !important;
}
#callMinBtn:hover { background: rgba(255, 255, 255, 0.10) !important; }
#callMinBtn .material-icons-round { font-size: 14px !important; }

#callPanel .rounded-xl.border.border-white\/10.bg-black\/55 {
  background: rgba(0, 0, 0, 0.32) !important;
  border-color: rgba(255, 255, 255, 0.08) !important;
  backdrop-filter: blur(8px);
}
#callPanel #call-quality-pill {
  background: rgba(0, 0, 0, 0.28) !important;
  border-color: rgba(255, 255, 255, 0.08) !important;
}

#callPanel > div.call-content > div:last-child,
#callPanel .call-content > div:last-child {
  background: rgba(0, 0, 0, 0.20) !important;
  padding: 10px 12px !important;
  gap: 8px !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  justify-content: space-between !important;
  align-items: center !important;
}
#callPanel .call-toggle-btn,
#callPanel #btn-switch-camera,
#callPanel #btn-call-pip {
  background: rgba(255, 255, 255, 0.06) !important;
  border: 1px solid rgba(255, 255, 255, 0.10) !important;
  color: #fff !important;
  width: 36px !important;
  height: 36px !important;
  flex: 0 0 auto !important;
}
#callPanel .call-toggle-btn:hover,
#callPanel #btn-switch-camera:hover,
#callPanel #btn-call-pip:hover {
  background: rgba(0, 212, 170, 0.16) !important;
  border-color: rgba(0, 212, 170, 0.36) !important;
}
#callPanel .call-toggle-btn .material-icons-round,
#callPanel #btn-switch-camera .material-icons-round,
#callPanel #btn-call-pip .material-icons-round {
  font-size: 17px !important;
  color: #fff !important;
}
#callPanel #btn-video-stop {
  background: rgba(239, 68, 68, 0.85) !important;
  border: 1px solid rgba(239, 68, 68, 0.5) !important;
  width: 36px !important;
  height: 36px !important;
  flex: 0 0 auto !important;
  box-shadow: 0 4px 12px rgba(239, 68, 68, 0.35) !important;
}
#callPanel #btn-video-stop:hover { background: rgba(239, 68, 68, 1) !important; }
#callPanel #btn-video-stop .material-icons-round { font-size: 17px !important; }
#callMiniFooter {
  background: transparent !important;
  padding: 6px 12px !important;
  font-size: 10px !important;
  color: rgba(255, 255, 255, 0.55) !important;
}

/* ============ RESPONSIVE ============ */
@media (max-width: 480px) {
  #sidebarDrawer { width: min(86vw, 320px) !important; padding: 12px !important; }
  #login-screen .max-w-\[380px\] { max-width: min(94vw, 380px); }
  #callPanel[data-min="true"] { max-width: 180px !important; }
  #callPanel:not([data-min="true"]) { width: min(300px, calc(100vw - 12px)) !important; }
  #openDrawerBtn span:not(.material-icons-round) { display: none; }
  #openDrawerBtn { padding: 8px !important; }
}
@media (orientation: landscape) and (max-height: 480px) {
  #appShell > div.absolute.top-2 { top: 4px !important; }
  #openDrawerBtn, #quick-center { padding: 6px 8px !important; }
  #ui-zoom-in, #ui-zoom-out { width: 30px !important; height: 30px !important; }
}

/* Inputs ≥16px en móvil para evitar auto-zoom de iOS */
@media (max-width: 768px) {
  input[type="text"], input[type="password"], input[type="email"],
  input[type="number"], input[type="search"], textarea, select {
    font-size: 16px !important;
  }
}

/* En navegación pro, ocultar la topbar antigua para no superponer */
body.gnav-active #appShell > div.absolute.top-2 { display: none !important; }
body.gnav-active #callPanel { opacity: 0; pointer-events: none; }
