/**
 * Slide Panel Component Demo Styles
 * Playground-specific styling for the SlidePanel component demos
 */

/* ============================================
   SLIDE DIRECTION OVERRIDES
   Force slide direction with !important to override any nav-position defaults
   ============================================ */

/* Left slide override */
.modal-slide-panel.modal-slide-left .modal-dialog {
  right: auto !important;
  left: 0 !important;
  transform: translateX(-100%) !important;
}

.modal-slide-panel.modal-slide-left.show .modal-dialog {
  transform: translateX(0) !important;
}

.modal-slide-panel.modal-slide-left .modal-content {
  border-right: 1px solid var(--pro-border-color, #30363d) !important;
  border-left: none !important;
}

/* Top slide override */
.modal-slide-panel.modal-slide-top .modal-dialog {
  top: 0 !important;
  right: 0 !important;
  bottom: auto !important;
  left: 0 !important;
  width: auto !important;
  height: auto !important;
  max-height: 80vh !important;
  margin: 0 auto !important;
  transform: translateY(-100%) !important;
}

.modal-slide-panel.modal-slide-top.show .modal-dialog {
  transform: translateY(0) !important;
}

.modal-slide-panel.modal-slide-top .modal-content {
  height: auto !important;
  max-height: 80vh !important;
  border-top: none !important;
  border-bottom: 1px solid var(--pro-border-color, #30363d) !important;
  border-radius: 0 0 12px 12px !important;
}

/* Bottom slide override */
.modal-slide-panel.modal-slide-bottom .modal-dialog {
  top: auto !important;
  right: 0 !important;
  bottom: 0 !important;
  left: 0 !important;
  width: auto !important;
  height: auto !important;
  max-height: 80vh !important;
  margin: 0 auto !important;
  transform: translateY(100%) !important;
}

.modal-slide-panel.modal-slide-bottom.show .modal-dialog {
  transform: translateY(0) !important;
}

.modal-slide-panel.modal-slide-bottom .modal-content {
  height: auto !important;
  max-height: 80vh !important;
  border-bottom: none !important;
  border-top: 1px solid var(--pro-border-color, #30363d) !important;
  border-radius: 12px 12px 0 0 !important;
}

/* ============================================
   BUTTON GRID FOR CONTROLS
   ============================================ */

.slide-panel-demo__button-grid {
  display: flex;
  flex-wrap: wrap;
  gap: var(--pro-spacing-sm, 0.75rem);
  align-items: flex-start;
}

.slide-panel-demo__button-grid .btn {
  flex-shrink: 0;
}

/* ============================================
   STATE & EVENT LOG
   ============================================ */

.slide-panel-demo__log {
  font-family: var(--pro-font-mono, 'Monaco', 'Menlo', 'Consolas', monospace);
  font-size: var(--pro-font-size-sm, 0.8125rem);
  line-height: 1.6;
  padding: var(--pro-spacing-md, 1rem);
  margin: 0;
  background: var(--pro-bg-tertiary, var(--pro-bg-secondary));
  color: var(--pro-text-muted, var(--pro-text-secondary));
  border-radius: var(--pro-radius-md, 6px);
  border: 1px solid var(--pro-border-color);
  min-height: 80px;
  max-height: 200px;
  overflow-y: auto;
  white-space: pre-wrap;
  word-break: break-word;
}

/* ============================================
   RESPONSIVE ADJUSTMENTS
   ============================================ */

@media (max-width: 768px) {
  .slide-panel-demo__button-grid {
    gap: var(--pro-spacing-xs, 0.5rem);
  }

  .slide-panel-demo__button-grid .btn {
    flex: 1 1 calc(50% - var(--pro-spacing-xs, 0.5rem));
    min-width: 140px;
  }
}

@media (max-width: 480px) {
  .slide-panel-demo__button-grid .btn {
    flex: 1 1 100%;
  }
}

/* ============================================
   HIGH CONTRAST MODE
   ============================================ */

@media (prefers-contrast: high) {
  .slide-panel-demo__log {
    border-width: 2px;
  }
}

/* ============================================
   HIGH CONTRAST THEME (Manual Selection)
   ============================================ */

[data-theme="high-contrast"] .slide-panel-demo__log {
  border: 2px solid #ffffff;
  background: #000000;
  color: #ffffff;
}
