/* ===========================================
   Shortcode Styles - Terminal Theme
   =========================================== */

/* Details/Accordion */
.shortcode-details {
  margin: 1rem 0;
  border: 1px solid var(--term-border, var(--border));
  border-radius: 6px;
  overflow: hidden;
  background: var(--term-bg-elevated, var(--code-bg));
}

.shortcode-details summary {
  padding: 0.75rem 1rem;
  background: var(--term-bg-subtle, var(--code-bg));
  cursor: pointer;
  font-weight: 500;
  list-style: none;
  font-family: var(--font-mono, monospace);
  color: var(--term-text, var(--primary));
}

.shortcode-details summary::-webkit-details-marker {
  display: none;
}

.shortcode-details summary::before {
  content: ">";
  display: inline-block;
  margin-right: 0.5rem;
  transition: transform 0.2s;
  color: var(--term-green, #3fb950);
}

.shortcode-details[open] summary::before {
  transform: rotate(90deg);
}

.shortcode-details .details-content {
  padding: 1rem;
  border-top: 1px solid var(--term-border, var(--border));
}

/* Tabs */
.shortcode-tabs {
  margin: 1.5rem 0;
  border: 1px solid var(--term-border, var(--border));
  border-radius: 6px;
  overflow: hidden;
  background: var(--term-bg-elevated, var(--entry));
}

.tabs-nav {
  display: flex;
  background: var(--term-bg-subtle, var(--code-bg));
  border-bottom: 1px solid var(--term-border, var(--border));
  overflow-x: auto;
}

.tab-btn {
  padding: 0.75rem 1.25rem;
  border: none;
  background: transparent;
  color: var(--term-text-muted, var(--secondary));
  cursor: pointer;
  font-size: 0.9rem;
  font-weight: 500;
  font-family: var(--font-mono, monospace);
  white-space: nowrap;
  transition: color 0.2s, border-color 0.2s;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
}

.tab-btn:hover {
  color: var(--term-text, var(--primary));
}

.tab-btn.active {
  color: var(--term-green, #3fb950);
  border-bottom-color: var(--term-green, #3fb950);
  background: var(--term-bg-elevated, var(--theme));
}

.tabs-content {
  padding: 1rem;
}

.tab-pane {
  display: none;
}

.tab-pane.active {
  display: block;
}

/* Note/Callout boxes */
.shortcode-note {
  display: flex;
  gap: 0.75rem;
  margin: 1.5rem 0;
  padding: 1rem;
  border-radius: 6px;
  border-left: 3px solid;
  background: var(--term-bg-elevated, rgba(0,0,0,0.1));
}

.note-icon {
  flex-shrink: 0;
  width: 1.5rem;
  height: 1.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 4px;
  font-weight: bold;
  font-size: 0.75rem;
  font-family: var(--font-mono, monospace);
}

.note-content {
  flex: 1;
  min-width: 0;
}

.note-title {
  display: block;
  margin-bottom: 0.25rem;
  font-family: var(--font-mono, monospace);
  font-weight: 600;
}

.note-info {
  background: var(--term-bg-elevated, rgba(59, 130, 246, 0.1));
  border-color: var(--term-blue, #58a6ff);
}

.note-info .note-icon {
  background: var(--term-blue, #58a6ff);
  color: var(--term-bg, #0d1117);
}

.note-warning {
  background: var(--term-bg-elevated, rgba(245, 158, 11, 0.1));
  border-color: var(--term-amber, #d29922);
}

.note-warning .note-icon {
  background: var(--term-amber, #d29922);
  color: var(--term-bg, #0d1117);
}

.note-danger {
  background: var(--term-bg-elevated, rgba(239, 68, 68, 0.1));
  border-color: var(--term-red, #f85149);
}

.note-danger .note-icon {
  background: var(--term-red, #f85149);
  color: var(--term-bg, #0d1117);
}

.note-success {
  background: var(--term-bg-elevated, rgba(34, 197, 94, 0.1));
  border-color: var(--term-green, #3fb950);
}

.note-success .note-icon {
  background: var(--term-green, #3fb950);
  color: var(--term-bg, #0d1117);
}

/* Code block with filename */
.shortcode-code {
  margin: 1.5rem 0;
  border-radius: 6px;
  overflow: hidden;
  border: 1px solid var(--term-border, var(--border));
  background: var(--term-bg-subtle, var(--code-bg));
}

.code-header {
  padding: 0.5rem 1rem;
  background: var(--term-bg-elevated, var(--code-bg));
  border-bottom: 1px solid var(--term-border, var(--border));
  font-size: 0.85rem;
  color: var(--term-text-muted, var(--secondary));
}

.code-filename {
  font-family: var(--font-mono, monospace);
  color: var(--term-cyan, #39c5cf);
}

.shortcode-code .highlight {
  margin: 0;
  border-radius: 0;
}

.shortcode-code pre {
  margin: 0;
  border-radius: 0;
}

/* Callout boxes */
.callout {
  display: flex;
  gap: 0.75rem;
  margin: 1.5rem 0;
  padding: 1rem;
  border-radius: 6px;
  border-left: 3px solid;
  background: var(--term-bg-elevated, rgba(0,0,0,0.1));
}

.callout-icon {
  flex-shrink: 0;
  width: 1.5rem;
  height: 1.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 4px;
  font-weight: bold;
  font-size: 0.75rem;
  font-family: var(--font-mono, monospace);
}

.callout-content {
  flex: 1;
  min-width: 0;
}

.callout-info {
  background: var(--term-bg-elevated, rgba(59, 130, 246, 0.1));
  border-color: var(--term-blue, #58a6ff);
}

.callout-info .callout-icon {
  background: var(--term-blue, #58a6ff);
  color: var(--term-bg, #0d1117);
}

.callout-warning {
  background: var(--term-bg-elevated, rgba(245, 158, 11, 0.1));
  border-color: var(--term-amber, #d29922);
}

.callout-warning .callout-icon {
  background: var(--term-amber, #d29922);
  color: var(--term-bg, #0d1117);
}

.callout-danger {
  background: var(--term-bg-elevated, rgba(239, 68, 68, 0.1));
  border-color: var(--term-red, #f85149);
}

.callout-danger .callout-icon {
  background: var(--term-red, #f85149);
  color: var(--term-bg, #0d1117);
}

.callout-success {
  background: var(--term-bg-elevated, rgba(34, 197, 94, 0.1));
  border-color: var(--term-green, #3fb950);
}

.callout-success .callout-icon {
  background: var(--term-green, #3fb950);
  color: var(--term-bg, #0d1117);
}

/* Legacy support for old callout classes */
.callout.border-warning {
  background: var(--term-bg-elevated, rgba(245, 158, 11, 0.1));
  border-color: var(--term-amber, #d29922);
}

.callout.border-info {
  background: var(--term-bg-elevated, rgba(59, 130, 246, 0.1));
  border-color: var(--term-blue, #58a6ff);
}
