/* ============================================
   Baróne App — Desktop Detail Panel
   Formularios y detalles como panel derecho
   Solo activo en ≥1024px
   ============================================ */

@media (min-width: 1024px) {

  /* ─── Panel base ─── */
  .view-detail {
    position: fixed !important;
    top: 56px !important;                    /* justo bajo el topbar */
    right: 0 !important;
    bottom: 0 !important;
    width: min(520px, 42vw) !important;
    height: auto !important;
    background-color: var(--color-bg-card) !important;
    border-left: 1px solid var(--color-border) !important;
    box-shadow: -8px 0 40px rgba(0, 0, 0, 0.5) !important;
    z-index: var(--z-drawer) !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    padding-top: var(--spacing-md) !important;

    /* Transición de entrada desde la derecha */
    transition: transform 280ms cubic-bezier(0.32, 0.72, 0, 1),
                opacity 200ms ease !important;
    transform: translateX(0) !important;
    opacity: 1 !important;
  }

  /* Animación de entrada al aparecer (CSS @starting-style) */
  @starting-style {
    .view-detail {
      transform: translateX(100%);
      opacity: 0;
    }
  }

  /* Sobrescribir transiciones slide-up de Alpine para el panel en desktop */
  .view-detail.slide-up-enter-start {
    transform: translateX(100%) !important;
    opacity: 0 !important;
  }
  .view-detail.slide-up-enter-end {
    transform: translateX(0) !important;
    opacity: 1 !important;
  }
  .view-detail.slide-up-leave-start {
    transform: translateX(0) !important;
    opacity: 1 !important;
  }
  .view-detail.slide-up-leave-end {
    transform: translateX(100%) !important;
    opacity: 0 !important;
  }

  /* ─── Vistas base: permanecer visibles cuando un panel está abierto ─── */
  /* !important sobrescribe el display:none inline de Alpine */
  .main-content:has(.view-detail:not([style*="display: none"])) .view-main {
    display: flex !important;
    flex-direction: column !important;
  }

  /* ─── Backdrop ─── */
  .desktop-panel-backdrop {
    display: none;
    position: fixed;
    top: 56px;
    left: 0;
    right: min(520px, 42vw);
    bottom: 0;
    background: rgba(0, 0, 0, 0.55);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    z-index: calc(var(--z-drawer) - 1);
    cursor: pointer;
  }

  /* Mostrar backdrop cuando hay un panel visible */
  body:has(.view-detail:not([style*="display: none"])) .desktop-panel-backdrop {
    display: block;
  }

  /* ─── Botón cerrar (X) flotante sobre el panel ─── */
  .desktop-panel-close {
    display: none;
    align-items: center;
    justify-content: center;
    position: fixed;
    top: calc(56px + 12px);
    right: calc(min(520px, 42vw) + 12px);
    width: 2rem;
    height: 2rem;
    background: var(--color-bg-elevated);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-full);
    color: var(--color-text-secondary);
    cursor: pointer;
    z-index: calc(var(--z-drawer) + 1);
    transition: background-color var(--transition-fast), color var(--transition-fast);
  }

  .desktop-panel-close:hover {
    background: var(--color-bg-card);
    color: var(--color-text);
  }

  .desktop-panel-close-icon {
    width: 0.875rem;
    height: 0.875rem;
  }

  /* Mostrar botón X cuando hay un panel visible */
  body:has(.view-detail:not([style*="display: none"])) .desktop-panel-close {
    display: flex;
  }

  /* En orientación vertical ocultamos la X flotante */
  @media (orientation: portrait) {
    .desktop-panel-close {
      display: none !important;
    }
  }
}

/* Móvil: sin estilos especiales para estas clases */
@media (max-width: 1023px) {
  .view-detail,
  .view-main,
  .desktop-panel-backdrop,
  .desktop-panel-close {
    /* sin cambios — comportamiento móvil intacto */
  }
}
