box-shadow

O box-shadow é uma propriedade do CSS, é utilizado para adicionar efeitos de sombra em volta de um elemento. Você pode especificar mais de um efeito, os separando com virgulas.

Uma box-shadow é descrita pelo deslocamentos (offset) X e Y em relação ao elemento, desfoco e propagação do raio e cor.

css
/* offset-x | offset-y | color */
box-shadow: 60px -16px teal;

/* offset-x | offset-y | blur-radius | color */
box-shadow: 10px 5px 5px black;

/* offset-x | offset-y | blur-radius | spread-radius | color */
box-shadow: 2px 2px 2px 1px rgba(0, 0, 0, 0.2);

/* inset | offset-x | offset-y | color */
box-shadow: inset 5em 1em gold;

/* Any number of shadows, separated by commas */
box-shadow:
  3px 3px red,
  -1em 0 0.4em olive;

/* Global keywords */
box-shadow: inherit;
box-shadow: initial;
box-shadow: unset;
css
box-shadow: 60px -16px teal;
css
box-shadow: 10px 5px 5px black;
css
box-shadow:
  3px 3px red,
  -1em 0 0.4em olive;
css
box-shadow: inset 5em 1em gold;
css
box-shadow: 0 0 1em gold;
css
box-shadow: inset 0 0 1em gold;
css
box-shadow:
  inset 0 0 1em gold,
  0 0 1em red;

A propriedade box-shadow permite que você adicione uma sombra em quase qualquer elemento. Se um border-radius (en-US) for especificado no elemento com uma box-shadow, a sombra assume os mesmos cantos arredondados. O comando z-ordering de múltiplas box-shadows é o mesmo que múltiplas text shadows (a primeira sombra especificada está na parte superior).

Box-shadow generator (en-US) é uma ferrament interativa qu permite a criação de box-shadow.

Initial valuenone
Aplica-se aall elements. It also applies to ::first-letter.
Inheritednão
Computed valueany length made absolute; any specified color computed; otherwise as specified
Animation type (en-US)a shadow list

Sintaxe

Especificando uma única box-shadow usando:

Para especificar mais de uma sombra, separe-as com virgula.

Valores

inset

Se não for especificado, a sombra ganha o efeito de como se a caixa fosse aumentada acima do conteúdo). A presença da palavra-chave inset muda a sombra para dentro da moldura (como se o conteúdo estivesse pressionado dentro da caixa). As sombras de inserção são desenhadas dentro da borda (mesmo as transparentes), acima do plano de fundo, mas abaixo do conteúdo.

<offset-x> <offset-y>

Existem dois valores <length> (en-US) para configurar o desvio (offset) da sombra:

  • <offset-x> especifica a distância horizontal. Valores negativos colocarão a sombra à esquerda do elemento.
  • <offset-y> especifca a distância vertical. Valores negativos colocam a sombra acima do elemento.

Consulte <length> (en-US) para as unidades disponíveis.

Se ambos os valores forem 0, a sombra será posicionada atrás do elemento (e poderá gerar um efeito de desfocagem caso <blur-radius> e/ou <spread-radius> estiverem configurados).

<blur-radius>

Este é um terceiro valor para <length> (en-US). Quanto maior for este valor, maior o efeito de desfocagem, desta forma a sombra se tornará maior e mais clara. Valores negativos não são permitidos. Se não for especificado, o valor padrão é 0 (os limites da sombra serão retos). A especificação não inclui um algoritmo exato de como o raio de esmaecimento deve ser calculado, no entanto, descreve o seguinte:

...para uma sombra com bordas longas e retas, deverá ser criada uma transição de cor do comprimento da distância de desfocagem que é perpendicular e centralizada com as bordas da sombra, e isto deve variar da cor total da sombra do seu ponto central até totalmente transparente no ponto final fora dela.

<spread-radius>

Este é um quarto valor de <length> (en-US). Valores positivos farão com que a sombra expanda e cresça maior, valores negativos farão com que a sombra encolha. Se não for especificado, o valor padrão é 0 (a sombra terá o mesmo tamanho do elemento)

<color>

Consulte <color> para possiveis palavras-chave e notações. Se não for especificada, a cor que será utilizada vai depender do navegador - geralmente é o valor da propriedade color, mas tenha em mente que o Safari atualmente imprime uma sombra transparente neste caso.

Interpolação

Each shadow in the list (treating none as a 0-length list) is interpolated via the color (as color) component, and x, y, blur, and (when appropriate) spread (as length) components. For each shadow, if both input shadows are or are not inset, then the interpolated shadow must match the input shadows in that regard. If any pair of input shadows has one inset and the other not inset, the entire shadow list is uninterpolable. If the lists of shadows have different lengths, then the shorter list is padded at the end with shadows whose color is transparent, all lengths are 0, and whose inset (or not) matches the longer list.

Formal syntax

box-shadow = 
<spread-shadow># (en-US)

<spread-shadow> =
<'box-shadow-color'>? (en-US) && (en-US)
[ (en-US) <'box-shadow-offset'> [ (en-US) <'box-shadow-blur'> <'box-shadow-spread'>? (en-US) ] (en-US)? (en-US) ] (en-US) && (en-US)
<'box-shadow-position'>? (en-US)

Live examples

Specifications

Specification
CSS Backgrounds and Borders Module Level 3
# box-shadow

Compatibilidade com navegadores

BCD tables only load in the browser

See also