/* ══════════════════════════════════════════
   User Bubble — bubble.css  v1.0.0
   ══════════════════════════════════════════ */

/* Variables */
:root {
  --ub-primary:      #334F9D;
  --ub-secondary:    #4D4C9B;
  --ub-accent:       #009640;
  --ub-accent-light: #39AE6F;
  --ub-bg:           #ffffff;
  --ub-text:         #1e1e1e;
  --ub-text-muted:   #666;
  --ub-border:       #e5e7eb;
  --ub-shadow:       0 8px 32px rgba(0,0,0,.14);
  --ub-radius:       12px;
  --ub-font-body:    Helvetica, Arial, sans-serif;
  --ub-avatar-size:  40px;
  --ub-avatar-lg:    52px;
}

/* ── Wrapper ── */
.ub-wrapper {
  display: inline-flex;
  align-items: center;
  position: relative;
  font-family: var(--ub-font-body);
}

/* ── Trigger button ── */
.ub-trigger {
  background: none !important;
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
  cursor: pointer;
  border-radius: 50%;
  display: flex !important;
  align-items: center;
  justify-content: center;
  transition: transform .15s ease, box-shadow .15s ease;
  box-shadow: none !important;
  font-size: inherit !important;
  line-height: 1 !important;
  color: inherit !important;
  width: var(--ub-avatar-size) !important;
  height: var(--ub-avatar-size) !important;
}
.ub-trigger:hover,
.ub-trigger:focus-visible {
  transform: scale(1.06);
  box-shadow: 0 0 0 3px rgba(51,79,157,.25);
  outline: none;
}
.ub-trigger:focus-visible { box-shadow: 0 0 0 3px rgba(51,79,157,.5); }

/* ── Avatar ── */
.ub-avatar {
  width:  var(--ub-avatar-size);
  height: var(--ub-avatar-size);
  border-radius: 50%;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 2px solid rgba(255,255,255,.8);
  box-shadow: 0 2px 8px rgba(0,0,0,.18);
  flex-shrink: 0;
}
.ub-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.ub-avatar-svg { width: 100%; height: 100%; display: block; }

.ub-avatar--lg {
  --ub-avatar-size: var(--ub-avatar-lg);
}

/* ── Dropdown ── */
.ub-dropdown {
  position: absolute;
  top: calc(var(--ub-avatar-size) + 12px);
  right: 0;
  min-width: 220px;
  background: var(--ub-bg);
  border: 1px solid var(--ub-border);
  border-radius: var(--ub-radius);
  box-shadow: var(--ub-shadow);
  z-index: 99999;
  overflow: hidden;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-6px) scale(.97);
  transition: opacity .18s ease, transform .18s ease, visibility .18s;
  pointer-events: none;
}
.ub-dropdown.is-open {
  opacity: 1;
  visibility: visible;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}

/* ── User info header ── */
.ub-user-info {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 14px 12px;
}
.ub-user-text { overflow: hidden; }
.ub-user-text strong {
  display: block;
  font-size: 13px;
  font-weight: 700;
  color: var(--ub-text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ub-user-text span {
  display: block;
  font-size: 11px;
  color: var(--ub-text-muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ub-user-roles {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-top: 4px;
}
.ub-user-role {
  display: inline-block;
  font-style: normal;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .4px;
  text-transform: uppercase;
  color: var(--ub-primary, #334F9D);
  background: rgba(51,79,157,.1);
  border-radius: 20px;
  padding: 2px 8px;
}

/* ── Divider ── */
.ub-divider {
  border: none;
  border-top: 1px solid var(--ub-border);
  margin: 0;
}

/* ── Nav items ── */
.ub-nav { display: flex; flex-direction: column; }
.ub-nav-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  font-size: 13px;
  color: var(--ub-text);
  text-decoration: none;
  transition: background .12s, color .12s;
  cursor: pointer;
  border: none;
  background: none;
  width: 100%;
  text-align: left;
  font-family: var(--ub-font-body);
}
.ub-nav-item:hover { background: #f5f7ff; color: var(--ub-primary); }
.ub-nav-item svg { flex-shrink: 0; }
/* Mantener compatibilidad si algún tema sí carga dashicons */
.ub-nav-item .dashicons { font-size: 16px; width: 16px; height: 16px; }

/* ── Logout ── */
.ub-logout {
  color: #c0392b;
  padding: 10px 14px 14px;
}
.ub-logout:hover { background: #fff5f5; color: #a93226; }

/* ── Botón login (no logueado) ── */
.ub-login-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: var(--ub-primary);
  color: #fff;
  text-decoration: none;
  padding: 9px 18px;
  border-radius: 25px;
  font-size: 13px;
  font-weight: 600;
  font-family: var(--ub-font-body);
  transition: background .15s, transform .15s;
  white-space: nowrap;
}
.ub-login-btn:hover {
  background: var(--ub-secondary);
  color: #fff;
  transform: translateY(-1px);
}
.ub-login-btn svg { flex-shrink: 0; }
/* Compatibilidad si dashicons carga */
.ub-login-btn .dashicons { font-size: 15px; width: 15px; height: 15px; }

/* ══════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════ */
@media (max-width: 768px) {
  .ub-wrapper { position: static; }

  .ub-dropdown {
    position: fixed;
    top: 50px;   /* siempre a 50px del tope, nunca tapa la imagen */
    right: 10px;
    left: 10px;
    min-width: unset;
    width: auto;
    transform: translateY(-6px) scale(.97);
  }
  .ub-dropdown.is-open {
    transform: translateY(0) scale(1);
  }
}
