@font-face {
    font-family: 'Material Symbols Rounded';
    font-style: normal;
    font-weight: 100 700;
    src: url(material-symbols-rounded.woff2) format('woff2');
}

:root {
    --md-ref-typeface-brand: 'Google Sans', 'Roboto', system-ui, sans-serif;
    --md-ref-typeface-plain: 'Roboto', system-ui, sans-serif;

    --md-sys-shape-corner-none: 0px;
    --md-sys-shape-corner-extra-small: 4px;
    --md-sys-shape-corner-small: 8px;
    --md-sys-shape-corner-medium: 12px;
    --md-sys-shape-corner-large: 16px;
    --md-sys-shape-corner-extra-large: 28px;
    --md-sys-shape-corner-full: 9999px;

    --md-elevation-level1: 0 1px 2px rgba(0,0,0,.3), 0 1px 3px 1px rgba(0,0,0,.15);
    --md-elevation-level2: 0 1px 2px rgba(0,0,0,.3), 0 2px 6px 2px rgba(0,0,0,.15);
    --md-elevation-level3: 0 4px 8px 3px rgba(0,0,0,.15), 0 1px 3px rgba(0,0,0,.3);

    --md-sys-motion-easing-emphasized-decelerate: cubic-bezier(0.05, 0.7, 0.1, 1);
    --md-sys-motion-easing-standard: cubic-bezier(0.2, 0.0, 0, 1.0);
    --md-sys-motion-duration-medium4: 400ms;
    --md-sys-motion-duration-short4: 200ms;
    
    --md-sys-color-scrim: rgba(0, 0, 0, 0.4);
    
    --md-switch-track-width: 52px;
    --md-switch-track-height: 32px;
    --md-switch-thumb-size-off: 16px;
    --md-switch-thumb-size-on: 24px;
    --md-co-track-off: var(--md-sys-color-surface-container-highest);
    --md-co-outline-off: var(--md-sys-color-outline);
    --md-co-thumb-off: var(--md-sys-color-outline);
    --md-co-track-on: var(--md-sys-color-primary);
    --md-co-thumb-on: var(--md-sys-color-on-primary);
    --md-expressive-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
}

*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html, body {
    overflow: hidden;
    height: 100%;
    scrollbar-width: none;
    -ms-overflow-style: none;
}
html::-webkit-scrollbar, body::-webkit-scrollbar { display: none; }

body {
    font-family: var(--md-ref-typeface-plain);
    background-color: var(--md-sys-color-surface);
    color: var(--md-sys-color-on-surface);
    line-height: 1.5;
    transition: background-color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard),
                color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard);
}

.material-symbols-rounded {
    font-family: 'Material Symbols Rounded';
    font-weight: normal;
    font-style: normal;
    font-size: 24px;
    line-height: 1;
    letter-spacing: normal;
    text-transform: none;
    display: inline-block;
    white-space: nowrap;
    word-wrap: normal;
    direction: ltr;
    font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
    user-select: none;
}

.md-display-large { font-family: var(--md-ref-typeface-brand); font-size: 3.5625rem; line-height: 4rem; font-weight: 400; letter-spacing: -0.016em; }
.md-headline-medium { font-family: var(--md-ref-typeface-brand); font-size: 1.75rem; line-height: 2.25rem; font-weight: 400; }
.md-headline-small { font-family: var(--md-ref-typeface-brand); font-size: 1.5rem; line-height: 2rem; font-weight: 400; }
.md-title-large { font-family: var(--md-ref-typeface-brand); font-size: 1.375rem; line-height: 1.75rem; font-weight: 400; }
.md-title-medium { font-family: var(--md-ref-typeface-plain); font-size: 1rem; line-height: 1.5rem; font-weight: 500; letter-spacing: 0.009em; }
.md-body-large { font-family: var(--md-ref-typeface-plain); font-size: 1rem; line-height: 1.5rem; font-weight: 400; letter-spacing: 0.031em; }
.md-body-medium { font-family: var(--md-ref-typeface-plain); font-size: 0.875rem; line-height: 1.25rem; font-weight: 400; letter-spacing: 0.016em; }
.md-label-large { font-family: var(--md-ref-typeface-plain); font-size: 0.875rem; line-height: 1.25rem; font-weight: 500; letter-spacing: 0.006em; }

.on-surface-variant { color: var(--md-sys-color-on-surface-variant); }

.estrutura-app { display: flex; height: 100vh; position: relative; z-index: 1; overflow: hidden; }

.gaveta-navegacao { 
    width: 320px; flex-shrink: 0; background: var(--md-sys-color-surface-container-low); 
    border-radius: 0 var(--md-sys-shape-corner-large) var(--md-sys-shape-corner-large) 0; 
    border-right: 1px solid var(--md-sys-color-outline-variant); padding: 12px; 
    display: flex; flex-direction: column; gap: 16px; overflow-y: auto; scrollbar-width: none; -ms-overflow-style: none;
    transition: background-color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard),
                border-color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard),
                color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard);
}
.gaveta-navegacao::-webkit-scrollbar { display: none; }

.cabecalho-gaveta { display: flex; align-items: center; justify-content: center; padding: 24px 12px; }
.logo-empresa { max-width: 100%; max-height: 80px; width: auto; height: auto; object-fit: contain; }
.divider { height: 1px; background: var(--md-sys-color-outline-variant); border: none; margin: 0; transition: background-color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard); }
.lista-navegacao { display: flex; flex-direction: column; gap: 4px; }

.grupo-navegacao { display: flex; flex-direction: column; gap: 0; width: 100%; }

.cabecalho-grupo-navegacao { 
    display: flex; align-items: center; gap: 12px; width: 100%; height: 56px; padding: 0 16px 0 28px; 
    border: none; background: transparent; color: var(--md-sys-color-on-surface-variant); 
    border-radius: var(--md-sys-shape-corner-full); font-family: var(--md-ref-typeface-plain); 
    font-size: 0.875rem; font-weight: 500; position: relative; overflow: hidden; cursor: pointer; 
    transition: background-color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard),
                color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard);
}
.cabecalho-grupo-navegacao .icone-expandir { 
    margin-left: auto; font-size: 20px; transition: transform var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard); 
}
.grupo-navegacao.aberto .cabecalho-grupo-navegacao .icone-expandir { transform: rotate(180deg); }
.cabecalho-grupo-navegacao::before { content: ''; position: absolute; inset: 0; background: currentColor; opacity: 0; transition: opacity 150ms; }
.cabecalho-grupo-navegacao:hover::before { opacity: 0.08; }
.cabecalho-grupo-navegacao:active::before { opacity: 0.12; }

.itens-grupo-navegacao { 
    max-height: 0; overflow: hidden; padding-left: 32px; 
    transition: max-height var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-emphasized-decelerate); 
}
.grupo-navegacao.aberto .itens-grupo-navegacao { max-height: 200px; }

.item-navegacao { 
    display: flex; align-items: center; gap: 12px; width: 100%; height: 56px; padding: 0 16px 0 28px; 
    border: none; background: transparent; color: var(--md-sys-color-on-surface-variant); 
    border-radius: var(--md-sys-shape-corner-full); font-family: var(--md-ref-typeface-plain); 
    font-size: 0.875rem; font-weight: 500; position: relative; overflow: hidden; cursor: pointer; 
    transition: background-color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard),
                color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard);
}
.item-navegacao .material-symbols-rounded { transition: font-variation-settings 150ms; }
.item-navegacao.ativo { background: var(--md-sys-color-secondary-container); color: var(--md-sys-color-on-secondary-container); }
.item-navegacao.ativo .material-symbols-rounded { font-variation-settings: 'FILL' 1, 'wght' 400, 'GRAD' 0, 'opsz' 24; }
.item-navegacao::before { content: ''; position: absolute; inset: 0; background: currentColor; opacity: 0; transition: opacity 150ms; }
.item-navegacao:hover::before { opacity: 0.08; }
.item-navegacao:active::before { opacity: 0.12; }

.icone-acao { width: 48px; height: 48px; padding: 0 12px; justify-content: center; }
.fundo-gaveta { display: none; }
.area-conteudo { flex: 1; display: flex; flex-direction: column; overflow: hidden; }

.barra-superior { 
    display: flex; align-items: center; gap: 12px; height: 64px; padding: 0 16px; 
    background: var(--md-sys-color-surface); color: var(--md-sys-color-on-surface); flex-shrink: 0; 
    transition: background-color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard),
                color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard),
                box-shadow var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard);
}
.barra-superior.rolada { background: var(--md-sys-color-surface-container); box-shadow: var(--md-elevation-level2); }
.titulo-barra { flex: 1; }
.acoes-barra { display: flex; gap: 4px; align-items: center; }
.botao-menu-mobile { display: none; }

.conteudo-principal { flex: 1; padding: 48px 64px; max-width: 1200px; width: 100%; margin: 0 auto; overflow-y: auto; scrollbar-width: none; -ms-overflow-style: none; }
.conteudo-principal::-webkit-scrollbar { display: none; }
.view { display: none; }
.view.ativo { display: block; }
.m3-enter { opacity: 0; }

@keyframes m3ExpressiveEntry { from { opacity: 0; transform: translateY(24px) scale(0.98); } to { opacity: 1; transform: translateY(0) scale(1); } }

.cabecalho-usuario { display: flex; align-items: center; gap: 24px; margin-bottom: 48px; }
.foto-perfil { width: 64px; height: 64px; border-radius: var(--md-sys-shape-corner-full); object-fit: cover; background: var(--md-sys-color-primary-container); transition: background-color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard); }

.grade-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; align-items: start; }
.card { 
    background: var(--md-sys-color-surface-container-high); border-radius: var(--md-sys-shape-corner-extra-large); 
    padding: 24px; border: 1px solid var(--md-sys-color-outline-variant); display: flex; flex-direction: column; gap: 16px; 
    transition: background-color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard),
                border-color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard);
}
.card-pequeno { grid-column: span 1; }
.card-grande { grid-column: span 2; }
.card-largo { grid-column: span 3; }
.cabecalho-card { display: flex; align-items: center; gap: 8px; }
.icone-card { color: var(--md-sys-color-primary); transition: color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard); }
.icone-card-svg { width: 24px; height: 24px; color: var(--md-sys-color-primary); transition: color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard); flex-shrink: 0; }
.corpo-card-expediente { display: flex; flex-direction: column; gap: 8px; }
.info-horarios { display: flex; gap: 12px; margin-top: 8px; }

.botao-filled, .botao-tonal { 
    display: inline-flex; align-items: center; justify-content: center; gap: 8px; height: 40px; padding: 0 24px; 
    border: none; border-radius: var(--md-sys-shape-corner-full); font-family: var(--md-ref-typeface-plain); 
    font-size: 0.875rem; font-weight: 500; cursor: pointer; margin-top: 16px; align-self: flex-start; 
    position: relative; overflow: hidden; transition: transform 150ms, background-color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard); 
}
.botao-filled { background: var(--md-sys-color-primary); color: var(--md-sys-color-on-primary); }
.botao-tonal { background: var(--md-sys-color-secondary-container); color: var(--md-sys-color-on-secondary-container); margin-top: 0; }
.botao-filled:active, .botao-tonal:active { transform: scale(0.95); }

.chip { 
    display: inline-flex; align-items: center; gap: 8px; height: 32px; padding: 0 12px; 
    border-radius: var(--md-sys-shape-corner-full); border: 1px solid var(--md-sys-color-outline-variant); 
    background: var(--md-sys-color-surface-container-low); color: var(--md-sys-color-on-surface-variant); 
    font-family: var(--md-ref-typeface-plain); font-size: 0.875rem; font-weight: 500; 
    transition: background-color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard),
                border-color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard),
                color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard);
}
.chip.selecionado { background: var(--md-sys-color-secondary-container); color: var(--md-sys-color-on-secondary-container); border-color: transparent; }
.chip .material-symbols-rounded { font-size: 18px; }
.corpo-card-tempo { display: flex; align-items: center; gap: 16px; }
.grade-info-empresa { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.info-empresa { display: flex; flex-direction: column; gap: 4px; }
.info-empresa-larga { grid-column: span 2; }

.grade-config-aparencia { display: flex; flex-direction: column; gap: 24px; padding-top: 16px; }
.linha-config-tema { display: flex; align-items: center; gap: 16px; width: fit-content; }

.md3-switch {
    position: relative;
    display: inline-flex;
    align-items: center;
    width: var(--md-switch-track-width);
    height: var(--md-switch-track-height);
    cursor: pointer;
    user-select: none;
}
.md3-switch input { opacity: 0; width: 0; height: 0; position: absolute; }
.md3-switch__track {
    position: absolute; top: 0; left: 0; right: 0; bottom: 0;
    background-color: var(--md-co-track-off); border: 2px solid var(--md-co-outline-off);
    border-radius: 16px; box-sizing: border-box;
    transition: background-color 0.15s linear, border-color 0.15s linear;
}
.md3-switch__thumb {
    position: absolute; top: 50%; left: 6px;
    width: var(--md-switch-thumb-size-off); height: var(--md-switch-thumb-size-off); aspect-ratio: 1 / 1;
    background-color: var(--md-co-thumb-off); border-radius: 50%; transform: translateY(-50%);
    transition: transform 0.4s var(--md-expressive-spring), left 0.4s var(--md-expressive-spring), width 0.3s var(--md-expressive-spring), height 0.3s var(--md-expressive-spring), background-color 0.15s linear;
}
.md3-switch:active .md3-switch__thumb { width: 26px; height: 22px; border-radius: 14px; }
.md3-switch input:checked + .md3-switch__track { background-color: var(--md-co-track-on); border-color: var(--md-co-track-on); }
.md3-switch input:checked + .md3-switch__track .md3-switch__thumb {
    background-color: var(--md-co-thumb-on); left: 4px;
    width: var(--md-switch-thumb-size-on); height: var(--md-switch-thumb-size-on); transform: translate(20px, -50%);
}
.md3-switch input:checked:active + .md3-switch__track .md3-switch__thumb { width: 26px; height: 22px; transform: translate(14px, -50%); }
.md3-switch input:focus-visible + .md3-switch__track { outline: 2px solid var(--md-co-track-on); outline-offset: 4px; }

.header-view-documentos { display: flex; justify-content: space-between; align-items: center; margin-bottom: 24px; gap: 16px; }
.categoria-documentos { margin-bottom: 32px; }
.titulo-categoria { font-family: var(--md-ref-typeface-brand); font-size: 1.125rem; font-weight: 500; margin-bottom: 12px; color: var(--md-sys-color-primary); padding-left: 8px; transition: color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard); }
.lista-documentos { display: flex; flex-direction: column; gap: 8px; }

.item-lista { 
    display: flex; align-items: center; gap: 16px; padding: 16px; background: var(--md-sys-color-surface-container-high); 
    border-radius: var(--md-sys-shape-corner-large); border: 1px solid var(--md-sys-color-outline-variant); 
    text-decoration: none; color: inherit; animation: docFadeIn 300ms var(--md-sys-motion-easing-standard) forwards;
    transition: background-color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard),
                border-color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard);
}
.item-lista.removing { animation: docFadeOut 200ms var(--md-sys-motion-easing-standard) forwards; }
@keyframes docFadeIn { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }
@keyframes docFadeOut { to { opacity: 0; transform: translateX(20px); } }

.item-lista .material-symbols-rounded { color: var(--md-sys-color-primary); transition: color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard); }
.info-item-lista { flex: 1; display: flex; flex-direction: column; }

.tabela-ponto { display: flex; flex-direction: column; gap: 4px; }
.linha-ponto { display: grid; grid-template-columns: 2fr 1fr 1.5fr auto; align-items: center; padding: 12px 8px; border-bottom: 1px solid var(--md-sys-color-outline-variant); gap: 16px; transition: border-color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard); }
.linha-ponto:last-child { border-bottom: none; }
.cabecalho-ponto { font-family: var(--md-ref-typeface-plain); font-weight: 500; color: var(--md-sys-color-on-surface-variant); font-size: 0.875rem; transition: color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard); }
.botao-excluir-ponto { background: transparent; border: none; color: var(--md-sys-color-on-surface-variant); cursor: pointer; padding: 8px; border-radius: var(--md-sys-shape-corner-full); display: inline-flex; align-items: center; justify-content: center; position: relative; overflow: hidden; transition: background 150ms, color 150ms; }
.botao-excluir-ponto:hover { background: var(--md-sys-color-error-container); color: var(--md-sys-color-on-error-container); }
.botao-excluir-ponto .material-symbols-rounded { font-size: 20px; }

.grade-paletas { display: flex; gap: 16px; flex-wrap: wrap; }
.opcao-paleta { 
    display: flex; flex-direction: column; align-items: center; gap: 8px; padding: 16px; border: 1px solid var(--md-sys-color-outline-variant); 
    border-radius: var(--md-sys-shape-corner-large); background: var(--md-sys-color-surface); color: var(--md-sys-color-on-surface); 
    cursor: pointer; overflow: hidden; position: relative; 
    transition: border-color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard),
                background-color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard);
}
.opcao-paleta:hover { border-color: var(--md-sys-color-primary); }
.opcao-paleta.selecionado { background: var(--md-sys-color-secondary-container); color: var(--md-sys-color-on-secondary-container); border-color: transparent; }
.cor-paleta { width: 40px; height: 40px; border-radius: var(--md-sys-shape-corner-full); border: 2px solid var(--md-sys-color-outline-variant); }

.m3-copa-card { 
    background-color: var(--md-sys-color-surface-container); border-radius: var(--md-sys-shape-corner-extra-large); 
    padding: 24px; color: var(--md-sys-color-on-surface); 
    transition: background-color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard),
                color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard);
}
.m3-list-item { display: flex; align-items: center; padding: 16px 12px; border-bottom: 1px solid var(--md-sys-color-outline-variant); border-radius: var(--md-sys-shape-corner-medium); transition: background 200ms, border-color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard); }
.m3-list-item:last-child { border-bottom: none; }
.m3-list-item.destaque { background-color: var(--md-sys-color-primary-container); color: var(--md-sys-color-on-primary-container); margin: 8px 0; border-bottom: none; }
.m3-list-item-start { display: flex; gap: 4px; margin-right: 16px; }
.m3-avatar { width: 40px; height: 40px; border-radius: var(--md-sys-shape-corner-full); background: var(--md-sys-color-surface-container-high); display: flex; align-items: center; justify-content: center; font-size: 20px; transition: background-color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard); }
.m3-list-item.destaque .m3-avatar { background: var(--md-sys-color-surface); }
.m3-list-item-content { display: flex; flex-direction: column; flex-grow: 1; }
.m3-list-item-content b { color: var(--md-sys-color-primary); font-weight: 700; margin: 0 4px; transition: color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard); }
.m3-list-item.destaque .m3-list-item-content b { color: var(--md-sys-color-on-primary-container); }
.m3-list-item-end { display: flex; align-items: center; gap: 8px; }
.m3-badge-time, .m3-badge-countdown, .m3-badge-live { padding: 6px 12px; border-radius: var(--md-sys-shape-corner-small); font-size: 14px; font-weight: 500; text-align: center; min-width: 60px; transition: background-color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard), color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard); }
.m3-badge-time { background: var(--md-sys-color-secondary-container); color: var(--md-sys-color-on-secondary-container); }
.m3-list-item.destaque .m3-badge-time, .m3-list-item.destaque .m3-badge-countdown { background: var(--md-sys-color-surface); color: var(--md-sys-color-on-surface); }
.m3-badge-countdown { background: var(--md-sys-color-tertiary-container); color: var(--md-sys-color-on-tertiary-container); font-variant-numeric: tabular-nums; }
.m3-badge-live { background: var(--md-sys-color-error); color: var(--md-sys-color-on-error); font-size: 12px; font-weight: 700; letter-spacing: 0.5px; display: flex; align-items: center; gap: 6px; }
.m3-badge-live::before { content: ''; width: 8px; height: 8px; border-radius: 50%; background: currentColor; animation: m3PulseDot 1.5s infinite ease-in-out; }

@keyframes m3PulseDot { 0%, 100% { opacity: 1; } 50% { opacity: 0.5; } }
@keyframes m3Pulse { 0% { opacity: 1; } 50% { opacity: 0.7; } 100% { opacity: 1; } }

.onda-ripple { position: absolute; border-radius: 50%; background: currentColor; opacity: 0.12; transform: scale(0); pointer-events: none; animation: ripple-animacao 600ms cubic-bezier(0.2, 0, 0, 1) forwards; }
@keyframes ripple-animacao { to { transform: scale(4); opacity: 0; } }

.md3-extended-fab-expressive { 
    position: fixed; bottom: 24px; right: 24px; display: inline-flex; align-items: center; justify-content: center; 
    gap: 12px; height: 56px; padding: 0 20px; background-color: var(--md-sys-color-primary-container); 
    color: var(--md-sys-color-on-primary-container); border: none; cursor: pointer; border-radius: 9999px; 
    font-family: var(--md-ref-typeface-plain); font-size: 14px; font-weight: 500; letter-spacing: 0.1px; 
    box-shadow: 0px 4px 8px 3px rgba(0, 0, 0, 0.1), 0px 1px 3px 0px rgba(0, 0, 0, 0.2); 
    opacity: 0; transform: translateY(120px) scale(0.8); pointer-events: none; z-index: 100; text-decoration: none; 
    transition: opacity 300ms cubic-bezier(0.4, 0, 1, 1), transform 300ms cubic-bezier(0.4, 0, 1, 1), background-color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard), color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard); 
}
.md3-extended-fab-expressive.visivel { opacity: 1; transform: translateY(0) scale(1); pointer-events: auto; transition: opacity 500ms cubic-bezier(0.34, 1.56, 0.64, 1), transform 500ms cubic-bezier(0.34, 1.56, 0.64, 1), background-color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard), color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard); }
.md3-extended-fab-expressive:hover { box-shadow: 0px 6px 10px 4px rgba(0, 0, 0, 0.1), 0px 2px 3px 0px rgba(0, 0, 0, 0.2); transform: scale(1.04); }
.md3-extended-fab-expressive:active { transform: scale(0.98); }
.md3-fab-icon-svg { width: 20px; height: 20px; fill: currentColor; display: inline-block; flex-shrink: 0; }

fundo-organico {
    position: fixed;
    bottom: 0;
    right: 0;
    z-index: 0;
    pointer-events: none;
    transform: translate(30%, 30%);
}
.fundo-morfo { color: var(--md-sys-color-primary); opacity: 0.1; }

.m3e-search-view-docked { position: fixed; top: 80px; left: 50%; transform: translateX(-50%); width: 90%; max-width: 720px; z-index: 2001; display: none; }
.m3e-search-view-docked.is-visible { display: block; }
.m3e-search-field-bar { 
    display: flex; align-items: center; height: 56px; padding: 0 16px; gap: 12px; background-color: var(--md-sys-color-surface-container-high); 
    border-radius: var(--md-sys-shape-corner-extra-large); box-sizing: border-box; 
    transition: background-color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard);
}
.m3e-search-field-bar input { flex: 1; background: transparent; border: none; outline: none; font-size: 16px; line-height: 24px; color: var(--md-sys-color-on-surface); font-family: var(--md-ref-typeface-plain); }
.m3e-search-field-bar input::placeholder { color: var(--md-sys-color-on-surface-variant); }
.m3e-search-action-left { width: 40px; height: 40px; position: relative; display: flex; align-items: center; justify-content: center; }
.m3e-search-icon-btn { position: absolute; width: 40px; height: 40px; border-radius: 50%; border: none; background: transparent; color: var(--md-sys-color-on-surface-variant); display: flex; align-items: center; justify-content: center; cursor: pointer; transition: transform var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard), opacity var(--md-sys-motion-duration-short4) linear; }
.m3e-search-icon-btn svg { width: 24px; height: 24px; fill: currentColor; }
.m3e-search-icon-btn.hidden { opacity: 0; pointer-events: none; transform: rotate(-90deg) scale(0.7); }
.m3e-search-clear-btn { width: 40px; height: 40px; border-radius: 50%; border: none; background: transparent; color: var(--md-sys-color-on-surface-variant); display: flex; align-items: center; justify-content: center; cursor: pointer; opacity: 0; pointer-events: none; transform: scale(0.8); transition: opacity var(--md-sys-motion-duration-short4) linear, transform var(--md-sys-motion-duration-short4) var(--md-sys-motion-easing-standard); }
.m3e-search-clear-btn.is-visible { opacity: 1; pointer-events: auto; transform: scale(1); }
.m3e-search-clear-btn svg { width: 24px; height: 24px; fill: currentColor; }
.m3e-search-results-suspended { 
    position: absolute; top: 60px; left: 0; width: 100%; background-color: var(--md-sys-color-surface-container-high); 
    border-radius: var(--md-sys-shape-corner-extra-large); box-sizing: border-box; padding: 12px 0; box-shadow: 0px 4px 12px rgba(0, 0, 0, 0.3); 
    opacity: 0; visibility: hidden; transform: translateY(-4px); 
    transition: opacity var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard), 
                transform var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard), 
                visibility var(--md-sys-motion-duration-medium4),
                background-color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard);
}
.m3e-search-view-docked.is-active .m3e-search-results-suspended { opacity: 1; visibility: visible; transform: translateY(0); }
.m3e-list-item { height: 48px; display: flex; align-items: center; padding: 0 24px; color: var(--md-sys-color-on-surface); font-size: 16px; font-weight: 500; cursor: pointer; user-select: none; transition: background-color var(--md-sys-motion-duration-short4) linear; }
.m3e-list-item:hover, .m3e-list-item.selecionado { background-color: rgba(230, 225, 229, 0.08); }
.m3e-list-item .material-symbols-rounded { margin-right: 16px; }
.m3-scrim { position: fixed; top: 0; left: 0; width: 100vw; height: 100vh; background-color: var(--md-sys-color-scrim); z-index: 2000; opacity: 0; pointer-events: none; transition: opacity var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard); }
.m3e-search-view-docked.is-active ~ .m3-scrim { opacity: 1; pointer-events: auto; }

@media (max-width: 1024px) { .grade-cards { grid-template-columns: repeat(2, 1fr); } .card-grande { grid-column: span 2; } .card-largo { grid-column: span 2; } }
@media (max-width: 768px) {
    .gaveta-navegacao { position: fixed; top: 0; left: 0; bottom: 0; z-index: 10; transform: translateX(-100%); transition: transform 200ms var(--md-sys-motion-easing-standard), background-color var(--md-sys-motion-duration-medium4) var(--md-sys-motion-easing-standard); }
    .gaveta-navegacao.aberta { transform: translateX(0); }
    .fundo-gaveta.visivel { display: block; position: fixed; inset: 0; background: rgba(0,0,0,0.4); z-index: 9; }
    .botao-menu-mobile { display: inline-flex; }
    .conteudo-principal { padding: 24px 16px; }
    .md-display-large { font-size: 2.5rem; line-height: 2.75rem; }
    .grade-cards { grid-template-columns: 1fr; }
    .card-pequeno, .card-grande, .card-largo { grid-column: span 1; }
    .cabecalho-usuario { gap: 16px; margin-bottom: 24px; }
    .foto-perfil { width: 48px; height: 48px; }
    .linha-ponto { grid-template-columns: 1fr 1fr auto; gap: 8px; }
    .cabecalho-ponto { display: none; }
    .header-view-documentos { flex-direction: column; align-items: flex-start; }
}

:focus-visible:not(input):not(textarea) { outline: 3px solid var(--md-sys-color-secondary); outline-offset: 2px; }
:focus:not(:focus-visible) { outline: none; }
@media (prefers-reduced-motion: reduce) { *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; } }
