.jl-drawer__overlay {
  position: fixed;
  inset: 0;
  z-index: 110;
  background: hsl(var(--shadow-color) / 0.45);
  backdrop-filter: blur(2px);
  display: flex;
  animation: jl-drawer-fade var(--duration-base) var(--ease-standard);
}
.jl-drawer__overlay[hidden] { display: none; } /* author display:flex would otherwise override [hidden] */
@keyframes jl-drawer-fade { from { opacity: 0; } to { opacity: 1; } }
.jl-drawer__overlay[data-side="right"]  { justify-content: flex-end; }
.jl-drawer__overlay[data-side="left"]   { justify-content: flex-start; }
.jl-drawer__overlay[data-side="bottom"] { align-items: flex-end; }

.jl-drawer {
  display: flex;
  flex-direction: column;
  background: var(--surface-overlay);
  box-shadow: var(--elevation-modal);
  max-width: 100vw;
  max-height: 100vh;
}
.jl-drawer__overlay[data-side="right"] .jl-drawer,
.jl-drawer__overlay[data-side="left"]  .jl-drawer {
  height: 100%;
  width: var(--_size, 420px);
}
.jl-drawer__overlay[data-side="right"] .jl-drawer  { animation: jl-drawer-r var(--duration-slow) var(--ease-emphasized); }
.jl-drawer__overlay[data-side="left"]  .jl-drawer  { animation: jl-drawer-l var(--duration-slow) var(--ease-emphasized); border-top-right-radius: 0; }
.jl-drawer__overlay[data-side="bottom"] .jl-drawer {
  width: 100%;
  max-height: 85vh;
  height: var(--_size, auto);
  border-top-left-radius: var(--radius-2xl);
  border-top-right-radius: var(--radius-2xl);
  animation: jl-drawer-b var(--duration-slow) var(--ease-emphasized);
}
@keyframes jl-drawer-r { from { transform: translateX(100%); } to { transform: none; } }
@keyframes jl-drawer-l { from { transform: translateX(-100%); } to { transform: none; } }
@keyframes jl-drawer-b { from { transform: translateY(100%); } to { transform: none; } }

.jl-drawer__header {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: var(--space-6) var(--space-6) var(--space-4);
  flex: none;
}
.jl-drawer__header-text { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 4px; }
.jl-drawer__title { font-size: var(--text-xl); font-weight: var(--weight-semibold); letter-spacing: var(--tracking-tight); }
.jl-drawer__desc { font-size: var(--text-base); color: var(--text-secondary); line-height: var(--leading-normal); }
.jl-drawer__close {
  flex: none;
  border: none;
  background: transparent;
  cursor: pointer;
  padding: 4px;
  margin: -2px -2px 0 0;
  color: var(--text-tertiary);
  border-radius: var(--radius-md);
  transition: var(--transition-control);
}
.jl-drawer__close:hover { background: var(--surface-active); color: var(--text-primary); }
.jl-drawer__body { flex: 1; overflow: auto; padding: 0 var(--space-6) var(--space-6); }
.jl-drawer__footer {
  display: flex;
  justify-content: flex-end;
  gap: var(--space-3);
  padding: var(--space-5) var(--space-6);
  border-top: 1px solid var(--border-subtle);
  flex: none;
}

@media (prefers-reduced-motion: reduce) {
  .jl-drawer__overlay, .jl-drawer { animation: none !important; }
}
