Jamdesk Documentation logo

CSS Personalizado

Añade CSS personalizado para sobreescribir estilos del tema, ajustar tipografía o agregar estilos específicos de marca. Jamdesk expone variables CSS para personalizaciones comunes.

Los temas de Jamdesk proporcionan valores predeterminados sensatos, pero puedes añadir CSS personalizado para adaptarlos a tu marca o ajustar estilos específicos.

Añadir CSS Personalizado

Crea un archivo CSS en el directorio de tu documentación y referéncialo en docs.json:

docs.json
{
  "styling": {
    "css": "/custom.css"
  }
}
custom.css
/* Your custom styles */
.content h1 {
  font-size: 2.5rem;
}

Variables CSS

Jamdesk expone variables CSS para personalizaciones comunes. Sobreescríbelas en tu CSS personalizado:

custom.css
:root {
  /* Typography */
  --font-family-sans: 'Inter', system-ui, sans-serif;
  --font-family-mono: 'JetBrains Mono', monospace;
  
  /* Spacing */
  --content-max-width: 900px;
  --sidebar-width: 280px;
  
  /* Border radius */
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 12px;
}

Variables de Color

Los colores primarios se definen en docs.json. Para un control más preciso, sobreescribe estas variables:

custom.css
:root {
  /* Light mode */
  --color-background: #ffffff;
  --color-text: #1a1a1a;
  --color-text-muted: #666666;
  --color-border: #e5e5e5;
  --color-code-bg: #f5f5f5;
}

[data-theme="dark"] {
  /* Dark mode */
  --color-background: #0a0a0a;
  --color-text: #fafafa;
  --color-text-muted: #a3a3a3;
  --color-border: #262626;
  --color-code-bg: #171717;
}

Personalizaciones Comunes

Ajustar el Ancho del Contenido

:root {
  --content-max-width: 1000px;  /* Default: 900px */
}

Cambiar la Fuente de los Bloques de Código

:root {
  --font-family-mono: 'Fira Code', monospace;
}

/* Ensure ligatures work if your font supports them */
pre code {
  font-variant-ligatures: common-ligatures;
}

Personalizar los Estilos de Enlace

.content a:not([class]) {
  color: var(--color-primary);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.content a:not([class]):hover {
  text-decoration-thickness: 2px;
}

Ajustar el Espaciado de los Encabezados

.content h2 {
  margin-top: 3rem;
  margin-bottom: 1rem;
}

.content h3 {
  margin-top: 2rem;
  margin-bottom: 0.75rem;
}

Estilizar los Bloques de Aviso

/* Make Note callouts more prominent */
[data-callout="note"] {
  border-left-width: 4px;
  background: var(--color-primary-subtle);
}

Modo Oscuro

Usa el selector [data-theme="dark"] para los estilos del modo oscuro:

/* Light mode */
.custom-banner {
  background: #f0f4ff;
  color: #1e3a5f;
}

/* Dark mode */
[data-theme="dark"] .custom-banner {
  background: #1e293b;
  color: #e2e8f0;
}

Apuntar a Componentes

Sobreescribe estilos para componentes específicos:

/* Card component */
[data-component="card"] {
  border-radius: 16px;
}

/* Code blocks */
[data-component="code-block"] {
  border-radius: 8px;
}

/* Tabs */
[data-component="tabs"] [data-state="active"] {
  border-bottom-width: 3px;
}

Fuentes Externas

Carga fuentes personalizadas con @import o @font-face:

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');

:root {
  --font-family-sans: 'Inter', system-ui, sans-serif;
}

O aloja las fuentes tú mismo:

@font-face {
  font-family: 'CustomFont';
  src: url('/fonts/custom-font.woff2') format('woff2');
  font-weight: 400;
  font-display: swap;
}

Estilos Responsivos

Usa media queries para ajustes responsivos:

/* Mobile adjustments */
@media (max-width: 768px) {
  .content h1 {
    font-size: 1.75rem;
  }
  
  :root {
    --content-max-width: 100%;
  }
}

Depuración

Usa las herramientas de desarrollador del navegador para inspeccionar elementos y encontrar los selectores correctos. Jamdesk usa atributos de datos para apuntar a componentes:

  • data-component="..." - Tipo de componente
  • data-theme="light|dark" - Tema actual
  • data-state="..." - Estado del componente (activo, deshabilitado, etc.)

Limitaciones

  • El CSS se aplica de forma global; usa selectores específicos para evitar conflictos
  • Algunos estilos de diseño internos usan !important y pueden requerir lo mismo para sobreescribirse
  • Los cambios requieren un rebuild para tener efecto

¿Qué sigue?

Temas

Elige y configura temas

Branding

Logotipos, colores e identidad de marca