* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    font-family: Arial, Helvetica, sans-serif;
}

:root {
    --cor-principal: #c99a3b;
    --cor-secundaria: #111111;
    --cor-texto: #ffffff;
    --cor-borda: rgba(255, 255, 255, 0.12);
    --cor-superficie: rgba(255, 255, 255, 0.06);
}

body {
    background: #0b0b0b;
    color: #fff;
}

.botao-area-admin {
    position: fixed;
    right: 18px;
    top: 18px;
    z-index: 9000;
    cursor: pointer;
    border: 1px solid rgba(255,255,255,.18);
    border-radius: 999px;
    background: rgba(17,17,17,.82);
    color: #fff;
    padding: 9px 14px;
    font-weight: 800;
    box-shadow: 0 10px 28px rgba(0,0,0,.25);
    backdrop-filter: blur(10px);
}

.modo-admin .botao-area-admin {
    background: var(--cor-principal);
    color: #111;
    top: auto;
    bottom: 18px;
}

.modo-barbeiro .painel,
.modo-barbeiro .abas-principais,
.modo-barbeiro .painel-gestao-tela,
.modo-barbeiro .painel-contas-tela,
.modo-barbeiro .whatsapp-tela {
    display: none !important;
}

.modo-barbeiro .app {
    display: block;
}

.modo-barbeiro .area-preview {
    width: 100%;
    padding-top: 64px;
}

.modo-barbeiro .agenda-profissional-tela {
    max-width: none;
}

.modo-cliente .painel,
.modo-cliente .abas-principais,
.modo-cliente .painel-gestao-tela,
.modo-cliente .painel-contas-tela,
.modo-cliente .agenda-profissional-tela,
.modo-cliente .whatsapp-tela {
    display: none !important;
}

.modo-cliente .area-preview {
    width: 100%;
    padding-top: 64px;
}

.modo-cliente .preview {
    max-width: 1200px;
}

.modo-cliente .imagem-editavel {
    cursor: default !important;
    user-select: auto;
}

.modo-cliente .imagem-editavel,
.modo-cliente .imagem-editavel:active {
    cursor: default !important;
}

.modo-cliente .imagem-editavel.selecionada {
    outline: none !important;
    box-shadow: none !important;
}

.modo-cliente .preview {
    user-select: auto;
}

.app {
    display: flex;
    min-height: 100vh;
}

.painel {
    width: 330px;
    flex: 0 0 330px;
    background: #151515;
    padding: 20px;
    overflow-y: auto;
    max-height: 100vh;
    border-right: 1px solid #333;
    transition: width .2s ease, flex-basis .2s ease, padding .2s ease;
}

.painel-topo {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 12px;
}

.painel-topo h2 {
    margin-bottom: 0;
}

.minimizar-editor,
.restaurar-editor {
    cursor: pointer;
    border: 1px solid #333;
    border-radius: 8px;
    background: #222;
    color: #fff;
    font-weight: 900;
}

.minimizar-editor {
    width: 34px;
    height: 34px;
    font-size: 24px;
    line-height: 1;
}

.restaurar-editor {
    display: none;
    width: 100%;
    min-height: 42px;
    padding: 8px 6px;
    writing-mode: vertical-rl;
    text-orientation: mixed;
}

.editor-contexto-aviso {
    background: #1d1d1d;
    border: 1px solid #333;
    border-radius: 8px;
    padding: 9px;
    margin-bottom: 12px;
}

.editor-bloco {
    display: grid;
    gap: 0;
    padding-bottom: 14px;
    margin-bottom: 14px;
    border-bottom: 1px solid #303030;
}

.editor-bloco[hidden] {
    display: none !important;
}

.editor-minimizado .painel {
    width: 58px;
    flex-basis: 58px;
    padding: 12px 8px;
    overflow: hidden;
}

.editor-minimizado .painel-topo,
.editor-minimizado .editor-contexto-aviso,
.editor-minimizado .editor-bloco {
    display: none !important;
}

.editor-minimizado .restaurar-editor {
    display: block;
}

.painel h2,
.painel h3 {
    margin-bottom: 15px;
    color: var(--cor-principal);
}

.painel label {
    display: block;
    font-size: 14px;
    margin: 12px 0 6px;
    color: #ddd;
}

.dias-funcionamento label,
.controle-check,
.dias-barbeiro label {
    display: flex;
    gap: 8px;
    align-items: center;
    margin: 8px 0;
    font-size: 13px;
}

.dias-funcionamento input,
.controle-check input,
.dias-barbeiro input {
    width: auto !important;
}

.duracoes-barbeiro {
    display: grid;
    gap: 8px;
    margin-top: 8px;
}

.duracao-barbeiro-item {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 84px;
    gap: 8px;
    align-items: center;
    padding: 8px;
    border: 1px solid #333;
    border-radius: 8px;
    background: #1d1d1d;
}

.duracao-barbeiro-item span {
    min-width: 0;
    color: #ddd;
    font-size: 13px;
    overflow-wrap: anywhere;
}

.duracao-barbeiro-item input {
    padding: 8px;
    text-align: center;
}

.lista-contas-acesso {
    display: grid;
    gap: 10px;
    margin-top: 12px;
}

.secao-acessos-mestre h4 {
    margin: 16px 0 10px;
    color: #f5f5f5;
    font-size: 14px;
}

.lista-barbearias-mestre {
    display: grid;
    gap: 10px;
    margin: 12px 0;
}

.barbearia-mestre-item {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px;
    align-items: center;
    border: 1px solid #333;
    border-radius: 8px;
    background: #1d1d1d;
    padding: 10px;
}

.barbearia-mestre-item strong,
.barbearia-mestre-item span {
    min-width: 0;
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.barbearia-mestre-item strong {
    color: #fff;
}

.barbearia-mestre-item span {
    color: #cfcfcf;
    font-size: 12px;
}

.barbearia-mestre-item button {
    cursor: pointer;
    border: none;
    border-radius: 8px;
    background: #25d366;
    color: #062016;
    padding: 8px 10px;
    font-weight: 900;
}

.barbearia-mestre-item button:disabled {
    cursor: default;
    opacity: .72;
}

.barbearia-mestre-item.ativo {
    border-color: #25d366;
    box-shadow: 0 0 0 2px rgba(37, 211, 102, .16);
}

.conta-acesso-item {
    display: grid;
    gap: 6px;
    border: 1px solid #333;
    border-radius: 8px;
    background: #1d1d1d;
    padding: 10px;
}

.conta-acesso-item strong {
    color: #fff;
}

.conta-acesso-item span,
.conta-acesso-item small {
    color: #cfcfcf;
    font-size: 12px;
}

.resumo-agenda-emails {
    display: grid;
    gap: 8px;
    margin-top: 12px;
}

.agenda-email-item {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 10px;
    padding: 10px;
    border: 1px solid #333;
    border-radius: 8px;
    background: #1d1d1d;
}

.agenda-email-texto {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 3px;
}

.agenda-email-texto strong {
    color: #fff;
    font-size: 13px;
}

.agenda-email-texto span {
    color: #cfcfcf;
    font-size: 12px;
    overflow-wrap: anywhere;
}

.agenda-email-status {
    flex: 0 0 auto;
    padding: 4px 7px;
    border-radius: 999px;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
}

.agenda-email-status.ok {
    background: rgba(54, 168, 83, .16);
    color: #72d38a;
}

.agenda-email-status.pendente {
    background: rgba(217, 74, 74, .16);
    color: #ee8b8b;
}

.gestao-filtros {
    display: grid;
    gap: 6px;
}

.resumo-financeiro {
    display: grid;
    grid-template-columns: 1fr;
    gap: 8px;
    margin: 12px 0;
}

.resumo-card,
.gestao-item {
    background: #1d1d1d;
    border: 1px solid #333;
    border-radius: 8px;
    padding: 10px;
}

.resumo-card {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.resumo-card span,
.resumo-card small,
.gestao-item span {
    color: #cfcfcf;
    font-size: 12px;
    line-height: 1.35;
}

.resumo-card strong,
.gestao-item strong {
    color: var(--cor-principal);
    font-size: 15px;
}

.painel-gestao-lista {
    display: grid;
    gap: 8px;
    margin-bottom: 12px;
}

.gestao-item {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.comparativo-card.positivo {
    border-color: rgba(54, 168, 83, .5);
}

.comparativo-card.negativo {
    border-color: rgba(217, 74, 74, .55);
}

.comparativo-card.positivo strong {
    color: #72d38a;
}

.comparativo-card.negativo strong {
    color: #ee8b8b;
}

.acoes-gestao {
    display: grid;
    grid-template-columns: 1fr;
    gap: 6px;
    margin-top: 6px;
}

.acoes-gestao button {
    margin-top: 0;
    padding: 8px;
}

.painel input,
.painel textarea,
.painel select {
    width: 100%;
    padding: 10px;
    border: 1px solid #333;
    border-radius: 8px;
    background: #222;
    color: #fff;
    outline: none;
}

.painel textarea {
    height: 70px;
    resize: vertical;
}

.painel button,
.modal-caixa button,
.hero button,
.card-info button {
    cursor: pointer;
    border: none;
    border-radius: 8px;
    transition: .2s;
}

.painel button {
    width: 100%;
    padding: 11px;
    margin-top: 10px;
    background: var(--cor-principal);
    color: #111;
    font-weight: bold;
}

.painel .btn-secundario-painel {
    background: #333;
    color: #fff;
}

.painel button:hover,
.hero button:hover,
.card-info button:hover,
.modal-caixa button:hover {
    transform: translateY(-1px);
    filter: brightness(1.08);
}

.painel hr {
    border: none;
    height: 1px;
    background: #333;
    margin: 20px 0;
}

.botoes-modo {
    display: flex;
    gap: 8px;
}

.botoes-modo button {
    background: #333;
    color: #fff;
}

.botoes-modo button.ativo {
    background: var(--cor-principal);
    color: #111;
}

.aviso {
    color: #aaa;
    font-size: 13px;
    line-height: 1.4;
}

.area-preview {
    flex: 1;
    padding: 25px;
    overflow: auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
}

.abas-principais {
    width: 100%;
    max-width: 1200px;
    display: flex;
    justify-content: flex-end;
    flex-wrap: wrap;
    gap: 8px;
}

.abas-principais button {
    cursor: pointer;
    border: 1px solid rgba(255, 255, 255, .14);
    border-radius: 8px;
    background: #1d1d1d;
    color: #fff;
    padding: 10px 16px;
    font-weight: 700;
    transition: .2s;
}

.abas-principais button.ativo {
    background: var(--cor-principal);
    color: #111;
    border-color: var(--cor-principal);
}

.abas-principais button:hover {
    transform: translateY(-1px);
    filter: brightness(1.08);
}

#abaContas {
    display: none;
}

.modo-mestre #abaContas {
    display: inline-flex;
}

.preview {
    width: 100%;
    min-height: 100vh;
    background: var(--cor-secundaria);
    color: var(--cor-texto);
    overflow: hidden;
    border-radius: 16px;
    box-shadow: 0 0 30px rgba(0, 0, 0, .45);
}

.painel-gestao-tela,
.painel-contas-tela {
    width: 100%;
    max-width: 1200px;
    min-height: 100vh;
    background: #111;
    border: 1px solid rgba(255, 255, 255, .12);
    border-radius: 16px;
    padding: 24px;
    box-shadow: 0 0 30px rgba(0, 0, 0, .45);
}

.painel-gestao-cabecalho {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 340px;
    gap: 22px;
    align-items: start;
    margin-bottom: 18px;
}

.painel-kicker {
    color: var(--cor-principal);
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0;
}

.painel-gestao-cabecalho h2 {
    margin: 6px 0;
    color: #fff;
    font-size: 32px;
}

.painel-gestao-cabecalho p {
    color: #bdbdbd;
    line-height: 1.5;
}

.painel-gestao-tela .gestao-filtros,
.caixa-form {
    display: grid;
    gap: 8px;
    padding: 14px;
    background: #181818;
    border: 1px solid #2d2d2d;
    border-radius: 8px;
}

.painel-gestao-tela label,
.painel-contas-tela label {
    color: #ddd;
    font-size: 13px;
}

.painel-gestao-tela input,
.painel-gestao-tela select,
.painel-contas-tela input,
.painel-contas-tela select {
    width: 100%;
    padding: 10px;
    border: 1px solid #333;
    border-radius: 8px;
    background: #222;
    color: #fff;
    outline: none;
}

.painel-gestao-tela button,
.painel-contas-tela button {
    cursor: pointer;
    border: none;
    border-radius: 8px;
    padding: 10px 12px;
    background: var(--cor-principal);
    color: #111;
    font-weight: 800;
    transition: .2s;
}

.painel-gestao-tela button:hover,
.painel-contas-tela button:hover {
    transform: translateY(-1px);
    filter: brightness(1.08);
}

.painel-contas-conteudo {
    max-width: 780px;
}

.painel-contas-tela .secao-acessos-mestre {
    display: grid;
    gap: 10px;
    padding: 18px;
    border: 1px solid #2d2d2d;
    border-radius: 8px;
    background: #171717;
}

.painel-contas-tela .secao-acessos-mestre[hidden] {
    display: none;
}

.painel-gestao-tela .resumo-financeiro {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    margin: 18px 0;
}

.painel-gestao-tela #resumoCaixa {
    display: block;
}

.painel-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
    margin-bottom: 16px;
}

.painel-secao {
    min-width: 0;
    background: #171717;
    border: 1px solid #2d2d2d;
    border-radius: 8px;
    padding: 16px;
}

.painel-secao-destaque {
    background: #191714;
}

.painel-secao h3 {
    color: var(--cor-principal);
    margin-bottom: 12px;
}

.caixa-form {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin-bottom: 14px;
}

.caixa-form label,
.caixa-form input,
.caixa-form select,
.caixa-form button {
    grid-column: 1 / -1;
}

.caixa-form button {
    min-height: 42px;
}

.grafico-barras {
    display: grid;
    gap: 12px;
    margin-top: 12px;
}

.grafico-linha {
    display: grid;
    grid-template-columns: 120px minmax(0, 1fr) 120px;
    gap: 10px;
    align-items: center;
}

.grafico-label {
    color: #ddd;
    font-size: 13px;
    font-weight: 700;
    overflow-wrap: anywhere;
}

.grafico-trilho {
    min-width: 0;
    height: 12px;
    background: #262626;
    border-radius: 999px;
    overflow: hidden;
}

.grafico-preenchimento {
    display: block;
    height: 100%;
    width: var(--largura-barra, 0%);
    background: var(--cor-principal);
    border-radius: inherit;
}

.grafico-linha.positivo .grafico-preenchimento {
    background: #72d38a;
}

.grafico-linha.negativo .grafico-preenchimento {
    background: #ee8b8b;
}

.grafico-valor {
    color: #cfcfcf;
    font-size: 12px;
    text-align: right;
}

.lista-agenda-operacional {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.preview.mobile {
    max-width: 390px;
}

.preview.desktop {
    max-width: 1200px;
}

.topo {
    position: sticky;
    top: 0;
    z-index: 10;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 20px;
    padding: 18px 35px;
    background: rgba(0, 0, 0, .82);
    backdrop-filter: blur(8px);
}

.logo {
    display: flex;
    align-items: center;
    gap: 12px;
    font-weight: bold;
    min-width: 0;
}

.logo img {
    flex: 0 0 64px;
    width: 64px;
    height: 64px;
    border-radius: 8px;
    object-fit: cover;
    background: #222;
}

.logo span {
    min-width: 0;
    overflow-wrap: anywhere;
    line-height: 1.15;
}

nav {
    display: flex;
    gap: 18px;
    align-items: center;
}

nav a,
nav a:visited,
nav a:hover,
nav a:active {
    color: var(--cor-texto);
    text-decoration: none;
    font-weight: bold;
}

.hero {
    min-height: 520px;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 70px 25px;
    background:
        linear-gradient(rgba(0,0,0,.65), rgba(0,0,0,.65)),
        url("https://images.unsplash.com/photo-1517832606299-7ae9b720a186?auto=format&fit=crop&w=1600&q=80") center/cover no-repeat;
}

.hero-conteudo {
    position: relative;
    z-index: 2;
    max-width: 850px;
    width: 100%;
    overflow: hidden;
}

.hero h1 {
    line-height: 1.05;
    overflow-wrap: break-word;
    max-width: 100%;
    margin: 0 auto 14px;
}

.hero p {
    line-height: 1.3;
    margin: 0 auto 28px;
    color: #eee;
    max-width: 90%;
}

.hero-botoes {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 12px;
}

.btn-agendar,
.btn-confirmar {
    padding: 14px 24px;
    background: var(--cor-principal);
    color: #111;
    font-weight: bold;
}

.servicos {
    padding: 60px 35px;
    background: var(--cor-secundaria);
}

.servicos h2,
.duvidas h2 {
    text-align: center;
    margin-bottom: 10px;
}

.subtitulo,
.duvidas p {
    text-align: center;
    color: #ccc;
    margin-bottom: 35px;
}

.grid-servicos {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 22px;
}

.card-servico {
    background: var(--cor-superficie);
    border: 1px solid var(--cor-borda);
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 10px 25px rgba(0,0,0,.25);
}

.card-servico img {
    width: 100%;
    height: 210px;
    object-fit: cover;
    display: block;
}

.card-info {
    padding: 18px;
}

.card-info h3 {
    margin-bottom: 8px;
    color: var(--cor-principal);
}

.card-info p {
    color: #ddd;
    font-size: 14px;
    min-height: 42px;
    line-height: 1.4;
}

.valor-servico {
    display: inline-block;
    margin: 0;
    padding: 7px 10px;
    border-radius: 20px;
    background: rgba(201,154,59,.15);
    color: var(--cor-principal);
    font-weight: bold;
}

.servico-detalhes {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
    margin: 12px 0;
}

.duracao-servico {
    display: inline-flex;
    align-items: center;
    min-height: 31px;
    padding: 7px 10px;
    border-radius: 20px;
    background: rgba(255,255,255,.08);
    color: #e7e7e7;
    font-size: 13px;
    font-weight: bold;
}

.card-info button {
    width: 100%;
    padding: 12px;
    background: var(--cor-principal);
    color: #111;
    font-weight: bold;
}

.duvidas {
    padding: 65px 25px;
    text-align: center;
    background: rgba(255,255,255,.04);
}

.btn-whatsapp-duvidas {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 210px;
    margin-top: 6px;
    padding: 13px 22px;
    border: none;
    border-radius: 8px;
    background: #25d366;
    color: #061f14;
    font-weight: 900;
    cursor: pointer;
}

.avaliacoes-google {
    padding: 64px 35px;
    background: #0d0d0d;
    border-top: 1px solid var(--cor-borda);
    text-align: center;
}

.avaliacoes-google[hidden] {
    display: none;
}

.avaliacoes-cabecalho {
    max-width: 760px;
    margin: 0 auto 30px;
}

.avaliacoes-kicker {
    display: inline-flex;
    margin-bottom: 10px;
    color: var(--cor-principal);
    font-size: 12px;
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.avaliacoes-cabecalho h2 {
    margin-bottom: 10px;
}

.avaliacoes-cabecalho p {
    color: #d5d5d5;
    line-height: 1.5;
}

.avaliacoes-grid {
    display: flex;
    gap: 18px;
    overflow-x: auto;
    overscroll-behavior-inline: contain;
    padding: 2px 2px 16px;
    scroll-padding-inline: 2px;
    scroll-snap-type: x proximity;
    text-align: left;
}

.avaliacao-card {
    flex: 0 0 clamp(280px, 32vw, 380px);
    display: flex;
    flex-direction: column;
    gap: 14px;
    min-height: 250px;
    padding: 20px;
    border: 1px solid var(--cor-borda);
    border-radius: 8px;
    background: var(--cor-superficie);
    box-shadow: 0 12px 28px rgba(0,0,0,.22);
    scroll-snap-align: start;
}

.avaliacao-topo {
    display: flex;
    align-items: center;
    gap: 12px;
}

.avaliacao-avatar {
    flex: 0 0 46px;
    width: 46px;
    height: 46px;
    overflow: hidden;
    border-radius: 50%;
    background: rgba(201,154,59,.18);
    color: var(--cor-principal);
    font-weight: 800;
}

.avaliacao-avatar img,
.avaliacao-avatar span {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    object-fit: cover;
}

.avaliacao-topo strong {
    display: block;
    color: #fff;
}

.avaliacao-topo small {
    display: block;
    margin-top: 3px;
    color: #aaa;
}

.avaliacao-estrelas {
    color: var(--cor-principal);
    font-size: 18px;
    letter-spacing: 1px;
}

.avaliacao-card p {
    color: #e4e4e4;
    line-height: 1.55;
    flex: 1;
}

.avaliacao-card a,
.avaliacoes-link {
    color: var(--cor-principal);
    font-weight: 800;
    text-decoration: none;
}

.avaliacoes-link {
    display: inline-flex;
    margin-top: 28px;
    padding: 12px 18px;
    border: 1px solid rgba(201,154,59,.45);
    border-radius: 8px;
}

.google-reviews-status {
    display: grid;
    gap: 4px;
    border: 1px solid rgba(255,255,255,.14);
    border-radius: 8px;
    background: rgba(255,255,255,.06);
    padding: 10px;
}

.google-reviews-status strong {
    color: #ffbc66;
}

.google-reviews-status.ok strong {
    color: #59d58a;
}

.google-reviews-status span {
    color: #ddd;
    font-size: 12px;
    line-height: 1.4;
}

footer {
    padding: 22px;
    text-align: center;
    background: #050505;
    color: #aaa;
}

.modal-agendamento {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.75);
    display: none;
    justify-content: center;
    align-items: center;
    z-index: 999;
    padding: 20px;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}

.modal-agendamento.ativo {
    display: flex;
}

.modal-caixa {
    width: min(960px, 94vw);
    max-height: 86vh;
    overflow: hidden;
    background: #171717;
    border: 1px solid #333;
    border-radius: 16px;
    color: #fff;
    position: relative;
    box-shadow: 0 20px 50px rgba(0,0,0,.5);
}

.agenda-layout {
    display: grid;
    grid-template-columns: 170px minmax(0, 1fr) 210px;
    height: min(520px, 86vh);
}

.agenda-lateral,
.agenda-resumo {
    background: #f7f4ef;
    color: #2c2c2c;
    padding: 16px 14px;
    border-right: 1px solid rgba(0, 0, 0, 0.08);
}

.agenda-resumo {
    background: #fbfaf8;
    border-right: none;
    border-left: 1px solid rgba(0, 0, 0, 0.08);
}

.agenda-resumo-mobile {
    display: none;
}

.agenda-conteudo {
    background: #ffffff;
    color: #111;
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.agenda-passo {
    padding: 14px 16px;
    height: 100%;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    display: flex;
    flex-direction: column;
    min-height: 0;
}

.passo-conteudo-scroll {
    flex: 1;
    min-height: 0;
    overflow-y: auto;
    padding-bottom: 6px;
}

#passo5 .passo-conteudo-scroll {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}

.agenda-passo h2 {
    font-size: 1rem;
    margin-bottom: 4px;
}

.topo-passo {
    display: flex;
    align-items: center;
    margin-bottom: 6px;
}

.btn-topo-voltar {
    background: transparent;
    color: #444;
    border: 1px solid #dadada;
    padding: 5px 8px;
    font-weight: 600;
    font-size: 12px;
}

.modal-subtitulo {
    color: #666;
    margin-bottom: 8px;
    font-size: 0.8rem;
}

.agenda-conteudo label {
    display: block;
    margin: 12px 0 6px;
    color: #404040;
}

.agenda-conteudo input {
    width: 100%;
    padding: 12px;
    border-radius: 10px;
    border: 1px solid #d7d7d7;
    background: #fff;
    color: #111;
    outline: none;
}

.fechar-modal {
    position: absolute;
    top: 14px;
    right: 14px;
    width: 36px;
    height: 36px;
    background: rgba(0, 0, 0, 0.06);
    color: #1f1f1f;
    font-size: 24px;
    z-index: 4;
}

.passos-indicador {
    display: flex;
    gap: 8px;
    margin-bottom: 24px;
}

.passo-bolinha {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #d7d4ce;
}

.passo-bolinha.ativo {
    background: #5d5d5d;
}

.agenda-ilustracao {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 8px;
    margin-top: 18px;
}

.agenda-icone {
    font-size: 32px;
    line-height: 1;
    color: #3d3d3d;
}

.agenda-ilustracao h3 {
    font-size: 0.92rem;
    font-weight: 500;
}

.agenda-ilustracao p {
    color: #8b8b8b;
    line-height: 1.25;
    font-size: 0.74rem;
}

.agenda-duvidas {
    margin-top: auto;
    display: flex;
    flex-direction: column;
    gap: 4px;
    color: #8b8b8b;
    font-size: 0.72rem;
}

.agenda-duvidas strong {
    color: #2e2e2e;
}

.agenda-acoes {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    margin-top: 10px;
    padding-top: 10px;
    border-top: 1px solid #ececec;
}

.agenda-acoes button,
#btnContinuar,
#btnConfirmar,
#btnIrParaBarbeiros,
#btnIrParaData {
    padding: 9px 14px;
    background: var(--cor-principal);
    color: #111;
    font-weight: bold;
    font-size: 12px;
}

#passo6 .agenda-acoes {
    background: #fff;
    margin-top: auto;
    flex-shrink: 0;
    min-height: 52px;
}

.agenda-acoes .btn-secundario {
    background: transparent;
    color: #252525;
    border: 1px solid #d6d6d6;
}

#btnContinuar {
    width: 100%;
    margin-top: 10px;
}

#listaServicosModal,
.lista-complementos,
.lista-barbeiros-modal,
.lista-horarios-modal {
    display: grid;
    gap: 14px;
}

.item-servico-modal,
.item-complemento-modal {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    background: #fff;
    border: 1px solid #dfe3ea;
    border-radius: 12px;
    padding: 12px 14px;
    cursor: pointer;
}

.item-servico-modal:hover,
.item-complemento-modal:hover,
.item-barbeiro-modal:hover,
.horario-item:hover {
    border-color: var(--cor-principal);
}

.item-servico-modal.selecionado,
.item-complemento-modal.selecionado,
.item-barbeiro-modal.selecionado,
.horario-item.selecionado {
    border-color: var(--cor-principal);
    box-shadow: 0 0 0 2px rgba(201, 154, 59, 0.18);
}

.item-servico-esquerda,
.item-complemento-esquerda {
    display: flex;
    gap: 12px;
    align-items: center;
    min-width: 0;
}

.item-servico-esquerda img,
.item-complemento-esquerda img {
    width: 55px;
    height: 55px;
    border-radius: 8px;
    object-fit: cover;
    flex: 0 0 55px;
}

.item-servico-texto,
.item-complemento-texto {
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 0;
}

.item-servico-texto strong,
.item-complemento-texto strong {
    color: #111;
    font-size: 15px;
}

.item-servico-texto span,
.item-complemento-texto span {
    font-size: 13px;
    color: #767676;
    line-height: 1.35;
}

.valor-direita {
    min-width: 85px;
    text-align: right;
    font-weight: bold;
    color: #111;
    white-space: nowrap;
    display: flex;
    flex-direction: column;
    gap: 4px;
    align-items: flex-end;
}

.valor-direita small {
    color: #777;
    font-size: 11px;
    font-weight: 600;
}

.complemento-checkbox {
    width: 18px;
    height: 18px;
    border: 1px solid #cfd5de;
    border-radius: 4px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--cor-principal);
    font-size: 13px;
}

.item-complemento-modal.selecionado .complemento-checkbox::before {
    content: "✓";
}

.complementos-vazio,
.barbeiros-vazio,
.horarios-vazio {
    border: 1px dashed #d5d5d5;
    border-radius: 12px;
    padding: 18px;
    color: #707070;
    background: #fafafa;
}

.lista-barbeiros-modal {
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
}

.item-barbeiro-modal {
    border: 1px solid #dfe3ea;
    border-radius: 12px;
    background: #fff;
    padding: 18px 14px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    text-align: center;
    cursor: pointer;
}

.item-barbeiro-modal img,
.avatar-barbeiro-padrao {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    object-fit: cover;
    background: #ebeef3;
}

.avatar-barbeiro-padrao {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 28px;
    color: #8e96a3;
}

.item-barbeiro-modal strong {
    font-size: 1.05rem;
    font-weight: 500;
}

.item-barbeiro-modal span {
    font-size: 13px;
    color: #717171;
}

.item-barbeiro-modal small {
    color: #8a8a8a;
    font-size: 12px;
    line-height: 1.3;
}

.aviso-data-agendamento {
    min-height: 20px;
    margin: 6px 0 10px;
    color: #666;
    font-size: 12px;
}

.calendario-agendamento {
    border: 1px solid #e5e5e5;
    border-radius: 14px;
    padding: 6px;
    background: #fcfcfc;
    width: 100%;
    max-width: 390px;
}

.calendario-topo {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    margin-bottom: 4px;
    padding: 0 2px;
}

.calendario-topo strong {
    font-size: 0.74rem;
    color: #252525;
}

.btn-calendario-nav {
    width: 24px;
    min-width: 24px;
    height: 24px;
    padding: 0;
    font-size: 12px;
    line-height: 1;
}

.calendario-semana,
.calendario-dias {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 1px;
}

.calendario-semana {
    margin-bottom: 4px;
    padding: 0 2px;
}

.calendario-semana span {
    text-align: center;
    font-size: 8px;
    color: #7a7a7a;
    text-transform: uppercase;
}

.dia-calendario,
.dia-calendario-vazio {
    aspect-ratio: 1;
    border-radius: 5px;
}

.dia-calendario {
    border: 1px solid #dbdbdb;
    background: #f2f2f2;
    color: #202020;
    font-weight: 600;
    cursor: pointer;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 1px;
    padding: 2px 1px;
    min-height: 18px;
}

.dia-calendario-numero {
    line-height: 1;
    font-size: 0.58rem;
}

.dia-calendario-status {
    width: 8px;
    height: 1px;
    border-radius: 999px;
    background: #d7d7d7;
}

.dia-calendario.disponivel {
    background: #e7f5ea;
    border-color: #a9d9b3;
    color: #22663a;
}

.dia-calendario.indisponivel,
.dia-calendario.passado {
    background: #f4f4f4;
    color: #b1b1b1;
    border-color: #ebebeb;
    cursor: not-allowed;
}

.dia-calendario.selecionado {
    background: var(--cor-principal);
    border-color: var(--cor-principal);
    color: #111;
    box-shadow: 0 0 0 2px rgba(201, 154, 59, 0.18);
}

.dia-calendario.tem-horario .dia-calendario-status {
    background: #36a853;
}

.dia-calendario.sem-horario .dia-calendario-status {
    background: #d94a4a;
}

.dia-calendario.passado .dia-calendario-status,
.dia-calendario.indisponivel .dia-calendario-status {
    opacity: 0.75;
}

.dia-calendario-vazio {
    background: transparent;
}

.lista-horarios-modal {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    max-height: 300px;
    overflow-y: auto;
    padding-right: 6px;
    align-content: start;
}

.lista-horarios-modal::-webkit-scrollbar {
    width: 8px;
}

.lista-horarios-modal::-webkit-scrollbar-track {
    background: #efefef;
    border-radius: 999px;
}

.lista-horarios-modal::-webkit-scrollbar-thumb {
    background: #b9b9b9;
    border-radius: 999px;
}

.lista-horarios-modal::-webkit-scrollbar-thumb:hover {
    background: #9e9e9e;
}

.horario-item {
    border: 1px solid #dfe3ea;
    border-radius: 10px;
    padding: 9px 6px;
    text-align: center;
    background: #f6f6f6;
    font-weight: bold;
    cursor: pointer;
    min-height: 36px;
    font-size: 12px;
}

.horario-item span,
.horario-item small {
    display: block;
    line-height: 1.2;
}

.horario-item small {
    margin-top: 2px;
    color: #666;
    font-size: 10px;
    font-weight: 600;
}

.agenda-resumo h3 {
    text-transform: uppercase;
    letter-spacing: .18em;
    font-size: 0.74rem;
    margin-bottom: 12px;
}

.resumo-item {
    padding: 8px 0;
    border-bottom: 1px solid rgba(0, 0, 0, 0.08);
    display: flex;
    flex-direction: column;
    gap: 3px;
}

.resumo-item span {
    text-transform: uppercase;
    letter-spacing: .08em;
    font-size: 0.58rem;
    color: #8f8b83;
}

.resumo-item strong {
    color: #1f1f1f;
    font-size: 0.84rem;
    font-weight: 500;
}

.resumo-total strong {
    font-size: 0.96rem;
    font-weight: 700;
}

.item-editor-servico,
.item-agendamento {
    background: #222;
    border: 1px solid #333;
    border-radius: 10px;
    padding: 10px;
    margin-bottom: 10px;
    font-size: 13px;
}

.item-editor-servico strong,
.item-agendamento strong {
    color: var(--cor-principal);
}

.item-editor-servico .acoes {
    display: flex;
    gap: 8px;
    margin-top: 8px;
}

.item-editor-servico .acoes button {
    margin: 0;
    padding: 8px;
}

.acoes-agendamento {
    margin-top: 8px;
}

.acoes-agendamento button {
    margin-top: 0;
    padding: 8px;
}

.link-agendamento {
    color: var(--cor-principal);
    display: inline-block;
    margin-top: 6px;
    text-decoration: none;
}

.link-agendamento:hover {
    text-decoration: underline;
}

.barbeiro-admin-topo {
    display: flex;
    gap: 10px;
    align-items: center;
}

.barbeiro-admin-topo img,
.barbeiro-admin-sem-foto {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    object-fit: cover;
    background: #2d2d2d;
}

.barbeiro-admin-sem-foto {
    display: flex;
    align-items: center;
    justify-content: center;
    color: #949494;
}

.barbeiro-duracoes-resumo {
    margin-top: 8px;
    color: #bcbcbc;
    font-size: 12px;
    line-height: 1.35;
}

.btn-remover {
    background: #b83232 !important;
    color: #fff !important;
}

.imagem-editavel {
    cursor: grab;
    transition: outline .15s ease, box-shadow .15s ease;
    transform-origin: center center;
    user-select: none;
}

.imagem-editavel:active {
    cursor: grabbing;
}

.imagem-editavel.selecionada {
    outline: 3px dashed var(--cor-principal);
    outline-offset: 3px;
    box-shadow: 0 0 0 4px rgba(201,154,59,.18);
    z-index: 4;
    position: relative;
}

.preview.mobile .topo {
    flex-direction: row;
    align-items: center;
    padding: 12px;
    gap: 10px;
}

.preview.mobile .logo {
    max-width: 100%;
}

.preview.mobile .logo img {
    flex-basis: 46px;
    width: 46px;
    height: 46px;
}

.preview.mobile .logo span {
    font-size: 15px;
}

.preview.mobile nav {
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 10px;
    font-size: 12px;
}

.preview.mobile .grid-servicos {
    grid-template-columns: 1fr;
}

.preview.mobile .servicos {
    padding: 45px 18px;
}

.preview.mobile .avaliacoes-google {
    padding: 45px 18px;
}

.preview.mobile .hero {
    min-height: 440px;
    padding: 45px 18px;
}

@media (max-width: 1100px) {
    .agenda-layout {
        grid-template-columns: 220px minmax(0, 1fr);
    }

    .agenda-resumo {
        grid-column: 1 / -1;
        border-left: none;
        border-top: 1px solid rgba(0, 0, 0, 0.08);
    }
}

@media (max-width: 900px) {
    .app {
        flex-direction: column;
    }

    .painel {
        width: 100%;
        max-height: none;
    }

    .area-preview {
        padding: 12px;
    }

    .abas-principais {
        justify-content: stretch;
    }

    .abas-principais button {
        flex: 1;
    }

    .painel-gestao-cabecalho,
    .painel-grid {
        grid-template-columns: 1fr;
    }

    .painel-gestao-tela .resumo-financeiro,
    .lista-agenda-operacional {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .grid-servicos {
        grid-template-columns: 1fr;
    }

    .avaliacao-card {
        flex-basis: min(86vw, 340px);
    }

    .topo {
        padding: 12px 14px;
        gap: 10px;
    }

    .logo img {
        flex-basis: 50px;
        width: 50px;
        height: 50px;
    }

    .logo span {
        font-size: 15px;
    }

    nav {
        flex-wrap: wrap;
        justify-content: flex-end;
        gap: 10px;
        font-size: 12px;
    }
}

@media (max-width: 760px) {
    .modal-agendamento {
        align-items: flex-start;
        padding: 10px;
    }

    .modal-caixa {
        width: 100%;
        max-height: 95vh;
        max-height: 95dvh;
    }

    .agenda-layout {
        display: flex;
        flex-direction: column;
        height: 95vh;
        height: 95dvh;
    }

    .agenda-lateral,
    .agenda-resumo {
        border: none;
    }

    .agenda-lateral {
        flex: 0 0 auto;
        padding: 12px 14px 10px;
    }

    .agenda-resumo {
        display: none;
    }

    .agenda-resumo-mobile {
        display: grid;
        gap: 2px;
        flex: 0 0 auto;
        padding: 10px 14px;
        background: #fbfaf8;
        border-top: 1px solid rgba(0, 0, 0, 0.08);
        color: #1f1f1f;
    }

    .agenda-resumo-mobile span {
        color: #8f8b83;
        font-size: 10px;
        font-weight: 800;
        text-transform: uppercase;
        letter-spacing: .08em;
    }

    .agenda-resumo-mobile strong {
        min-width: 0;
        color: #1f1f1f;
        font-size: 13px;
        line-height: 1.25;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    .agenda-ilustracao {
        display: none;
    }

    .agenda-duvidas {
        display: none;
    }

    .passos-indicador {
        margin-bottom: 0;
    }

    .agenda-conteudo {
        flex: 1 1 auto;
        min-height: 0;
    }

    .agenda-passo {
        padding: 18px;
        min-height: 0;
    }

    .agenda-acoes {
        flex-direction: column;
    }

    .lista-horarios-modal {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .painel-gestao-tela {
        padding: 16px;
    }

    .painel-gestao-tela .resumo-financeiro,
    .lista-agenda-operacional {
        grid-template-columns: 1fr;
    }

    .grafico-linha {
        grid-template-columns: 1fr;
        gap: 6px;
    }

    .grafico-valor {
        text-align: left;
    }
}

/* ===== Incremento: gráficos profissionais e aba de agendas ===== */
.painel-agendas-tela {
    width: 100%;
    max-width: 1200px;
    min-height: 100vh;
    background: radial-gradient(circle at top left, rgba(201,154,59,.12), transparent 34%), #111;
    border: 1px solid rgba(255, 255, 255, .12);
    border-radius: 16px;
    padding: 24px;
    box-shadow: 0 0 30px rgba(0, 0, 0, .45);
}

.agenda-toolbar {
    display: grid;
    gap: 10px;
    padding: 14px;
    background: #181818;
    border: 1px solid #2d2d2d;
    border-radius: 12px;
}

.agenda-toolbar button {
    cursor: pointer;
    border: none;
    border-radius: 10px;
    padding: 11px 14px;
    background: var(--cor-principal);
    color: #111;
    font-weight: 800;
    transition: .2s;
}

.agenda-toolbar button:nth-child(2) {
    background: #2b2b2b;
    color: #fff;
    border: 1px solid #3b3b3b;
}

.agenda-toolbar button:hover {
    transform: translateY(-1px);
    filter: brightness(1.08);
}

.grafico-pro {
    display: grid;
    gap: 14px;
    margin-top: 14px;
}

.grafico-pro-linha {
    padding: 12px;
    border: 1px solid rgba(255,255,255,.10);
    border-radius: 14px;
    background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.03));
}

.grafico-pro-topo {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: center;
    margin-bottom: 9px;
}

.grafico-pro-topo strong {
    color: #fff;
    font-size: 13px;
}

.grafico-pro-topo span {
    color: #d7d7d7;
    font-size: 12px;
    text-align: right;
}

.grafico-pro-trilho {
    height: 12px;
    border-radius: 999px;
    background: rgba(255,255,255,.09);
    overflow: hidden;
    position: relative;
}

.grafico-pro-barra {
    display: block;
    width: var(--largura-barra, 0%);
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, var(--cor-principal), #f0c76b);
    box-shadow: 0 0 18px rgba(201,154,59,.35);
}

.grafico-pro-linha.negativo .grafico-pro-barra {
    background: linear-gradient(90deg, #ee8b8b, #d94a4a);
    box-shadow: 0 0 18px rgba(217,74,74,.30);
}

.agenda-card,
.agenda-barbeiro-card {
    background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.03));
    border: 1px solid rgba(255,255,255,.11);
    border-radius: 14px;
    padding: 14px;
    box-shadow: 0 12px 24px rgba(0,0,0,.18);
}

.agenda-card-topo {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    margin-bottom: 10px;
}

.agenda-card-topo strong,
.agenda-barbeiro-topo strong {
    color: var(--cor-principal);
    font-size: 15px;
}

.agenda-card-topo span {
    flex: 0 0 auto;
    padding: 4px 8px;
    border-radius: 999px;
    background: rgba(201,154,59,.14);
    color: var(--cor-principal);
    font-size: 11px;
    font-weight: 800;
}

.agenda-card-info,
.agenda-barbeiro-metricas {
    display: grid;
    gap: 5px;
    color: #d1d1d1;
    font-size: 12px;
    line-height: 1.35;
}

.agenda-card-acoes {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 8px;
    margin-top: 12px;
}

.agenda-card-acoes button,
.agenda-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    padding: 8px;
    border-radius: 9px;
    border: none;
    background: #2b2b2b;
    color: #fff;
    font-size: 11px;
    font-weight: 800;
    text-decoration: none;
    cursor: pointer;
    text-align: center;
}

.agenda-link {
    background: var(--cor-principal);
    color: #111;
}

.agenda-link-desativado {
    background: #333;
    color: #aaa;
    cursor: default;
}

.agenda-barbeiro-topo {
    display: flex;
    gap: 12px;
    align-items: center;
    margin-bottom: 12px;
}

.agenda-barbeiro-topo img,
.agenda-barbeiro-topo .avatar-barbeiro-padrao {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    object-fit: cover;
    flex: 0 0 48px;
}

.agenda-barbeiro-topo span {
    display: block;
    color: #cfcfcf;
    font-size: 12px;
    margin-top: 3px;
}

@media (max-width: 760px) {
    .agenda-card-acoes {
        grid-template-columns: 1fr;
    }
}

/* ===== Correção: aba Agendas em formato de lista por barbeiro e horário ===== */
.agenda-toolbar-com-filtro label {
    color: #ddd;
    font-size: 13px;
    font-weight: 700;
}

.agenda-toolbar-com-filtro input[type="date"] {
    width: 100%;
    padding: 10px;
    border: 1px solid #333;
    border-radius: 10px;
    background: #222;
    color: #fff;
    outline: none;
}

.subtexto-painel {
    margin: -6px 0 12px;
    color: #bdbdbd;
    font-size: 13px;
    line-height: 1.4;
}

.painel-secao-agenda-dia {
    min-width: 0;
}

.agenda-grade-barbeiros {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(270px, 1fr));
    gap: 14px;
    align-items: start;
}

.agenda-coluna-barbeiro {
    min-width: 0;
    overflow: hidden;
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 16px;
    background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.035));
    box-shadow: 0 12px 24px rgba(0,0,0,.20);
}

.agenda-coluna-topo {
    display: flex;
    gap: 12px;
    align-items: center;
    padding: 14px;
    background: rgba(0,0,0,.22);
    border-bottom: 1px solid rgba(255,255,255,.10);
}

.agenda-coluna-topo img,
.agenda-coluna-topo .avatar-barbeiro-padrao {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    object-fit: cover;
    flex: 0 0 50px;
}

.agenda-coluna-topo strong {
    display: block;
    color: var(--cor-principal);
    font-size: 16px;
    margin-bottom: 3px;
}

.agenda-coluna-topo span,
.agenda-coluna-topo small {
    display: block;
    color: #d2d2d2;
    font-size: 12px;
    line-height: 1.35;
}

.agenda-lista-horarios {
    display: grid;
    gap: 8px;
    max-height: 520px;
    overflow-y: auto;
    padding: 12px;
}

.agenda-lista-horarios::-webkit-scrollbar {
    width: 8px;
}

.agenda-lista-horarios::-webkit-scrollbar-track {
    background: rgba(255,255,255,.08);
    border-radius: 999px;
}

.agenda-lista-horarios::-webkit-scrollbar-thumb {
    background: rgba(255,255,255,.28);
    border-radius: 999px;
}

.linha-horario-agenda {
    display: grid;
    grid-template-columns: 58px minmax(0, 1fr) auto;
    gap: 10px;
    align-items: center;
    padding: 10px;
    border-radius: 12px;
    border: 1px solid rgba(255,255,255,.10);
    background: rgba(255,255,255,.045);
}

.linha-horario-agenda.livre {
    opacity: .72;
    grid-template-columns: 58px minmax(0, 1fr);
}

.linha-horario-agenda.ocupado {
    border-color: rgba(201,154,59,.45);
    background: rgba(201,154,59,.11);
}

.linha-horario-agenda strong {
    color: #fff;
    font-size: 13px;
    text-align: center;
    padding: 7px 6px;
    border-radius: 999px;
    background: rgba(0,0,0,.25);
}

.linha-horario-agenda span {
    display: block;
    color: #fff;
    font-size: 13px;
    font-weight: 800;
    overflow-wrap: anywhere;
}

.linha-horario-agenda small {
    display: block;
    color: #cfcfcf;
    font-size: 11px;
    line-height: 1.35;
    margin-top: 2px;
}

.linha-horario-agenda button {
    min-width: 38px;
    padding: 7px 8px;
    border-radius: 8px;
    border: none;
    background: var(--cor-principal);
    color: #111;
    font-weight: 900;
    cursor: pointer;
}

@media (max-width: 900px) {
    .agenda-grade-barbeiros {
        grid-template-columns: 1fr;
    }

    .agenda-lista-horarios {
        max-height: none;
    }
}

/* ===== Dashboard profissional inspirado no padrão CredBusiness ===== */
.painel-gestao-tela.dashboard-profissional {
    background: #eef3f6;
    color: #26333b;
    border: 0;
    padding: 0;
    overflow: hidden;
}

.painel-gestao-tela.dashboard-profissional .painel-gestao-cabecalho {
    background: #092238;
    color: #fff;
    grid-template-columns: minmax(0, 1fr) minmax(320px, 480px);
    padding: 22px 26px;
    margin: 0;
    border-radius: 16px 16px 0 0;
}

.painel-gestao-tela.dashboard-profissional .painel-kicker {
    color: #4bd08b;
}

.painel-gestao-tela.dashboard-profissional .painel-gestao-cabecalho h2,
.painel-gestao-tela.dashboard-profissional .painel-gestao-cabecalho p {
    color: #fff;
}

.painel-gestao-tela.dashboard-profissional .gestao-filtros {
    background: transparent;
    border: 0;
    padding: 0;
    grid-template-columns: repeat(2, 1fr);
}

.painel-gestao-tela.dashboard-profissional .gestao-filtros label {
    color: #c7d4dc;
}

.painel-gestao-tela.dashboard-profissional .gestao-filtros input,
.painel-gestao-tela.dashboard-profissional .gestao-filtros select {
    background: #12324c;
    border-color: rgba(75, 208, 139, .5);
}

.painel-gestao-tela.dashboard-profissional .gestao-filtros button {
    grid-column: 1 / -1;
    background: #4bd08b;
    color: #082136;
}

.dashboard-metricas-topo,
.dashboard-filtros-visuais,
.painel-gestao-tela.dashboard-profissional .resumo-financeiro,
.painel-gestao-tela.dashboard-profissional .painel-grid,
.painel-gestao-tela.dashboard-profissional > .painel-secao {
    margin-left: 18px;
    margin-right: 18px;
}

.dashboard-metricas-topo {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
    margin-top: 18px;
    margin-bottom: 14px;
}

.dashboard-metrica {
    background: #fff;
    border: 1px solid #dfe8ee;
    border-radius: 10px;
    padding: 14px;
    box-shadow: 0 6px 18px rgba(12, 33, 50, .06);
}

.dashboard-metrica span {
    color: #73808a;
    font-size: 12px;
    display: block;
    margin-bottom: 4px;
}

.dashboard-metrica strong {
    color: #0d253a;
    font-size: 22px;
}

.dashboard-metrica.destaque strong {
    color: #17a96b;
}

.painel-gestao-tela.dashboard-profissional .painel-grid {
    grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
    gap: 16px;
}

.painel-gestao-tela.dashboard-profissional .painel-secao {
    background: #fff;
    border: 1px solid #dfe8ee;
    border-radius: 10px;
    box-shadow: 0 6px 18px rgba(12, 33, 50, .06);
}

.painel-gestao-tela.dashboard-profissional .painel-secao h3 {
    color: #66737c;
    font-size: 13px;
    font-weight: 700;
    margin-bottom: 14px;
}

.painel-gestao-tela.dashboard-profissional .resumo-card,
.painel-gestao-tela.dashboard-profissional .gestao-item {
    background: #fff;
    border: 1px solid #e4edf2;
    color: #26333b;
}

.painel-gestao-tela.dashboard-profissional .resumo-card strong,
.painel-gestao-tela.dashboard-profissional .gestao-item strong {
    color: #0d253a;
}

.chart-card {
    min-height: 230px;
}

.chart-horizontal {
    display: grid;
    gap: 14px;
}

.chart-horizontal-row {
    display: grid;
    grid-template-columns: 145px minmax(0, 1fr) 44px;
    gap: 10px;
    align-items: center;
    font-size: 12px;
    color: #40505a;
}

.chart-horizontal-track {
    height: 24px;
    position: relative;
    border-left: 1px dotted #d6e0e7;
    border-right: 1px dotted #d6e0e7;
}

.chart-horizontal-bar {
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    height: 20px;
    width: var(--largura-barra);
    border-radius: 0 2px 2px 0;
    background: #4bd08b;
}

.chart-horizontal-value {
    font-weight: 800;
    color: #0e263b;
}

.chart-vertical {
    display: flex;
    align-items: flex-end;
    gap: 9px;
    height: 180px;
    padding: 16px 8px 22px;
    border-bottom: 1px dotted #cfdbe3;
    background-image: linear-gradient(to top, transparent 24%, rgba(207,219,227,.7) 25%, transparent 26%, transparent 49%, rgba(207,219,227,.7) 50%, transparent 51%, transparent 74%, rgba(207,219,227,.7) 75%, transparent 76%);
}

.chart-vertical-item {
    flex: 1;
    min-width: 8px;
    position: relative;
    display: flex;
    align-items: flex-end;
    justify-content: center;
}

.chart-vertical-bar {
    width: 100%;
    max-width: 28px;
    min-height: 4px;
    height: var(--altura-barra);
    background: #4bd08b;
    border-radius: 2px 2px 0 0;
}

.chart-vertical-label {
    position: absolute;
    bottom: -22px;
    font-size: 10px;
    color: #798791;
}

.chart-line svg {
    width: 100%;
    height: 210px;
    overflow: visible;
}

.chart-line-grid {
    stroke: #d7e1e8;
    stroke-dasharray: 3 4;
}

.chart-line-path {
    fill: none;
    stroke: #4bd08b;
    stroke-width: 3;
}

.chart-line-dot {
    fill: #4bd08b;
    stroke: #fff;
    stroke-width: 2;
}

.chart-line-label {
    font-size: 11px;
    fill: #0e263b;
    font-weight: 700;
}

.chart-line-x {
    font-size: 10px;
    fill: #71808a;
}

.caixa-dashboard {
    display: grid;
    gap: 14px;
}

.caixa-kpis {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
}

.caixa-kpi {
    min-width: 0;
    border-radius: 14px;
    padding: 13px;
    background: #f8fafb;
    border: 1px solid #e2e8ee;
}

.caixa-kpi span {
    display: block;
    color: #66727e;
    font-size: 11px;
    font-weight: 900;
    text-transform: uppercase;
}

.caixa-kpi strong {
    display: block;
    margin-top: 5px;
    color: #1b1f24;
    font-size: 18px;
}

.caixa-kpi.entrada {
    border-color: rgba(54, 168, 83, .28);
    background: #f3fff6;
}

.caixa-kpi.saida {
    border-color: rgba(217, 74, 74, .28);
    background: #fff6f4;
}

.caixa-kpi.saldo {
    border-color: color-mix(in srgb, var(--cor-principal) 38%, #dfe8ee 62%);
    background: color-mix(in srgb, var(--cor-principal) 12%, #fff 88%);
}

.caixa-graficos {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.caixa-grafico-card {
    min-width: 0;
    background: #fff;
    border: 1px solid #e1e7ed;
    border-radius: 14px;
    padding: 13px;
}

.caixa-grafico-card > strong {
    display: block;
    color: #1b1f24;
    margin-bottom: 10px;
}

.caixa-grafico-card .grafico-pro-linha {
    background: #f8fafb;
    border-color: #e2e8ee;
}

.caixa-grafico-card .grafico-pro-topo strong {
    color: #1b1f24;
}

.caixa-grafico-card .grafico-pro-topo span {
    color: #66727e;
}

.caixa-grafico-card .grafico-pro-trilho {
    background: #e9eef3;
}

.caixa-grafico-linha {
    grid-column: 1 / -1;
}

.caixa-lista-topo {
    display: flex;
    justify-content: space-between;
    gap: 10px;
    align-items: baseline;
    margin: 14px 0 10px;
}

.caixa-lista-topo strong {
    color: #1b1f24;
}

.caixa-lista-topo span {
    color: #66727e;
    font-size: 12px;
}

.caixa-lista-movimentos {
    display: grid;
    gap: 8px;
}

.caixa-movimento {
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr) auto;
    gap: 10px;
    align-items: center;
    background: #fff;
    border: 1px solid #e2e8ee;
    border-left: 5px solid #59c77a;
    border-radius: 12px;
    padding: 10px;
}

.caixa-movimento.saida {
    border-left-color: #f06a3d;
}

.caixa-movimento-icone {
    width: 34px;
    height: 34px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #eaf8ef;
    color: #236e38;
    font-weight: 900;
}

.caixa-movimento.saida .caixa-movimento-icone {
    background: #fff0eb;
    color: #b74125;
}

.caixa-movimento-info {
    min-width: 0;
    display: grid;
    gap: 2px;
}

.caixa-movimento-info strong {
    color: #1b1f24;
    font-size: 13px;
}

.caixa-movimento-info span,
.caixa-movimento-info small {
    color: #66727e;
    font-size: 12px;
    overflow-wrap: anywhere;
}

.caixa-movimento-valor {
    display: grid;
    gap: 5px;
    justify-items: end;
}

.caixa-movimento-valor strong {
    color: #236e38;
    white-space: nowrap;
}

.caixa-movimento.saida .caixa-movimento-valor strong {
    color: #b74125;
}

.caixa-movimento-valor button {
    cursor: pointer;
    border: none;
    border-radius: 7px;
    background: #eef2f5 !important;
    color: #1b1f24 !important;
    padding: 6px 8px;
    font-size: 11px;
    font-weight: 900;
}

.whatsapp-tela {
    width: 100%;
    max-width: 1440px;
    min-height: 760px;
    display: grid;
    grid-template-columns: 330px minmax(0, 1fr);
    background: #eef3f1;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 0 30px rgba(0,0,0,.45);
    border: 1px solid rgba(255,255,255,.12);
}

.whatsapp-lateral {
    min-width: 0;
    background: #0f2d24;
    color: #fff;
    padding: 18px;
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.whatsapp-lateral .whatsapp-conversas {
    flex: 1;
    min-height: 220px;
    max-height: 360px;
    align-content: start;
    grid-auto-rows: max-content;
}

.whatsapp-lateral h2 {
    margin: 6px 0;
    color: #fff;
}

.whatsapp-lateral p {
    color: rgba(255,255,255,.72);
    font-size: 13px;
    line-height: 1.45;
}

.whatsapp-status,
.whatsapp-nova-conversa {
    display: grid;
    gap: 6px;
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.14);
    border-radius: 14px;
    padding: 12px;
}

.whatsapp-chatbot-config {
    display: grid;
    gap: 8px;
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.14);
    border-radius: 14px;
    padding: 12px;
}

.whatsapp-chatbot-config textarea,
.whatsapp-chatbot-config input {
    width: 100%;
    border: 1px solid #dce5e1;
    border-radius: 10px;
    padding: 11px;
}

.whatsapp-chatbot-config textarea {
    min-height: 86px;
    resize: vertical;
}

.whatsapp-chatbot-config input {
    min-height: 42px;
}

.chatbot-teste-resposta {
    min-height: 42px;
    max-height: 180px;
    overflow-y: auto;
    white-space: pre-wrap;
    border: 1px solid rgba(255,255,255,.14);
    border-radius: 10px;
    background: rgba(255,255,255,.08);
    color: rgba(255,255,255,.88);
    padding: 10px;
    font-size: 12px;
    line-height: 1.45;
}

.whatsapp-filtros {
    display: grid;
    gap: 8px;
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.14);
    border-radius: 14px;
    padding: 12px;
}

.whatsapp-status strong {
    color: #ffbc66;
}

.whatsapp-status.ok strong {
    color: #59d58a;
}

.whatsapp-status span,
.whatsapp-status small,
.whatsapp-nova-conversa label,
.whatsapp-filtros label {
    color: rgba(255,255,255,.72);
    font-size: 12px;
}

.whatsapp-nova-conversa input,
.whatsapp-filtros input,
.whatsapp-filtros select,
.whatsapp-resposta textarea {
    width: 100%;
    border: 1px solid #dce5e1;
    border-radius: 10px;
    padding: 11px;
    background: #fff;
    color: #111;
    outline: none;
}

.whatsapp-botao,
.whatsapp-nova-conversa button,
.whatsapp-botao-perigo,
.whatsapp-resposta button,
.whatsapp-chat-topo a {
    cursor: pointer;
    border: none;
    border-radius: 10px;
    background: #25d366;
    color: #062016;
    padding: 10px 12px;
    font-weight: 900;
    text-decoration: none;
}

.whatsapp-botao-perigo,
.whatsapp-chat-topo button {
    cursor: pointer;
    border: 1px solid rgba(255, 255, 255, .18);
    border-radius: 10px;
    background: #fee2e2;
    color: #7f1d1d;
    padding: 10px 12px;
    font-weight: 700;
}

.whatsapp-conversas {
    display: grid;
    gap: 8px;
    overflow-y: auto;
    padding-right: 3px;
}

.editor-bloco-whatsapp {
    gap: 12px;
}

.editor-bloco-whatsapp .whatsapp-status,
.editor-bloco-whatsapp .whatsapp-nova-conversa,
.editor-bloco-whatsapp .whatsapp-chatbot-config,
.editor-bloco-whatsapp .clientes-massa {
    background: #1d1d1d;
    border-color: #333;
    border-radius: 8px;
}

.editor-bloco-whatsapp .whatsapp-status span,
.editor-bloco-whatsapp .whatsapp-status small,
.editor-bloco-whatsapp .whatsapp-nova-conversa label,
.editor-bloco-whatsapp .whatsapp-chatbot-config label,
.editor-bloco-whatsapp .clientes-massa header span,
.editor-bloco-whatsapp .cliente-massa-item small,
.editor-bloco-whatsapp .cliente-massa-item em {
    color: #ddd;
}

.editor-bloco-whatsapp .whatsapp-botao,
.editor-bloco-whatsapp .whatsapp-nova-conversa button,
.editor-bloco-whatsapp .whatsapp-chatbot-config button,
.editor-bloco-whatsapp .clientes-massa-acoes button {
    width: 100%;
}

.editor-bloco-whatsapp .clientes-massa header strong,
.editor-bloco-whatsapp .cliente-massa-item strong {
    color: #fff;
}

.editor-bloco-whatsapp .cliente-massa-item {
    border-color: #333;
    background: #141414;
}

.whatsapp-conversa {
    width: 100%;
    cursor: pointer;
    border: 1px solid #dce5e1;
    border-radius: 12px;
    background: #fff;
    color: #1b1f24;
    padding: 8px 10px;
    text-align: left;
    display: grid;
    gap: 2px;
    position: relative;
}

.whatsapp-conversa.ativo {
    background: #25d366;
    color: #062016;
}

.whatsapp-conversa strong,
.whatsapp-conversa span {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.whatsapp-conversa span {
    font-size: 11px;
    color: #66736d;
}

.whatsapp-conversa em {
    width: max-content;
    border-radius: 999px;
    background: #edf6f1;
    color: inherit;
    padding: 3px 7px;
    font-size: 9px;
    font-style: normal;
    font-weight: 900;
    text-transform: uppercase;
}

.whatsapp-lateral .whatsapp-conversa {
    min-height: 0;
}

.whatsapp-fila-operacao .whatsapp-conversa {
    border-radius: 8px;
    padding: 10px;
}

.whatsapp-conversa small {
    position: absolute;
    right: 9px;
    top: 9px;
    min-width: 20px;
    height: 20px;
    border-radius: 999px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #ffbc66;
    color: #111;
    font-weight: 900;
}

.whatsapp-chat {
    min-width: 0;
    display: grid;
    grid-template-rows: auto auto minmax(0, 1fr) auto;
    background: #e7efeb;
    color: #1b1f24;
}

.whatsapp-operacao {
    display: grid;
    gap: 12px;
    background: #f8fbf9;
    border-bottom: 1px solid #dce5e1;
    padding: 14px 16px;
}

.whatsapp-kpis {
    display: grid;
    grid-template-columns: repeat(4, minmax(120px, 1fr));
    gap: 10px;
}

.whatsapp-kpis article {
    background: #fff;
    border: 1px solid #dce5e1;
    border-radius: 8px;
    padding: 10px 12px;
}

.whatsapp-kpis span {
    display: block;
    color: #66736d;
    font-size: 11px;
    font-weight: 800;
    text-transform: uppercase;
}

.whatsapp-kpis strong {
    display: block;
    color: #0f2d24;
    font-size: 24px;
    line-height: 1.1;
    margin-top: 4px;
}

.whatsapp-acoes-principais {
    display: flex;
    justify-content: flex-end;
}

.whatsapp-acoes-principais button {
    cursor: pointer;
    border: none;
    border-radius: 8px;
    background: #25d366;
    color: #062016;
    padding: 10px 14px;
    font-weight: 900;
}

.clientes-massa {
    display: grid;
    gap: 10px;
    border: 1px solid #dce5e1;
    border-radius: 8px;
    background: #fff;
    padding: 12px;
}

.clientes-massa.destacado {
    box-shadow: 0 0 0 3px rgba(37, 211, 102, .32);
}

.clientes-massa header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
}

.clientes-massa header strong {
    color: #0f2d24;
    font-size: 15px;
}

.clientes-massa header span {
    color: #66736d;
    font-size: 12px;
    font-weight: 800;
}

.clientes-massa textarea {
    width: 100%;
    min-height: 76px;
    border: 1px solid #dce5e1;
    border-radius: 8px;
    padding: 10px;
    resize: vertical;
    outline: none;
}

.clientes-massa-acoes {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.clientes-massa-acoes button {
    cursor: pointer;
    border: 1px solid #dce5e1;
    border-radius: 8px;
    background: #f8fbf9;
    color: #0f2d24;
    padding: 9px 11px;
    font-weight: 900;
}

.clientes-massa-acoes button:last-child {
    border-color: #25d366;
    background: #25d366;
    color: #062016;
}

.clientes-massa-acoes button:disabled {
    cursor: wait;
    opacity: .65;
}

.clientes-massa-lista {
    max-height: 210px;
    overflow-y: auto;
    display: grid;
    gap: 7px;
}

.cliente-massa-item {
    display: grid;
    grid-template-columns: 18px minmax(0, 1fr);
    gap: 9px;
    align-items: start;
    border: 1px solid #e8efec;
    border-radius: 8px;
    padding: 9px;
}

.cliente-massa-item input {
    margin-top: 3px;
}

.cliente-massa-item span {
    min-width: 0;
    display: grid;
    gap: 2px;
}

.cliente-massa-item strong,
.cliente-massa-item small,
.cliente-massa-item em {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.cliente-massa-item strong {
    color: #1b1f24;
    font-size: 13px;
}

.cliente-massa-item small,
.cliente-massa-item em {
    color: #66736d;
    font-size: 12px;
    font-style: normal;
}

.whatsapp-fila-operacao {
    max-height: 270px;
    overflow-y: auto;
    display: grid;
    gap: 7px;
}

.whatsapp-fila-item {
    width: 100%;
    cursor: pointer;
    border: 1px solid #dce5e1;
    border-radius: 8px;
    background: #fff;
    color: #1b1f24;
    padding: 10px;
    display: grid;
    grid-template-columns: minmax(140px, 1.1fr) minmax(130px, .8fr) minmax(180px, 1.8fr) 92px 92px;
    gap: 10px;
    align-items: center;
    text-align: left;
}

.whatsapp-fila-item.ativo {
    border-color: #25d366;
    box-shadow: 0 0 0 2px rgba(37, 211, 102, .18);
}

.whatsapp-fila-cliente,
.whatsapp-fila-telefone,
.whatsapp-fila-msg,
.whatsapp-fila-data {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.whatsapp-fila-cliente {
    font-weight: 900;
}

.whatsapp-fila-telefone,
.whatsapp-fila-msg,
.whatsapp-fila-data {
    color: #66736d;
    font-size: 12px;
}

.whatsapp-fila-status {
    justify-self: end;
    border-radius: 999px;
    padding: 5px 8px;
    font-size: 11px;
    font-weight: 900;
}

.whatsapp-fila-status.pendente {
    background: #fee2e2;
    color: #991b1b;
}

.whatsapp-fila-status.respondido {
    background: #dcfce7;
    color: #166534;
}

.whatsapp-fila-status.neutro {
    background: #e5e7eb;
    color: #374151;
}

.whatsapp-chat-topo {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    background: #fff;
    border-bottom: 1px solid #dce5e1;
    padding: 16px 18px;
}

.whatsapp-chat-topo strong,
.whatsapp-chat-topo span {
    display: block;
}

.whatsapp-chat-topo span {
    color: #66736d;
    font-size: 12px;
    margin-top: 3px;
}

.whatsapp-mensagens {
    min-height: 0;
    overflow-y: auto;
    padding: 18px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.whatsapp-msg {
    max-width: min(620px, 78%);
    border-radius: 14px;
    padding: 10px 12px;
    box-shadow: 0 8px 18px rgba(21,31,43,.07);
}

.whatsapp-msg.entrada {
    align-self: flex-start;
    background: #fff;
}

.whatsapp-msg.saida {
    align-self: flex-end;
    background: #dcf8c6;
}

.whatsapp-msg p {
    color: #1b1f24;
    line-height: 1.35;
}

.whatsapp-msg span {
    display: block;
    color: #66736d;
    font-size: 10px;
    margin-top: 5px;
    text-align: right;
}

.whatsapp-resposta {
    background: #fff;
    border-top: 1px solid #dce5e1;
    padding: 12px;
    display: grid;
    gap: 10px;
}

.whatsapp-respostas-rapidas {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.whatsapp-respostas-rapidas button {
    background: #edf6f1;
    color: #0f2d24;
    padding: 7px 10px;
    font-size: 12px;
}

.whatsapp-resposta textarea {
    min-height: 74px;
    resize: vertical;
}

@media (max-width: 900px) {
    .dashboard-metricas-topo,
    .painel-gestao-tela.dashboard-profissional .painel-grid,
    .painel-gestao-tela.dashboard-profissional .painel-gestao-cabecalho {
        grid-template-columns: 1fr;
    }

    .caixa-kpis,
    .caixa-graficos,
    .whatsapp-tela {
        grid-template-columns: 1fr;
    }

    .whatsapp-kpis {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .whatsapp-fila-item {
        grid-template-columns: 1fr;
    }

    .whatsapp-fila-status {
        justify-self: start;
    }
}


/* ===== Personalização: dashboard usa as mesmas cores do site ===== */
.painel-gestao-tela.dashboard-profissional {
    background: color-mix(in srgb, var(--cor-secundaria) 8%, #eef3f6 92%);
}

.painel-gestao-tela.dashboard-profissional .painel-gestao-cabecalho {
    background: linear-gradient(135deg, var(--cor-secundaria), color-mix(in srgb, var(--cor-secundaria) 82%, #000 18%));
    color: var(--cor-texto);
}

.painel-gestao-tela.dashboard-profissional .painel-kicker,
.painel-gestao-tela.dashboard-profissional .dashboard-metrica.destaque strong,
.painel-gestao-tela.dashboard-profissional .painel-secao h3,
.painel-gestao-tela.dashboard-profissional .chart-horizontal-value,
.painel-gestao-tela.dashboard-profissional .chart-line-label {
    color: var(--cor-principal);
    fill: var(--cor-principal);
}

.painel-gestao-tela.dashboard-profissional .painel-gestao-cabecalho h2,
.painel-gestao-tela.dashboard-profissional .painel-gestao-cabecalho p {
    color: var(--cor-texto);
}

.painel-gestao-tela.dashboard-profissional .gestao-filtros input,
.painel-gestao-tela.dashboard-profissional .gestao-filtros select {
    background: color-mix(in srgb, var(--cor-secundaria) 88%, #fff 12%);
    border-color: color-mix(in srgb, var(--cor-principal) 65%, #fff 35%);
    color: var(--cor-texto);
}

.painel-gestao-tela.dashboard-profissional .gestao-filtros button,
.painel-gestao-tela.dashboard-profissional button,
.chart-horizontal-bar,
.chart-vertical-bar {
    background: var(--cor-principal);
    color: #111;
}

.chart-line-path {
    stroke: var(--cor-principal);
}

.chart-line-dot {
    fill: var(--cor-principal);
}

.dashboard-metrica,
.painel-gestao-tela.dashboard-profissional .painel-secao,
.painel-gestao-tela.dashboard-profissional .resumo-card,
.painel-gestao-tela.dashboard-profissional .gestao-item {
    border-color: color-mix(in srgb, var(--cor-principal) 18%, #dfe8ee 82%);
}

.dashboard-metrica strong,
.painel-gestao-tela.dashboard-profissional .resumo-card strong,
.painel-gestao-tela.dashboard-profissional .gestao-item strong {
    color: color-mix(in srgb, var(--cor-secundaria) 80%, #000 20%);
}

.painel-gestao-tela.dashboard-profissional .chart-card {
    box-shadow: 0 8px 22px color-mix(in srgb, var(--cor-principal) 12%, transparent 88%);
}

/* ==============================
   AGENDA OPERACIONAL ESTILO SISTEMA PROFISSIONAL
   ============================== */
.agenda-profissional-tela {
    width: 100%;
    max-width: 1280px;
    min-height: 760px;
    display: grid;
    grid-template-columns: 245px minmax(0, 1fr);
    background: #f3f5f7;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 0 30px rgba(0,0,0,.45);
    border: 1px solid rgba(255,255,255,.12);
}

.agenda-menu-lateral {
    background: var(--cor-principal);
    color: #111;
    padding: 18px 14px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    min-height: 760px;
}

.agenda-logo-bloco {
    padding: 10px 8px 18px;
    border-bottom: 1px solid rgba(0,0,0,.16);
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.agenda-logo-bloco strong {
    font-size: 21px;
    line-height: 1;
    color: #111;
}

.agenda-logo-bloco span {
    font-size: 12px;
    color: rgba(0,0,0,.68);
    font-weight: 700;
}

.agenda-menu-item {
    width: 100%;
    cursor: pointer;
    border: none;
    border-radius: 10px;
    padding: 11px 12px;
    text-align: left;
    background: rgba(255,255,255,.18);
    color: #111;
    font-weight: 800;
    transition: .2s;
}

.agenda-menu-item:hover,
.agenda-menu-item.ativo {
    background: rgba(255,255,255,.82);
    transform: translateX(2px);
}

.agenda-filtros-box,
.agenda-mini-calendario,
.agenda-legenda {
    background: rgba(255,255,255,.82);
    border: 1px solid rgba(0,0,0,.08);
    border-radius: 14px;
    padding: 12px;
}

.agenda-filtros-box label {
    display: block;
    color: rgba(0,0,0,.66);
    font-size: 11px;
    font-weight: 800;
    margin: 10px 0 5px;
    text-transform: uppercase;
}

.agenda-filtros-box label:first-child {
    margin-top: 0;
}

.agenda-filtros-box input,
.agenda-filtros-box select {
    width: 100%;
    border: 1px solid rgba(0,0,0,.16);
    border-radius: 8px;
    padding: 9px;
    background: #fff;
    color: #111;
    outline: none;
}

.agenda-mini-calendario strong {
    display: block;
    margin-bottom: 10px;
    color: #111;
    text-transform: capitalize;
}

.agenda-mini-dias {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 4px;
}

.agenda-mini-semana,
.agenda-mini-vazio,
.agenda-mini-dia {
    height: 25px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 11px;
}

.agenda-mini-semana {
    color: rgba(0,0,0,.55);
    font-weight: 800;
}

.agenda-mini-dia {
    cursor: pointer;
    border: 1px solid rgba(0,0,0,.1);
    border-radius: 7px;
    background: #fff;
    color: #111;
    font-weight: 700;
}

.agenda-mini-dia.ativo {
    background: var(--cor-secundaria);
    color: var(--cor-texto);
    border-color: var(--cor-secundaria);
}

.agenda-legenda {
    display: grid;
    gap: 8px;
    margin-top: auto;
}

.agenda-legenda span {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    color: #222;
    font-weight: 700;
}

.agenda-legenda i {
    width: 11px;
    height: 11px;
    border-radius: 3px;
    display: inline-block;
}

.legenda-livre { background: #eaf8ef; border: 1px solid #a9dfb8; }
.legenda-ocupado { background: var(--cor-principal); }
.legenda-finalizado { background: #59c77a; }
.legenda-alerta { background: #f06a3d; }

.agenda-operacional-main {
    min-width: 0;
    display: flex;
    flex-direction: column;
    background: #eef2f4;
    color: #1b1f24;
}

.agenda-operacional-topo {
    min-height: 96px;
    padding: 18px 22px;
    background: var(--cor-secundaria);
    color: var(--cor-texto);
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 18px;
    align-items: center;
}

.agenda-operacional-topo h2 {
    margin: 3px 0;
    font-size: 26px;
    color: var(--cor-texto);
}

.agenda-operacional-topo p {
    color: rgba(255,255,255,.72);
    font-size: 13px;
}

.agenda-kpis {
    display: grid;
    grid-template-columns: repeat(4, minmax(88px, 1fr));
    gap: 10px;
}

.agenda-kpis .resumo-card {
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 12px;
    min-width: 90px;
}

.agenda-kpis .resumo-card span,
.agenda-kpis .resumo-card small {
    color: rgba(255,255,255,.68);
}

.agenda-kpis .resumo-card strong {
    color: var(--cor-principal);
    font-size: 20px;
}

.agenda-barra-controles {
    padding: 12px 18px;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: 10px;
    align-items: center;
    background: #fff;
    border-bottom: 1px solid #dfe5e9;
}

.agenda-barra-controles strong {
    text-align: center;
    text-transform: capitalize;
    color: #1b1f24;
}

.agenda-barra-controles button {
    cursor: pointer;
    border: 1px solid #d7dee4;
    border-radius: 9px;
    background: #f8fafb;
    color: #1b1f24;
    padding: 9px 12px;
    font-weight: 800;
}

.agenda-resumo-barbeiros {
    padding: 14px 16px 0;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 12px;
}

.agenda-resumo-barbeiro {
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr);
    gap: 10px;
    align-items: center;
    background: #fff;
    border: 1px solid #dfe5e9;
    border-radius: 14px;
    padding: 12px;
    box-shadow: 0 8px 18px rgba(21,31,43,.06);
}

.agenda-resumo-avatar img,
.agenda-resumo-avatar span {
    width: 42px;
    height: 42px;
    border-radius: 50%;
    object-fit: cover;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--cor-principal);
    color: #111;
    font-weight: 900;
}

.agenda-resumo-barbeiro strong {
    display: block;
    color: #1b1f24;
    font-size: 14px;
}

.agenda-resumo-barbeiro span {
    color: #77818b;
    font-size: 12px;
}

.agenda-resumo-metricas {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 6px;
}

.agenda-resumo-metricas span {
    background: #f4f6f8;
    border-radius: 8px;
    padding: 6px;
    text-align: center;
    color: #1b1f24;
    font-weight: 800;
    font-size: 11px;
}

.agenda-quadro-wrap {
    padding: 16px;
    overflow: auto;
    min-height: 430px;
}

.agenda-quadro-profissional {
    min-width: 760px;
}

.agenda-grid-agendamentos {
    display: grid;
    grid-template-columns: 76px repeat(calc(var(--agenda-colunas) - 1), minmax(185px, 1fr));
    border: 1px solid #dfe5e9;
    border-radius: 14px;
    overflow: hidden;
    background: #fff;
    box-shadow: 0 10px 24px rgba(21,31,43,.08);
}

.agenda-grid-cabecalho {
    position: sticky;
    top: 0;
    z-index: 2;
    background: #fff;
    border-right: 1px solid #e6ebef;
    border-bottom: 1px solid #dfe5e9;
    min-height: 74px;
}

.agenda-hora-cabecalho {
    display: flex;
    align-items: center;
    justify-content: center;
    color: #6d7884;
    font-size: 12px;
    font-weight: 900;
    text-transform: uppercase;
}

.agenda-barbeiro-cabecalho {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px;
}

.agenda-barbeiro-cabecalho img,
.agenda-barbeiro-cabecalho .avatar-barbeiro-padrao {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    object-fit: cover;
    flex: 0 0 auto;
}

.agenda-barbeiro-cabecalho strong {
    display: block;
    color: #1b1f24;
    font-size: 14px;
}

.agenda-barbeiro-cabecalho span {
    display: block;
    color: #77818b;
    font-size: 11px;
    margin-top: 3px;
}

.agenda-grid-hora {
    min-height: 76px;
    background: #fbfcfd;
    border-right: 1px solid #e6ebef;
    border-bottom: 1px solid #e6ebef;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding-top: 10px;
    color: #6d7884;
    font-size: 12px;
}

.agenda-grid-celula {
    min-height: 76px;
    border-right: 1px solid #edf1f4;
    border-bottom: 1px solid #edf1f4;
    padding: 6px;
    background: #fff;
}

.agenda-grid-celula.fora-expediente {
    background: #f6f7f8;
}

.agenda-celula-livre,
.agenda-celula-fechada {
    height: 100%;
    min-height: 62px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: 800;
}

.agenda-celula-livre {
    background: #eefaf2;
    color: #2e8b4d;
    border: 1px dashed #bfe8ca;
}

.agenda-celula-fechada {
    background: #f1f2f3;
    color: #a1a8af;
    border: 1px dashed #d8dde1;
}

.agenda-evento {
    height: 100%;
    min-height: 62px;
    border-radius: 11px;
    padding: 8px;
    display: flex;
    flex-direction: column;
    gap: 3px;
    color: #111;
    box-shadow: 0 8px 14px rgba(0,0,0,.08);
    border-left: 4px solid rgba(0,0,0,.22);
}

.agenda-evento.status-agendado {
    background: var(--cor-principal);
}

.agenda-evento.status-compareceu {
    background: #75d995;
}

.agenda-evento.status-nao-compareceu {
    background: #ff875f;
}

.agenda-evento.status-cancelado {
    background: #cfd4d9;
    color: #555;
}

.agenda-evento.evento-continuacao {
    opacity: .78;
    filter: saturate(.8);
}

.agenda-evento strong {
    font-size: 12px;
    line-height: 1.15;
}

.agenda-evento span,
.agenda-evento small {
    font-size: 10px;
    line-height: 1.2;
}

.agenda-evento-acoes {
    display: flex;
    gap: 4px;
    margin-top: auto;
}

.agenda-evento-acoes button {
    cursor: pointer;
    border: none;
    border-radius: 6px;
    background: rgba(255,255,255,.72);
    color: #111;
    font-size: 10px;
    font-weight: 900;
    padding: 4px 6px;
}

.agenda-rodape-listas {
    padding: 0 16px 16px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
}

.agenda-rodape-listas > div {
    background: #fff;
    border: 1px solid #dfe5e9;
    border-radius: 14px;
    padding: 14px;
    min-width: 0;
}

.agenda-rodape-listas h3 {
    color: #1b1f24;
    margin-bottom: 10px;
}

.agenda-lista-compacta {
    display: grid;
    gap: 8px;
    max-height: 260px;
    overflow-y: auto;
    padding-right: 4px;
}

.agenda-card-compacto {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px;
    align-items: center;
    border: 1px solid #e4e9ed;
    border-left: 5px solid var(--cor-principal);
    border-radius: 11px;
    padding: 10px;
    background: #fff;
}

.agenda-card-compacto.status-compareceu { border-left-color: #59c77a; }
.agenda-card-compacto.status-nao-compareceu { border-left-color: #f06a3d; }
.agenda-card-compacto.status-cancelado { border-left-color: #a7afb7; opacity: .72; }

.agenda-card-compacto strong {
    display: block;
    color: #1b1f24;
    font-size: 13px;
}

.agenda-card-compacto span {
    display: block;
    color: #74808a;
    font-size: 12px;
    margin-top: 3px;
}

.agenda-card-compacto small {
    display: block;
    color: #54606b;
    font-size: 11px;
    margin-top: 4px;
    font-weight: 800;
}

.agenda-card-compacto.comanda-fechada {
    background: #f4fff7;
}

.agenda-card-compacto-acoes {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 5px;
}

.agenda-card-compacto-acoes button,
.agenda-card-compacto-acoes a {
    cursor: pointer;
    border: none;
    border-radius: 7px;
    background: var(--cor-principal);
    color: #111;
    text-decoration: none;
    padding: 6px 8px;
    font-size: 11px;
    font-weight: 900;
}

.agenda-vazio-profissional {
    background: #fff;
    border: 1px dashed #ccd5dd;
    border-radius: 14px;
    padding: 30px;
    color: #697582;
    text-align: center;
    font-weight: 800;
}

@media (max-width: 980px) {
    .agenda-profissional-tela {
        grid-template-columns: 1fr;
    }

    .agenda-menu-lateral {
        min-height: auto;
    }

    .agenda-operacional-topo {
        grid-template-columns: 1fr;
    }

    .agenda-kpis,
    .agenda-rodape-listas {
        grid-template-columns: 1fr;
    }
}


/* ===== AJUSTE FINAL: agenda em colunas por barbeiro + mini calendário lateral ===== */
.agenda-profissional-tela {
    max-width: 1440px;
    grid-template-columns: 270px minmax(0, 1fr);
    background: #f4f6f8;
}

.agenda-menu-lateral {
    background: color-mix(in srgb, var(--cor-secundaria) 92%, #000 8%);
    color: var(--cor-texto);
    padding: 16px;
}

.agenda-logo-bloco strong,
.agenda-logo-bloco span,
.agenda-legenda span,
.agenda-mini-calendario strong,
.agenda-filtros-box label {
    color: var(--cor-texto);
}

.agenda-filtros-box,
.agenda-mini-calendario,
.agenda-legenda {
    background: rgba(255,255,255,.08);
    border-color: rgba(255,255,255,.14);
}

.agenda-filtros-box input,
.agenda-filtros-box select,
.agenda-menu-item {
    background: rgba(255,255,255,.95);
    color: #111;
}

.agenda-menu-item.ativo,
.agenda-menu-item:hover {
    background: var(--cor-principal);
    color: #111;
}

.agenda-mini-dias {
    gap: 5px;
}

.agenda-mini-semana,
.agenda-mini-vazio,
.agenda-mini-dia {
    height: 30px;
}

.agenda-mini-semana {
    color: rgba(255,255,255,.72);
}

.agenda-mini-dia {
    background: rgba(255,255,255,.94);
    border: 1px solid rgba(255,255,255,.15);
}

.agenda-mini-dia.ativo {
    background: var(--cor-principal);
    color: #111;
    border-color: var(--cor-principal);
}

.agenda-quadro-wrap {
    padding: 14px;
    overflow: auto;
    min-height: 580px;
}

.agenda-quadro-profissional {
    min-width: 900px;
}

.agenda-grade-colunas-barbeiros {
    grid-template-columns: 82px repeat(calc(var(--agenda-colunas) - 1), minmax(210px, 1fr));
    align-items: stretch;
}

.agenda-grid-cabecalho {
    position: sticky;
    top: 0;
    z-index: 5;
}

.agenda-barbeiro-cabecalho {
    min-height: 78px;
    background: #ffffff;
}

.agenda-barbeiro-cabecalho small {
    display: block;
    color: #8a96a3;
    font-size: 10px;
    margin-top: 2px;
}

.agenda-grid-hora,
.agenda-grid-celula {
    min-height: 82px;
}

.agenda-grid-hora {
    background: #f8fafc;
    color: #687684;
    font-weight: 800;
}

.agenda-grid-celula {
    background: #ffffff;
}

.agenda-celula-livre,
.agenda-celula-fechada {
    flex-direction: column;
    gap: 4px;
    min-height: 68px;
    text-align: center;
}

.agenda-celula-livre strong,
.agenda-celula-fechada strong {
    font-size: 12px;
}

.agenda-celula-livre span,
.agenda-celula-fechada span {
    font-size: 11px;
}

.agenda-celula-livre {
    background: linear-gradient(135deg, #f4fff7, #e9f8ee);
    border: 1px dashed #9bd7ac;
    color: #236e38;
}

.agenda-celula-fechada {
    background: #f1f3f5;
    border: 1px dashed #d3d9df;
    color: #8d98a3;
}

.agenda-evento {
    min-height: 68px;
    color: #111;
    background: var(--cor-principal);
}

.agenda-evento em {
    font-style: normal;
    width: fit-content;
    padding: 2px 6px;
    border-radius: 999px;
    background: rgba(255,255,255,.58);
    color: #111;
    font-size: 9px;
    font-weight: 900;
    text-transform: uppercase;
}

.agenda-evento.evento-continuacao .agenda-evento-acoes {
    display: none;
}

@media (max-width: 980px) {
    .agenda-profissional-tela {
        grid-template-columns: 1fr;
    }

    .agenda-quadro-profissional {
        min-width: 760px;
    }
}

.modal-comanda {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, .68);
    display: none;
    align-items: center;
    justify-content: center;
    padding: 18px;
    z-index: 10000;
}

.modal-comanda.ativo {
    display: flex;
}

.modal-login-admin {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, .68);
    display: none;
    align-items: center;
    justify-content: center;
    padding: 18px;
    z-index: 10001;
}

.modal-login-admin.ativo {
    display: flex;
}

.modal-login-caixa {
    width: min(420px, 100%);
    position: relative;
    background: #fff;
    color: #1b1f24;
    border-radius: 16px;
    padding: 24px;
    box-shadow: 0 24px 70px rgba(0,0,0,.36);
}

.modal-login-caixa h2 {
    margin: 6px 0;
    color: #1b1f24;
}

.modal-login-caixa p {
    color: #66727e;
    font-size: 13px;
    margin-bottom: 16px;
}

.modal-login-caixa label {
    color: #596673;
    display: block;
    font-size: 12px;
    font-weight: 800;
    margin-bottom: 6px;
}

.modal-login-caixa input {
    width: 100%;
    border: 1px solid #d6dde4;
    border-radius: 10px;
    padding: 12px;
    background: #fff;
    color: #111;
    outline: none;
}

.modal-login-caixa button:not(.fechar-modal) {
    width: 100%;
    cursor: pointer;
    border: none;
    border-radius: 10px;
    padding: 12px;
    margin-top: 12px;
    background: var(--cor-principal);
    color: #111;
    font-weight: 900;
}

.modal-login-caixa small {
    display: block;
    min-height: 18px;
    margin-top: 8px;
    color: #b83232;
    font-weight: 800;
}

.modal-comanda-caixa {
    width: min(520px, 100%);
    position: relative;
    background: #fff;
    color: #1b1f24;
    border-radius: 16px;
    padding: 22px;
    box-shadow: 0 24px 70px rgba(0,0,0,.36);
}

.comanda-topo {
    padding-right: 42px;
    margin-bottom: 16px;
}

.comanda-topo h2 {
    margin: 5px 0;
    color: #1b1f24;
}

.comanda-topo p {
    color: #66727e;
    font-size: 13px;
}

.comanda-resumo-itens {
    display: grid;
    gap: 8px;
    margin-bottom: 14px;
}

.comanda-item {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    padding: 12px;
    border: 1px solid #e1e6eb;
    border-radius: 12px;
    background: #f8fafb;
}

.comanda-item strong,
.comanda-item span {
    display: block;
}

.comanda-item span {
    color: #66727e;
    font-size: 12px;
    margin-top: 3px;
}

.comanda-item > span {
    color: #1b1f24;
    font-weight: 900;
    margin-top: 0;
    white-space: nowrap;
}

.comanda-campos {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
}

.comanda-campos label {
    color: #596673;
    font-size: 12px;
    font-weight: 800;
}

.comanda-campos label:first-child,
.comanda-campos select {
    grid-column: 1 / -1;
}

.comanda-campos input,
.comanda-campos select {
    width: 100%;
    border: 1px solid #d6dde4;
    border-radius: 10px;
    padding: 11px;
    background: #fff;
    color: #111;
    outline: none;
}

.comanda-total {
    margin: 16px 0;
    padding: 14px;
    border-radius: 14px;
    background: var(--cor-secundaria);
    color: var(--cor-texto);
    display: grid;
    gap: 4px;
}

.comanda-total span,
.comanda-total small {
    color: rgba(255,255,255,.7);
}

.comanda-total strong {
    color: var(--cor-principal);
    font-size: 28px;
}

.comanda-acoes {
    display: flex;
    gap: 10px;
}

.comanda-acoes button {
    flex: 1;
    cursor: pointer;
    border: none;
    border-radius: 10px;
    padding: 12px;
    background: var(--cor-principal);
    color: #111;
    font-weight: 900;
}

.comanda-acoes .btn-secundario-comanda {
    background: #e8edf1;
    color: #1b1f24;
}

@media (max-width: 620px) {
    .comanda-campos {
        grid-template-columns: 1fr;
    }

    .comanda-acoes {
        flex-direction: column;
    }
}
