/**
 * EssentialsC Documentation - Components
 * Reusable UI components and patterns
 */

/* ============================================
   SIDEBAR COMPONENTS
   ============================================ */

/* Sidebar Header */
.sidebar-header {
  text-align: center;
  padding: 0 var(--space-6) var(--space-6);
  border-bottom: 1px solid var(--border);
  margin-bottom: var(--space-6);
}

.sidebar-title {
  font-size: 1.25rem;
  font-weight: 600;
  letter-spacing: -0.25px;
  color: var(--text-primary);
  margin-bottom: var(--space-1);
}

.sidebar-subtitle {
  font-size: 0.75rem;
  color: var(--text-muted);
  font-weight: 500;
}

/* Navigation Section */
.nav-section {
  margin-bottom: var(--space-6);
}

.nav-section-title {
  font-size: 0.6875rem;
  text-transform: uppercase;
  letter-spacing: 0.75px;
  color: var(--text-muted);
  padding: 0 var(--space-6);
  margin-bottom: var(--space-3);
  font-weight: 600;
}

/* Navigation Group */
.nav-group {
  margin-bottom: var(--space-2);
}

.nav-group-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-2) var(--space-6);
  cursor: pointer;
  transition: background-color var(--transition-fast);
  border-left: 2px solid transparent;
  user-select: none;
}

.nav-group-header:hover {
  background: var(--surface-hover);
}

.nav-group-header.active {
  border-left-color: var(--accent);
  background: var(--bg-tertiary);
}

.nav-group-title {
  font-size: 0.9375rem;
  font-weight: 500;
  color: var(--text-primary);
}

.nav-group-arrow {
  width: 16px;
  height: 16px;
  color: var(--text-muted);
  transition: transform var(--transition);
}

.nav-group.expanded .nav-group-arrow {
  transform: rotate(90deg);
}

/* Navigation Pages Container */
.nav-pages {
  max-height: 0;
  overflow: hidden;
  transition: max-height var(--transition-slow);
}

.nav-group.expanded .nav-pages {
  max-height: 500px; /* Arbitrary large value for animation */
}

/* Navigation Page Link */
.nav-page {
  display: block;
  padding: var(--space-2) var(--space-6) var(--space-2) var(--space-8);
  font-size: 0.875rem;
  color: var(--text-secondary);
  transition: all var(--transition-fast);
  border-left: 2px solid transparent;
  position: relative;
}

.nav-page:hover {
  color: var(--text-primary);
  transform: translateX(2px);
}

.nav-page.active {
  color: var(--accent);
  border-left-color: var(--accent);
  background: var(--bg-tertiary);
  font-weight: 500;
}

/* ============================================
   CARDS
   ============================================ */

/* Base Card */
.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: var(--space-6);
  box-shadow: var(--shadow);
  transition: all var(--transition);
}

.card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-hover);
  border-color: var(--accent);
}

/* Plugin Card (Large) */
.plugin-card {
  display: grid;
  gap: var(--space-4);
  padding: var(--space-8);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  transition: all var(--transition);
}

.plugin-card:hover {
  border-color: var(--accent);
  box-shadow: var(--shadow-glow);
}

.plugin-card-header {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

.plugin-icon {
  width: 48px;
  height: 48px;
  background: var(--accent-gradient);
  border-radius: var(--radius);
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  flex-shrink: 0;
}

.plugin-icon svg {
  width: 24px;
  height: 24px;
}

.plugin-info {
  flex: 1;
}

.plugin-title {
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: var(--space-1);
}

.plugin-meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
}

/* Hero Card */
.hero-card {
  padding: var(--space-10);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  position: relative;
  overflow: hidden;
}

.hero-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--accent-gradient);
}

.hero-card h1 {
  font-size: 2.25rem;
  margin-bottom: var(--space-4);
  background: var(--accent-gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* Feature Card */
.feature-card {
  display: flex;
  gap: var(--space-4);
  padding: var(--space-5);
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  transition: all var(--transition);
}

.feature-card:hover {
  border-color: var(--border-light);
  transform: translateY(-1px);
}

.feature-icon {
  width: 40px;
  height: 40px;
  background: var(--accent);
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  flex-shrink: 0;
}

.feature-icon svg {
  width: 20px;
  height: 20px;
}

.feature-content h3 {
  font-size: 1rem;
  margin-bottom: var(--space-2);
}

.feature-content p {
  font-size: 0.875rem;
  color: var(--text-secondary);
  margin: 0;
}

/* Guide Card */
.guide-card {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-5);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  transition: all var(--transition);
  text-decoration: none;
}

.guide-card:hover {
  transform: translateX(4px);
  border-color: var(--accent);
  background: var(--surface-hover);
}

.guide-card:hover .guide-arrow {
  transform: translateX(4px);
  color: var(--accent);
}

.guide-icon {
  width: 40px;
  height: 40px;
  background: var(--bg-tertiary);
  border-radius: var(--radius);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--accent);
  flex-shrink: 0;
}

.guide-content {
  flex: 1;
}

.guide-content h3 {
  font-size: 1rem;
  margin-bottom: var(--space-1);
  color: var(--text-primary);
}

.guide-content p {
  font-size: 0.875rem;
  color: var(--text-secondary);
  margin: 0;
}

.guide-arrow {
  color: var(--text-muted);
  transition: all var(--transition);
}

/* ============================================
   BUTTONS & INTERACTIVE
   ============================================ */

/* Theme Toggle */
.theme-toggle {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  background: var(--surface);
  border: 1px solid var(--border);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius);
  color: var(--text-secondary);
  font-size: 0.875rem;
  transition: all var(--transition-fast);
  cursor: pointer;
}

.theme-toggle:hover {
  border-color: var(--accent);
  color: var(--text-primary);
}

.theme-toggle svg {
  width: 16px;
  height: 16px;
}

/* Button Primary */
.btn-primary {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  background: var(--accent-gradient);
  color: white;
  padding: var(--space-3) var(--space-6);
  border-radius: var(--radius);
  font-weight: 500;
  transition: all var(--transition);
  border: none;
  cursor: pointer;
  text-decoration: none;
}

.btn-primary:hover {
  box-shadow: var(--shadow-glow);
  transform: translateY(-1px);
  color: white;
}

/* Button Secondary */
.btn-secondary {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  background: var(--surface);
  border: 1px solid var(--border);
  color: var(--text-primary);
  padding: var(--space-3) var(--space-6);
  border-radius: var(--radius);
  font-weight: 500;
  transition: all var(--transition);
  cursor: pointer;
  text-decoration: none;
}

.btn-secondary:hover {
  border-color: var(--accent);
  background: var(--surface-hover);
}

/* Support Link Card */
.support-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-4) var(--space-5);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  transition: all var(--transition);
  text-decoration: none;
}

.support-card:hover {
  background: var(--surface-hover);
  transform: translateX(2px);
  border-color: var(--border-light);
}

.support-card-content {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.support-icon {
  color: var(--accent);
}

/* Breadcrumb */
.breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: 0.875rem;
  color: var(--text-muted);
}

.breadcrumb a {
  color: var(--text-secondary);
  transition: color var(--transition-fast);
}

.breadcrumb a:hover {
  color: var(--accent);
}

.breadcrumb-separator {
  color: var(--text-muted);
}

.breadcrumb-current {
  color: var(--text-primary);
  font-weight: 500;
}

/* ============================================
   CODE BLOCKS
   ============================================ */

.code-block {
  position: relative;
  background: var(--bg-tertiary);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
}

.code-block-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-3) var(--space-4);
  background: var(--bg-secondary);
  border-bottom: 1px solid var(--border);
  font-size: 0.875rem;
}

.code-block-lang {
  color: var(--text-muted);
  font-family: var(--font-mono);
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.code-block-copy {
  background: none;
  border: none;
  color: var(--text-muted);
  cursor: pointer;
  padding: var(--space-1);
  transition: color var(--transition-fast);
}

.code-block-copy:hover {
  color: var(--accent);
}

.code-block pre {
  margin: 0;
  border: none;
  border-radius: 0;
  background: transparent;
}

/* Inline Code */
code {
  font-family: var(--font-mono);
  font-size: 0.85em;
  background: var(--bg-tertiary);
  padding: 0.125em 0.375em;
  border-radius: var(--radius-sm);
  color: var(--accent);
  border: 1px solid var(--border);
}

/* YAML Syntax Highlighting (Basic) */
.yaml-key {
  color: var(--accent);
}

.yaml-string {
  color: var(--success);
}

.yaml-number {
  color: var(--warning);
}

.yaml-boolean {
  color: var(--danger);
}

.yaml-comment {
  color: var(--text-muted);
  font-style: italic;
}

/* ============================================
   STATUS BADGES
   ============================================ */

/* Version Badge */
.version-badge {
  display: inline-flex;
  align-items: center;
  background: var(--bg-tertiary);
  border: 1px solid var(--border);
  border-radius: var(--radius-full);
  padding: var(--space-1) var(--space-3);
  font-family: var(--font-mono);
  font-size: 0.75rem;
  color: var(--text-secondary);
  font-weight: 500;
}

.version-badge.latest {
  background: rgba(74, 222, 128, 0.1);
  border-color: rgba(74, 222, 128, 0.3);
  color: var(--success);
}

/* Warning Banner */
.warning-banner {
  background: rgba(251, 191, 36, 0.1);
  border: 1px solid rgba(251, 191, 36, 0.3);
  border-left: 3px solid var(--warning);
  border-radius: var(--radius);
  padding: var(--space-5);
  margin-bottom: var(--space-6);
}

.warning-banner-header {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  color: var(--warning);
  font-weight: 600;
  margin-bottom: var(--space-3);
}

.warning-banner-header svg {
  width: 20px;
  height: 20px;
}

.warning-banner p {
  margin: 0;
  color: var(--text-secondary);
  font-size: 0.9375rem;
}

/* Tags/Chips */
.tag {
  display: inline-flex;
  align-items: center;
  background: var(--bg-tertiary);
  border: 1px solid var(--border);
  border-radius: var(--radius-full);
  padding: var(--space-1) var(--space-3);
  font-size: 0.75rem;
  color: var(--text-secondary);
  font-weight: 500;
}

.tag-accent {
  background: rgba(109, 140, 255, 0.1);
  border-color: rgba(109, 140, 255, 0.3);
  color: var(--accent);
}

/* ============================================
   TABLES
   ============================================ */

.data-table {
  width: 100%;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  background: var(--surface);
}

.data-table th,
.data-table td {
  padding: var(--space-4);
  text-align: left;
  border-bottom: 1px solid var(--border);
}

.data-table th {
  background: var(--bg-tertiary);
  font-weight: 600;
  font-size: 0.875rem;
  color: var(--text-primary);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  font-size: 0.75rem;
}

.data-table td {
  font-size: 0.875rem;
  color: var(--text-secondary);
}

.data-table tr:last-child td {
  border-bottom: none;
}

.data-table tr:hover td {
  background: var(--surface-hover);
}

/* Permission Node Styling */
.perm-node {
  font-family: var(--font-mono);
  font-size: 0.8125rem;
  background: var(--bg-tertiary);
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  color: var(--accent);
}

/* Command Syntax */
.command-syntax {
  font-family: var(--font-mono);
  font-size: 0.9375rem;
  background: var(--bg-tertiary);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius);
  border: 1px solid var(--border);
  color: var(--text-primary);
}

.arg-required {
  color: var(--danger);
  font-weight: 500;
}

.arg-optional {
  color: var(--info);
  font-style: italic;
}

/* Grid Layouts */
.grid-2 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-6);
}

.grid-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
}

.grid-4 {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-6);
}

/* Responsive grids */
@media (max-width: 1024px) {
  .grid-4 { grid-template-columns: repeat(2, 1fr); }
  .grid-3 { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
  .grid-4,
  .grid-3,
  .grid-2 {
    grid-template-columns: 1fr;
  }
  
  .plugin-card-header {
    flex-direction: column;
    align-items: flex-start;
  }
}

/* Section spacing */
section {
  margin-bottom: var(--space-12);
}

.section-title {
  font-size: 1.5rem;
  margin-bottom: var(--space-6);
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

/* Quick Links Grid */
.quick-links {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: var(--space-4);
}

/* Support Grid */
.support-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
}

@media (max-width: 768px) {
  .support-grid {
    grid-template-columns: 1fr;
  }
}

/* Collapsible Section */
.collapsible {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  margin-bottom: var(--space-4);
}

.collapsible-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-4) var(--space-5);
  background: var(--surface);
  cursor: pointer;
  transition: background-color var(--transition-fast);
}

.collapsible-header:hover {
  background: var(--surface-hover);
}

.collapsible-title {
  font-weight: 600;
  color: var(--text-primary);
}

.collapsible-arrow {
  color: var(--text-muted);
  transition: transform var(--transition);
}

.collapsible.expanded .collapsible-arrow {
  transform: rotate(180deg);
}

.collapsible-content {
  max-height: 0;
  overflow: hidden;
  transition: max-height var(--transition-slow);
  background: var(--bg-secondary);
}

.collapsible.expanded .collapsible-content {
  max-height: 2000px;
}

.collapsible-inner {
  padding: var(--space-5);
}

/* Placeholder Card (Coming Soon) */
.placeholder-card {
  opacity: 0.6;
  border-style: dashed;
}

.placeholder-card .plugin-icon {
  background: var(--bg-tertiary);
  color: var(--text-muted);
}

/* Feature Grid for EssentialsC page */
.feature-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
}

@media (max-width: 1024px) {
  .feature-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 640px) {
  .feature-grid {
    grid-template-columns: 1fr;
  }
}

/* Documentation Cards Grid */
.docs-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
}

@media (max-width: 1024px) {
  .docs-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 640px) {
  .docs-grid {
    grid-template-columns: 1fr;
  }
}