Customize Handsontable's appearance using CSS variables to create consistent themes and styles across your application.
 
 CSS variables provide a powerful and flexible way to customize Handsontable's appearance by adjusting design elements such as colors, spacing, borders, and typography to match your application's design system. Those variables gives you granular control over every visual aspect of the data grid, from basic styling to advanced component customization.
 We provide multiple approaches for leveraging CSS variables to create any look that your designer can imagine. From quick theme modifications to completely custom designs, your options include:
 Override built-in theme variables  to quickly customize existing themes like ht-theme-main.Create custom theme files  by copying and modifying existing theme SCSS files.Use the Figma Theme Generator  to convert design tokens into CSS variables automatically. The data grid's styling system is built entirely on CSS variables, with over 200 variables organized into logical categories covering typography, colors, spacing, borders, and component-specific styling listed below.
 Follow these steps  to apply a theme, then override the variables for your chosen theme.
 Here's an example for .ht-theme-main:
 
 
 
  
 Creating a custom theme is straightforward. You just need a local clone of the Handsontable repository(opens new window)   and follow these steps to set up your custom design:
 1. Create a new SCSS file  Start by copying one of the SCSS files in the handsontable/src/styles/themes directory, such as main.scss(opens new window) falcon.scss.
 Next, customize the existing variables to match your design requirements. If you need icons, you can use the ones already declared such as the main theme icons in this example or create your own icons in the handsontable/src/styles/themes/utils/[theme]/_icons.scss directory. To use your custom icons, update the @use "utils/[theme]/icons"; directive accordingly.
 2. Compile your SCSS file  After customizing your theme file, you'll need to compile it into CSS. To do this, run the build command in the handsontable/handsontable directory.
 3. Load and apply the theme  Include the new CSS file into your project, ensuring it's loaded after the base CSS file (handsontable/styles/handsontable.min.css). If you're using imports, it might look like this:
 To apply a theme, use the themeName option by specifying it in the configuration, like this:
 
 
 
 
 To create a new theme or modify an existing one in Figma, visit the Handsontable Theme Generator(opens new window)   and follow the instructions to convert your Figma tokens into a CSS theme file that works with Handsontable. The Theme Generator will help you transform the JSON tokens exported from Figma into a properly formatted CSS theme file.
 Handsontable provides a comprehensive set of CSS variables that allow you to customize the appearance of every component. These variables are organized into logical categories for easy reference.
 Variable  Description --ht-font-sizeBase font size for all text elements --ht-font-size-smallFont size for smaller text --ht-line-heightLine height for text elements --ht-line-height-smallLine height for smaller text --ht-font-weightFont weight for text elements --ht-letter-spacingLetter spacing for text elements 
Variable  Description --ht-gap-sizeStandard gap size used throughout the component --ht-icon-sizeSize of icons throughout the interface --ht-table-transitionTransition duration for table animations 
Variable  Description --ht-border-colorDefault border color for all elements --ht-accent-colorPrimary accent color used for highlights and active states --ht-foreground-colorPrimary text color --ht-foreground-secondary-colorSecondary text color --ht-background-colorPrimary background color --ht-placeholder-colorColor for placeholder text --ht-read-only-colorColor for read-only text --ht-disabled-colorColor for disabled elements 
Variable  Description --ht-shadow-colorBase color used for shadows --ht-shadow-xHorizontal offset of shadows --ht-shadow-yVertical offset of shadows --ht-shadow-blurBlur radius of shadows 
Variable  Description --ht-cell-horizontal-border-colorColor of horizontal cell borders --ht-cell-vertical-border-colorColor of vertical cell borders 
Variable  Description --ht-wrapper-border-widthWidth of the table wrapper border --ht-wrapper-border-radiusBorder radius of the table wrapper --ht-wrapper-border-colorColor of the table wrapper border 
Variable  Description --ht-row-header-odd-background-colorBackground color for odd row headers --ht-row-header-even-background-colorBackground color for even row headers --ht-row-cell-odd-background-colorBackground color for odd row cells --ht-row-cell-even-background-colorBackground color for even row cells 
Variable  Description --ht-cell-horizontal-paddingHorizontal padding inside cells --ht-cell-vertical-paddingVertical padding inside cells 
Variable  Description --ht-cell-editor-border-widthBorder width of cell editors --ht-cell-editor-border-colorBorder color of cell editors --ht-cell-editor-foreground-colorText color in cell editors --ht-cell-editor-background-colorBackground color of cell editors --ht-cell-editor-shadow-blur-radiusShadow blur radius for cell editors --ht-cell-editor-shadow-colorShadow color for cell editors 
Variable  Description --ht-cell-success-background-colorBackground color for successful cell operations --ht-cell-error-background-colorBackground color for error states in cells --ht-cell-read-only-background-colorBackground color for read-only cells 
Variable  Description --ht-cell-selection-border-colorBorder color for selected cells --ht-cell-selection-background-colorBackground color for selected cells 
Variable  Description --ht-cell-autofill-sizeSize of the autofill handle --ht-cell-autofill-border-widthBorder width of autofill elements --ht-cell-autofill-border-radiusBorder radius of autofill elements --ht-cell-autofill-border-colorBorder color of autofill elements --ht-cell-autofill-background-colorBackground color of autofill elements --ht-cell-autofill-fill-border-colorBorder color of autofill fill indicator 
Variable  Description --ht-cell-mobile-handle-sizeSize of mobile touch handles --ht-cell-mobile-handle-border-widthBorder width of mobile handles --ht-cell-mobile-handle-border-radiusBorder radius of mobile handles --ht-cell-mobile-handle-border-colorBorder color of mobile handles --ht-cell-mobile-handle-background-colorBackground color of mobile handles 
Variable  Description --ht-resize-indicator-colorColor of resize indicators --ht-move-backlight-colorBackground color for move operations --ht-move-indicator-colorColor of move indicators --ht-hidden-indicator-colorColor of hidden element indicators 
Variable  Description --ht-scrollbar-border-radiusBorder radius of scrollbars --ht-scrollbar-track-colorBackground color of scrollbar tracks --ht-scrollbar-thumb-colorColor of scrollbar thumbs 
Variable  Description --ht-header-font-weightFont weight for header text --ht-header-foreground-colorText color for headers --ht-header-background-colorBackground color for headers --ht-header-highlighted-shadow-sizeShadow size for highlighted headers --ht-header-highlighted-foreground-colorText color for highlighted headers --ht-header-highlighted-background-colorBackground color for highlighted headers --ht-header-active-border-colorBorder color for active headers --ht-header-active-foreground-colorText color for active headers --ht-header-active-background-colorBackground color for active headers --ht-header-filter-background-colorBackground color for header filters 
Variable  Description --ht-header-row-foreground-colorText color for header rows --ht-header-row-background-colorBackground color for header rows --ht-header-row-highlighted-foreground-colorText color for highlighted header rows --ht-header-row-highlighted-background-colorBackground color for highlighted header rows --ht-header-row-active-foreground-colorText color for active header rows --ht-header-row-active-background-colorBackground color for active header rows 
Variable  Description --ht-checkbox-sizeSize of checkbox elements --ht-checkbox-border-radiusBorder radius of checkboxes --ht-checkbox-border-colorBorder color of checkboxes --ht-checkbox-background-colorBackground color of checkboxes --ht-checkbox-icon-colorColor of checkbox icons --ht-checkbox-focus-border-colorBorder color of focused checkboxes --ht-checkbox-focus-background-colorBackground color of focused checkboxes --ht-checkbox-focus-icon-colorIcon color of focused checkboxes --ht-checkbox-focus-ring-colorFocus ring color for checkboxes --ht-checkbox-disabled-border-colorBorder color of disabled checkboxes --ht-checkbox-disabled-background-colorBackground color of disabled checkboxes --ht-checkbox-disabled-icon-colorIcon color of disabled checkboxes --ht-checkbox-checked-border-colorBorder color of checked checkboxes --ht-checkbox-checked-background-colorBackground color of checked checkboxes --ht-checkbox-checked-icon-colorIcon color of checked checkboxes --ht-checkbox-checked-focus-border-colorBorder color of focused checked checkboxes --ht-checkbox-checked-focus-background-colorBackground color of focused checked checkboxes --ht-checkbox-checked-focus-icon-colorIcon color of focused checked checkboxes --ht-checkbox-checked-disabled-border-colorBorder color of disabled checked checkboxes --ht-checkbox-checked-disabled-background-colorBackground color of disabled checked checkboxes --ht-checkbox-checked-disabled-icon-colorIcon color of disabled checked checkboxes --ht-checkbox-indeterminate-border-colorBorder color of indeterminate checkboxes --ht-checkbox-indeterminate-background-colorBackground color of indeterminate checkboxes --ht-checkbox-indeterminate-icon-colorIcon color of indeterminate checkboxes --ht-checkbox-indeterminate-focus-border-colorBorder color of focused indeterminate checkboxes --ht-checkbox-indeterminate-focus-background-colorBackground color of focused indeterminate checkboxes --ht-checkbox-indeterminate-focus-icon-colorIcon color of focused indeterminate checkboxes --ht-checkbox-indeterminate-disabled-border-colorBorder color of disabled indeterminate checkboxes --ht-checkbox-indeterminate-disabled-background-colorBackground color of disabled indeterminate checkboxes --ht-checkbox-indeterminate-disabled-icon-colorIcon color of disabled indeterminate checkboxes 
Variable  Description --ht-radio-sizeSize of radio button elements --ht-radio-border-colorBorder color of radio buttons --ht-radio-background-colorBackground color of radio buttons --ht-radio-icon-colorColor of radio button icons --ht-radio-focus-border-colorBorder color of focused radio buttons --ht-radio-focus-background-colorBackground color of focused radio buttons --ht-radio-focus-icon-colorIcon color of focused radio buttons --ht-radio-focus-ring-colorFocus ring color for radio buttons --ht-radio-disabled-border-colorBorder color of disabled radio buttons --ht-radio-disabled-background-colorBackground color of disabled radio buttons --ht-radio-disabled-icon-colorIcon color of disabled radio buttons --ht-radio-checked-border-colorBorder color of checked radio buttons --ht-radio-checked-background-colorBackground color of checked radio buttons --ht-radio-checked-icon-colorIcon color of checked radio buttons --ht-radio-checked-focus-border-colorBorder color of focused checked radio buttons --ht-radio-checked-focus-background-colorBackground color of focused checked radio buttons --ht-radio-checked-focus-icon-colorIcon color of focused checked radio buttons --ht-radio-checked-disabled-border-colorBorder color of disabled checked radio buttons --ht-radio-checked-disabled-background-colorBackground color of disabled checked radio buttons --ht-radio-checked-disabled-icon-colorIcon color of disabled checked radio buttons 
Variable  Description --ht-icon-button-border-radiusBorder radius of icon buttons --ht-icon-button-large-border-radiusBorder radius of large icon buttons --ht-icon-button-large-paddingPadding of large icon buttons --ht-icon-button-border-colorBorder color of icon buttons --ht-icon-button-background-colorBackground color of icon buttons --ht-icon-button-icon-colorColor of icon button icons --ht-icon-button-hover-border-colorBorder color of hovered icon buttons --ht-icon-button-hover-background-colorBackground color of hovered icon buttons --ht-icon-button-hover-icon-colorIcon color of hovered icon buttons --ht-icon-button-active-border-colorBorder color of active icon buttons --ht-icon-button-active-background-colorBackground color of active icon buttons --ht-icon-button-active-icon-colorIcon color of active icon buttons --ht-icon-button-active-hover-border-colorBorder color of hovered active icon buttons --ht-icon-button-active-hover-background-colorBackground color of hovered active icon buttons --ht-icon-button-active-hover-icon-colorIcon color of hovered active icon buttons 
Variable  Description --ht-collapse-button-border-radiusBorder radius of collapse buttons --ht-collapse-button-open-border-colorBorder color of open collapse buttons --ht-collapse-button-open-background-colorBackground color of open collapse buttons --ht-collapse-button-open-icon-colorIcon color of open collapse buttons --ht-collapse-button-open-icon-active-colorActive icon color of open collapse buttons --ht-collapse-button-open-hover-border-colorBorder color of hovered open collapse buttons --ht-collapse-button-open-hover-background-colorBackground color of hovered open collapse buttons --ht-collapse-button-open-hover-icon-colorIcon color of hovered open collapse buttons --ht-collapse-button-open-hover-icon-active-colorActive icon color of hovered open collapse buttons --ht-collapse-button-close-border-colorBorder color of closed collapse buttons --ht-collapse-button-close-background-colorBackground color of closed collapse buttons --ht-collapse-button-close-icon-colorIcon color of closed collapse buttons --ht-collapse-button-close-icon-active-colorActive icon color of closed collapse buttons --ht-collapse-button-close-hover-border-colorBorder color of hovered closed collapse buttons --ht-collapse-button-close-hover-background-colorBackground color of hovered closed collapse buttons --ht-collapse-button-close-hover-icon-colorIcon color of hovered closed collapse buttons --ht-collapse-button-close-hover-icon-active-colorActive icon color of hovered closed collapse buttons 
Variable  Description --ht-button-border-radiusBorder radius of buttons --ht-button-horizontal-paddingHorizontal padding of buttons --ht-button-vertical-paddingVertical padding of buttons 
Variable  Description --ht-primary-button-border-colorBorder color of primary buttons --ht-primary-button-foreground-colorText color of primary buttons --ht-primary-button-background-colorBackground color of primary buttons --ht-primary-button-disabled-border-colorBorder color of disabled primary buttons --ht-primary-button-disabled-foreground-colorText color of disabled primary buttons --ht-primary-button-disabled-background-colorBackground color of disabled primary buttons --ht-primary-button-hover-border-colorBorder color of hovered primary buttons --ht-primary-button-hover-foreground-colorText color of hovered primary buttons --ht-primary-button-hover-background-colorBackground color of hovered primary buttons --ht-primary-button-focus-border-colorBorder color of focused primary buttons --ht-primary-button-focus-foreground-colorText color of focused primary buttons --ht-primary-button-focus-background-colorBackground color of focused primary buttons 
Variable  Description --ht-secondary-button-border-colorBorder color of secondary buttons --ht-secondary-button-foreground-colorText color of secondary buttons --ht-secondary-button-background-colorBackground color of secondary buttons --ht-secondary-button-disabled-border-colorBorder color of disabled secondary buttons --ht-secondary-button-disabled-foreground-colorText color of disabled secondary buttons --ht-secondary-button-disabled-background-colorBackground color of disabled secondary buttons --ht-secondary-button-hover-border-colorBorder color of hovered secondary buttons --ht-secondary-button-hover-foreground-colorText color of hovered secondary buttons --ht-secondary-button-hover-background-colorBackground color of hovered secondary buttons --ht-secondary-button-focus-border-colorBorder color of focused secondary buttons --ht-secondary-button-focus-foreground-colorText color of focused secondary buttons --ht-secondary-button-focus-background-colorBackground color of focused secondary buttons 
Variable  Description --ht-comments-textarea-horizontal-paddingHorizontal padding of comment textareas --ht-comments-textarea-vertical-paddingVertical padding of comment textareas --ht-comments-textarea-border-widthBorder width of comment textareas --ht-comments-textarea-border-colorBorder color of comment textareas --ht-comments-textarea-foreground-colorText color of comment textareas --ht-comments-textarea-background-colorBackground color of comment textareas --ht-comments-textarea-focus-border-widthBorder width of focused comment textareas --ht-comments-textarea-focus-border-colorBorder color of focused comment textareas --ht-comments-textarea-focus-foreground-colorText color of focused comment textareas --ht-comments-textarea-focus-background-colorBackground color of focused comment textareas --ht-comments-indicator-sizeSize of comment indicators --ht-comments-indicator-colorColor of comment indicators 
Variable  Description --ht-license-horizontal-paddingHorizontal padding of license elements --ht-license-vertical-paddingVertical padding of license elements --ht-license-foreground-colorText color of license elements --ht-license-background-colorBackground color of license elements 
Variable  Description --ht-link-colorColor of links --ht-link-hover-colorColor of hovered links 
Variable  Description --ht-input-border-widthBorder width of input elements --ht-input-border-radiusBorder radius of input elements --ht-input-horizontal-paddingHorizontal padding of input elements --ht-input-vertical-paddingVertical padding of input elements --ht-input-border-colorBorder color of input elements --ht-input-foreground-colorText color of input elements --ht-input-background-colorBackground color of input elements --ht-input-hover-border-colorBorder color of hovered input elements --ht-input-hover-foreground-colorText color of hovered input elements --ht-input-hover-background-colorBackground color of hovered input elements --ht-input-disabled-border-colorBorder color of disabled input elements --ht-input-disabled-foreground-colorText color of disabled input elements --ht-input-disabled-background-colorBackground color of disabled input elements --ht-input-focus-border-colorBorder color of focused input elements --ht-input-focus-foreground-colorText color of focused input elements --ht-input-focus-background-colorBackground color of focused input elements 
Variable  Description --ht-menu-border-widthBorder width of menu elements --ht-menu-border-radiusBorder radius of menu elements --ht-menu-horizontal-paddingHorizontal padding of menu elements --ht-menu-vertical-paddingVertical padding of menu elements --ht-menu-item-horizontal-paddingHorizontal padding of menu items --ht-menu-item-vertical-paddingVertical padding of menu items --ht-menu-border-colorBorder color of menu elements --ht-menu-shadow-xHorizontal shadow offset of menus --ht-menu-shadow-yVertical shadow offset of menus --ht-menu-shadow-blurShadow blur radius of menus --ht-menu-shadow-colorShadow color of menus --ht-menu-item-hover-colorBackground color of hovered menu items --ht-menu-item-active-colorBackground color of active menu items 
Variable  Description --ht-dialog-semi-transparent-background-colorSemi-transparent background color of dialog overlay --ht-dialog-solid-background-colorSolid background color of dialog overlay --ht-dialog-content-padding-horizontalHorizontal padding of dialog content --ht-dialog-content-padding-verticalVertical padding of dialog content --ht-dialog-content-border-radiusBorder radius of dialog content --ht-dialog-content-background-colorBackground color of dialog content 
Variable  Description --ht-pagination-bar-foreground-colorText color of pagination bar --ht-pagination-bar-background-colorBackground color of pagination bar --ht-pagination-bar-horizontal-paddingHorizontal padding of pagination bar --ht-pagination-bar-vertical-paddingVertical padding of pagination bar