/**
 * RADEXEL Design System - Terminal Component
 *
 * Bridge terminal dark theme for admin Claude Code interaction.
 * Always uses dark colors regardless of system theme.
 */

/* ==========================================================================
   Terminal Container
   ========================================================================== */

.terminal {
  display: flex;
  flex-direction: column;
  background: #1E1E2E;
  border-radius: var(--radius-lg);
  border: 1px solid #313244;
  overflow: hidden;
  font-family: var(--font-mono);
  font-size: var(--font-size-sm);
  line-height: var(--line-height-relaxed);
}


/* ==========================================================================
   Terminal Header (Title Bar)
   ========================================================================== */

.terminal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-2) var(--space-4);
  background: #181825;
  border-bottom: 1px solid #313244;
  flex-shrink: 0;
}

.terminal__header-left {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

/* macOS-style traffic lights */
.terminal__dots {
  display: flex;
  align-items: center;
  gap: 6px;
}

.terminal__dot {
  width: 10px;
  height: 10px;
  border-radius: var(--radius-full);
}

.terminal__dot--close {
  background: #F38BA8;
}

.terminal__dot--minimize {
  background: #F9E2AF;
}

.terminal__dot--maximize {
  background: #A6E3A1;
}

.terminal__title {
  font-size: var(--font-size-xs);
  color: #6C7086;
  font-weight: var(--font-weight-medium);
}

.terminal__header-right {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.terminal__action-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  background: transparent;
  border: none;
  border-radius: var(--radius-sm);
  color: #6C7086;
  cursor: pointer;
  transition:
    background-color var(--duration-fast) var(--ease-default),
    color var(--duration-fast) var(--ease-default);
}

.terminal__action-btn:hover {
  background: rgba(255, 255, 255, 0.1);
  color: #CDD6F4;
}

.terminal__action-btn svg {
  width: 14px;
  height: 14px;
}


/* ==========================================================================
   Terminal Output
   ========================================================================== */

.terminal__output {
  flex: 1;
  padding: var(--space-4);
  overflow-y: auto;
  color: #CDD6F4;
  white-space: pre-wrap;
  word-break: break-word;
  min-height: 200px;
}

/* Scrollbar for terminal */
.terminal__output::-webkit-scrollbar {
  width: 6px;
}

.terminal__output::-webkit-scrollbar-track {
  background: transparent;
}

.terminal__output::-webkit-scrollbar-thumb {
  background: #45475A;
  border-radius: var(--radius-full);
}

.terminal__output::-webkit-scrollbar-thumb:hover {
  background: #585B70;
}


/* ==========================================================================
   Terminal Lines
   ========================================================================== */

.terminal__line {
  display: block;
  padding: 1px 0;
}

/* Prompt styling */
.terminal__prompt {
  color: #89B4FA;
  font-weight: var(--font-weight-medium);
}

/* Command input text */
.terminal__command {
  color: #CDD6F4;
}

/* Standard output */
.terminal__stdout {
  color: #A6ADC8;
}

/* Error output */
.terminal__stderr {
  color: #F38BA8;
}

/* Success output */
.terminal__success {
  color: #A6E3A1;
}

/* Warning output */
.terminal__warning {
  color: #F9E2AF;
}

/* Info output */
.terminal__info {
  color: #89B4FA;
}

/* Timestamp */
.terminal__timestamp {
  color: #585B70;
  font-size: var(--font-size-xs);
}

/* Separator line */
.terminal__separator {
  border: none;
  border-top: 1px solid #313244;
  margin: var(--space-2) 0;
}


/* ==========================================================================
   Terminal Input
   ========================================================================== */

.terminal__input-area {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  border-top: 1px solid #313244;
  background: #181825;
}

.terminal__input-prompt {
  color: #89B4FA;
  font-weight: var(--font-weight-semibold);
  flex-shrink: 0;
  user-select: none;
}

.terminal__input-field {
  flex: 1;
  background: transparent;
  border: none;
  outline: none;
  color: #CDD6F4;
  font-family: var(--font-mono);
  font-size: var(--font-size-sm);
  caret-color: #89B4FA;
}

.terminal__input-field::placeholder {
  color: #45475A;
}

.terminal__input-send {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  background: rgba(137, 180, 250, 0.15);
  border: none;
  border-radius: var(--radius-sm);
  color: #89B4FA;
  cursor: pointer;
  flex-shrink: 0;
  transition:
    background-color var(--duration-fast) var(--ease-default);
}

.terminal__input-send:hover:not(:disabled) {
  background: rgba(137, 180, 250, 0.25);
}

.terminal__input-send:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}

.terminal__input-send svg {
  width: 14px;
  height: 14px;
}


/* ==========================================================================
   Terminal Status Bar
   ========================================================================== */

.terminal__status-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-1) var(--space-4);
  background: #11111B;
  font-size: 11px;
  color: #585B70;
}

.terminal__status-left {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.terminal__status-right {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.terminal__status-item {
  display: flex;
  align-items: center;
  gap: var(--space-1);
}

.terminal__status-dot {
  width: 6px;
  height: 6px;
  border-radius: var(--radius-full);
}

.terminal__status-dot--connected {
  background: #A6E3A1;
}

.terminal__status-dot--disconnected {
  background: #F38BA8;
}

.terminal__status-dot--processing {
  background: #F9E2AF;
  animation: pulse 1.5s var(--ease-default) infinite;
}


/* ==========================================================================
   Terminal Loading
   ========================================================================== */

.terminal__loading {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) 0;
  color: #585B70;
}

.terminal__loading-spinner {
  width: 14px;
  height: 14px;
  border: 2px solid #45475A;
  border-top-color: #89B4FA;
  border-radius: var(--radius-full);
  animation: spin 0.8s linear infinite;
}


/* ==========================================================================
   Full-height terminal (when embedded in a tab panel)
   ========================================================================== */

.team-tab-panel .terminal {
  height: 100%;
  border-radius: 0;
  border: none;
}

.team-tab-panel .terminal__output {
  min-height: 0;
  flex: 1;
}


/* ==========================================================================
   Streaming line marker
   ========================================================================== */

.terminal__line--streaming {
  /* Blinking cursor effect at the end of the streaming line */
  border-right: 2px solid #89B4FA;
  animation: blink-cursor 0.8s step-end infinite;
}

@keyframes blink-cursor {
  50% {
    border-color: transparent;
  }
}


/* ==========================================================================
   Focus & Accessibility
   ========================================================================== */

.terminal__input-field:focus {
  outline: none;
}

.terminal__action-btn:focus-visible,
.terminal__input-send:focus-visible {
  outline: 2px solid #89B4FA;
  outline-offset: 1px;
}
