.#{$prefix}grid-body {
    background: $grid-body-background-color;
    border-width: $grid-body-border-width;
    border-style: $grid-body-border-style;
    border-color: $grid-body-border-color;
}

.#{$prefix}grid-empty {
    padding: $grid-empty-padding;
    color: $grid-empty-color;
    background-color: $grid-empty-background-color;
    font: $grid-empty-font-weight $grid-empty-font-size $grid-empty-font-family;
}

.#{$prefix}grid-cell {
    @if $grid-row-cell-color {
        color: $grid-row-cell-color;
    }
    font: $grid-row-cell-font;
    background-color: $grid-row-cell-background-color;
    border-color: $grid-row-cell-border-color;
    border-style: $grid-row-cell-border-style;
}

.#{$prefix}grid-td {
    .#{$prefix}grid-row-alt & {
        background-color: $grid-row-cell-alt-background-color;
    }

    .#{$prefix}grid-row-before-over & {
        border-bottom-style: $grid-row-cell-over-border-style;
        border-bottom-color: $grid-row-cell-over-border-color;
    }

    .#{$prefix}grid-row-over & {
        border-bottom-style: $grid-row-cell-over-border-style;
        border-bottom-color: $grid-row-cell-over-border-color;
    }

    .#{$prefix}grid-row-before-selected & {
        border-bottom-style: $grid-row-cell-selected-border-style;
        border-bottom-color: $grid-row-cell-selected-border-color;
    }

    .#{$prefix}grid-row-selected & {
        border-bottom-style: $grid-row-cell-selected-border-style;
        border-bottom-color: $grid-row-cell-selected-border-color;
    }

    .#{$prefix}grid-row-before-focused & {
        border-bottom-style: $grid-row-cell-focus-border-style;
        border-bottom-color: $grid-row-cell-focus-border-color;
        @if $grid-no-row-lines-show-focus-border {
            border-bottom-width: $grid-row-cell-border-width
        }
    }

    .#{$prefix}grid-row-focused & {
        @if $grid-row-cell-focus-color != $grid-row-cell-color {
            color: $grid-row-cell-focus-color;
        }
        background-color: $grid-row-cell-focus-background-color;
    }

    .#{$prefix}grid-row-over & {
        @if $grid-row-cell-over-color != $grid-row-cell-color or
            $grid-row-cell-over-color != $grid-row-cell-focus-color {
            color: $grid-row-cell-over-color;
        }
        background-color: $grid-row-cell-over-background-color;
    }

    .#{$prefix}grid-row-selected & {
        @if $grid-row-cell-selected-color != $grid-row-cell-color or
            $grid-row-cell-selected-color != $grid-row-cell-focus-color or
            $grid-row-cell-selected-color != $grid-row-cell-over-color {
            color: $grid-row-cell-selected-color;
        }
        background-color: $grid-row-cell-selected-background-color;
    }

    .#{$prefix}grid-row-focused & {
        border-bottom-style: $grid-row-cell-focus-border-style;
        border-bottom-color: $grid-row-cell-focus-border-color;
        @if $grid-no-row-lines-show-focus-border {
            border-bottom-width: $grid-row-cell-border-width
        }
    }

    @if $grid-no-row-lines-show-focus-border {
        // use x-grid-table to increase specificity to equal the previous 2 rules.
        .#{$prefix}grid-table .#{$prefix}grid-row-focused-first & {
            border-top: $grid-row-cell-border-width $grid-row-cell-focus-border-style $grid-row-cell-focus-border-color;
        }
    } @else {
        .#{$prefix}grid-with-row-lines .#{$prefix}grid-row-focused-first & {
            border-top: $grid-row-cell-border-width $grid-row-cell-focus-border-style $grid-row-cell-focus-border-color;
        }
    }

    // The two rules below ensure that summary rows which are embedded within
    // selected/focused wrapped rows do not also get a visible border.
    .#{$prefix}grid-row-selected .#{$prefix}grid-row-summary & {
        border-bottom-color: $grid-row-cell-selected-background-color;
        border-top-width: 0;
    }

    .#{$prefix}grid-row-focused .#{$prefix}grid-row-summary & {
        border-bottom-color: $grid-row-cell-focus-background-color;
        border-top-width: 0;
    }
}

.#{$prefix}grid-with-row-lines {
    .#{$prefix}grid-td {
        border-bottom-width: $grid-row-cell-border-width;
    }

    // since the top border of each row is the bottom border of the row above, the top
    // border of the first row goes on the table element.
    .#{$prefix}grid-table {
        border-top: $grid-row-cell-border-width solid $grid-row-cell-background-color;
    }

    .#{$prefix}grid-table-over-first {
        border-top-style: $grid-row-cell-over-border-style;
        border-top-color: $grid-row-cell-over-border-color;
    }

    .#{$prefix}grid-table-selected-first {
        border-top-style: $grid-row-cell-selected-border-style;
        border-top-color: $grid-row-cell-selected-border-color;
    }
}

@if $grid-no-row-lines-show-focus-border {
    // use grid-view class to increase specificity to match the previous rules for
    // over/selected
    .#{$prefix}grid-body .#{$prefix}grid-table-focused-first {
        border-top: $grid-row-cell-border-width $grid-row-cell-focus-border-style $grid-row-cell-focus-border-color;
    }
} @else {
    .#{$prefix}grid-with-row-lines .#{$prefix}grid-table-focused-first {
        border-top-style: $grid-row-cell-focus-border-style;
        border-top-color: $grid-row-cell-focus-border-color;
    }
}

.#{$prefix}grid-cell-inner {
    text-overflow: $grid-cell-inner-text-overflow;
    padding: $grid-cell-inner-padding;
}

@if $include-rtl and (left($grid-cell-inner-padding) != right($grid-cell-inner-padding)) {
    .#{$prefix}rtl.#{$prefix}grid-cell-inner {
        padding: rtl($grid-cell-inner-padding);
    }
}

@if $grid-no-row-lines-show-focus-border {
    .#{$prefix}grid-no-row-lines {
        .#{$prefix}grid-row-focused {
            .#{$prefix}grid-cell-inner {
                // when the grid has no row lines we need to subtract the border width from the 
                // top and bottom padding when the row is focused so that the focus border does
                // not increase the row height.
                padding-top: top($grid-cell-inner-padding) - $grid-row-cell-border-width;
                padding-bottom: bottom($grid-cell-inner-padding) - $grid-row-cell-border-width;
            }
        }
    }
}

@if $include-ext-grid-column-rownumberer
    or $include-ext-selection-checkboxmodel
    or $include-ext-grid-plugin-rowexpander {
    // .x-grid-cell-special is used by RowNumberer, CheckboxModel, and RowExpander
    .#{$prefix}grid-cell-special {
        @if $grid-cell-special-border-width != 0 {
            border-color: $grid-cell-special-border-color;
            border-style: $grid-cell-special-border-style;
            border-right-width: $grid-cell-special-border-width;
        }
        @if $grid-cell-special-background-color != null {
            @if $grid-cell-special-background-gradient == null {
                background-color: $grid-cell-special-background-color;
            } @else {
                @include background-gradient($grid-cell-special-background-color, $grid-cell-special-background-gradient);
            }

            .#{$prefix}grid-row-selected & {
                @if $grid-cell-special-selected-border-color != null {
                    border-right-color: $grid-cell-special-selected-border-color;
                }

                @if $grid-row-cell-selected-background-color != null {
                    @if $grid-cell-special-background-gradient == null {
                        background-color: $grid-row-cell-selected-background-color;
                    } @else {
                        @include background-gradient($grid-row-cell-selected-background-color, $grid-cell-special-background-gradient, left);
                    }
                }
            }

            @if not $supports-gradients or $compile-all {
                .#{$prefix}nlg & {
                    background-repeat: repeat-y;
                    background-image: slicer-background-image(grid-cell-special, 'grid/cell-special-bg');
                }

                .#{$prefix}nlg .#{$prefix}grid-row-selected & {
                    background-image: slicer-background-image(grid-cell-special-selected, 'grid/cell-special-selected-bg');
                }
                @include x-slicer(grid-cell-special);
                @include x-slicer(grid-cell-special-selected);
            }
        }
    }

    @if $include-rtl and $grid-cell-special-border-width != 0 {
        .#{$prefix}rtl.#{$prefix}grid-cell-special {
            border-right-width: 0;
            border-left-width: $grid-cell-special-border-width;
        }
    }
}

.#{$prefix}grid-dirty-cell {
    background: theme-background-image('grid/dirty') no-repeat 0 0;
}

@if $include-rtl {
    .#{$prefix}rtl.#{$prefix}grid-dirty-cell {
        background-image: theme-background-image('grid/dirty-rtl');
        background-position: right 0;
    }
}

// add grid-row class to increase specificity over the state rules that set background-color
// e.g. .x-grid-row-over .x-grid-td, .x-grid-row-focused .x-grid-td
.#{$prefix}grid-row .#{$prefix}grid-cell-selected {
    color: $grid-cell-selected-color;
    background-color: $grid-cell-selected-background-color;
}

// Column lines on leading edge where there may be whitespace following
.#{$prefix}grid-with-col-lines .#{$prefix}grid-cell {
    border-right-width: $grid-row-cell-border-width;
}

// Column lines in RTL mode - leading edge is left.
@if $include-rtl {
    .#{$prefix}rtl.#{$prefix}grid-with-col-lines .#{$prefix}grid-cell {
        border-right-width: 0;
        border-left-width: $grid-row-cell-border-width;
    }
}

.#{$prefix}grid-resize-marker {
    width: $grid-row-cell-border-width;
    background-color: $grid-resize-marker-background-color;
}