/* UCP Developer Dashboard - Shared Theme and Components */

:root {
  --dashboard-primary: #667eea;
  --dashboard-primary-dark: #5a67d8;
  --dashboard-secondary: #764ba2;
  --dashboard-success: #28a745;
  --dashboard-warning: #ffc107;
  --dashboard-danger: #dc3545;
  --dashboard-info: #17a2b8;
  --dashboard-light: #f8f9fa;
  --dashboard-dark: #343a40;
  --dashboard-gray: #6c757d;
  --dashboard-border: #dee2e6;
  --dashboard-shadow: rgba(0,0,0,0.1);
  --dashboard-radius: 4px;
  --dashboard-font: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --dashboard-mono: 'Monaco', 'Menlo', 'Ubuntu Mono', monospace;
}

/* Global Dashboard Styles */
.dashboard-body {
  margin: 0;
  padding: 0;
  font-family: var(--dashboard-font);
  background: var(--dashboard-light);
  height: 100vh;
  overflow: hidden;
}

/* Dashboard Header */
.dashboard-header {
  background: linear-gradient(135deg, var(--dashboard-primary) 0%, var(--dashboard-secondary) 100%);
  color: white;
  padding: 12px 20px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  box-shadow: 0 2px 4px var(--dashboard-shadow);
  z-index: 1000;
}

.dashboard-title {
  font-size: 16px;
  font-weight: 600;
  margin: 0;
  display: flex;
  align-items: center;
  gap: 8px;
}

.dashboard-controls {
  display: flex;
  gap: 10px;
}

/* Dashboard Tabs */
.dashboard-tabs {
  background: white;
  border-bottom: 1px solid var(--dashboard-border);
  display: flex;
  align-items: center;
  padding: 0 20px;
  height: 48px;
}

.tab-button {
  background: none;
  border: none;
  padding: 12px 20px;
  margin: 0 2px;
  border-radius: var(--dashboard-radius) var(--dashboard-radius) 0 0;
  cursor: pointer;
  font-size: 14px;
  font-weight: 500;
  color: var(--dashboard-gray);
  transition: all 0.2s;
  position: relative;
  top: 1px;
}

.tab-button:hover {
  color: var(--dashboard-primary);
  background: rgba(102, 126, 234, 0.1);
}

.tab-button.active {
  color: var(--dashboard-primary);
  background: white;
  border: 1px solid var(--dashboard-border);
  border-bottom: 1px solid white;
}

.tab-button.active::after {
  content: '';
  position: absolute;
  bottom: -1px;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--dashboard-primary);
}

/* Dashboard Content */
.dashboard-content {
  height: calc(100vh - 108px); /* Header + tabs */
  overflow: hidden;
}

.tab-content {
  height: 100%;
  display: none;
  flex-direction: column;
}

.tab-content.active {
  display: flex;
}

/* Control Button Styles */
.control-btn {
  background: rgba(255,255,255,0.2);
  border: 1px solid rgba(255,255,255,0.3);
  color: white;
  padding: 6px 12px;
  border-radius: var(--dashboard-radius);
  font-size: 12px;
  cursor: pointer;
  transition: background 0.2s;
}

.control-btn:hover {
  background: rgba(255,255,255,0.3);
}

.control-btn.active {
  background: rgba(255,255,255,0.4);
  border-color: rgba(255,255,255,0.6);
}

/* Toolbar Styles */
.tab-toolbar {
  background: white;
  border-bottom: 1px solid var(--dashboard-border);
  padding: 10px 20px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.toolbar-left {
  display: flex;
  gap: 15px;
  align-items: center;
}

.toolbar-right {
  display: flex;
  gap: 10px;
  align-items: center;
}

.filter-group {
  display: flex;
  align-items: center;
  gap: 8px;
}

.filter-group label {
  font-size: 12px;
  color: var(--dashboard-gray);
  font-weight: 500;
}

.filter-select, .filter-input {
  padding: 4px 8px;
  border: 1px solid var(--dashboard-border);
  border-radius: var(--dashboard-radius);
  font-size: 12px;
}

/* Main Content Layout */
.tab-main-content {
  flex: 1;
  display: flex;
  overflow: hidden;
}

/* Sidebar Styles */
.tab-sidebar {
  width: 300px;
  background: white;
  border-right: 1px solid var(--dashboard-border);
  display: flex;
  flex-direction: column;
}

.sidebar-header {
  padding: 12px;
  background: var(--dashboard-light);
  border-bottom: 1px solid var(--dashboard-border);
  font-size: 14px;
  font-weight: 600;
  color: #495057;
}

/* Details Panel */
.tab-details-panel {
  flex: 1;
  display: flex;
  flex-direction: column;
  background: white;
}

.details-header {
  padding: 15px 20px;
  background: var(--dashboard-light);
  border-bottom: 1px solid var(--dashboard-border);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.details-title {
  font-size: 16px;
  font-weight: 600;
  color: #333;
}

.details-content {
  flex: 1;
  overflow-y: auto;
  padding: 20px;
}

/* Utility Classes */
.text-muted {
  color: var(--dashboard-gray) !important;
}

.text-small {
  font-size: 12px;
}

.text-mono {
  font-family: var(--dashboard-mono);
}

.badge {
  display: inline-block;
  padding: 2px 6px;
  font-size: 11px;
  font-weight: 500;
  border-radius: 12px;
  color: white;
}

.badge-primary { background: var(--dashboard-primary); }
.badge-success { background: var(--dashboard-success); }
.badge-warning { background: var(--dashboard-warning); color: #212529; }
.badge-danger { background: var(--dashboard-danger); }
.badge-info { background: var(--dashboard-info); }
.badge-light { background: var(--dashboard-light); color: #212529; }
.badge-dark { background: var(--dashboard-dark); }

.btn-sm {
  padding: 4px 8px;
  font-size: 12px;
  border-radius: var(--dashboard-radius);
  border: 1px solid var(--dashboard-border);
  background: white;
  cursor: pointer;
  transition: all 0.2s;
}

.btn-sm:hover {
  background: var(--dashboard-light);
}

.no-selection {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  color: var(--dashboard-gray);
  font-style: italic;
}
