/* Reset */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

@font-face {
    font-family: 'Kingthings Foundation';
    src: url('/font/Kingthings-Foundation/Kingthings_Foundation.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

html {
    width: 100%;
    max-width: 100%;
    overflow-x: hidden;
}

/* Quando algum modal está aberto, trava o scroll do fundo (evita 2 barras). */
html.modal-open,
body.modal-open {
    overflow: hidden !important;
    height: 100%;
}

/* Variáveis de Tema */
:root {
    --bg-primary: #f0f2f5;
    --bg-secondary: #ffffff;
    --bg-header: #7394b8; /* Cor original do header */
    --bg-input: #e0e6ed;
    --bg-hover: #f0f0f0;
    --bg-action: #f0f2f5;
    --bg-action-hover: #e4e6eb;
    --bg-comment: #f0f2f5;
    --bg-anuncio: #e9ecef;
    --bg-slider: #ccc;
    
    --text-primary: #333;
    --text-secondary: #666;
    --text-header: white;
    --text-link: #007bff;
    --text-placeholder: #666;
    --text-anuncio: #6c757d;

    --border-color: #ddd;
    --border-anuncio: #ced4da;
    --shadow-color: rgba(0, 0, 0, 0.1);

    /* Cor da borda do botão de câmera (tema claro = preto) */
    --camera-border-color: #000;
    /* Cor do ícone de câmera (tema claro = preto) */
    --camera-icon-color: #000;

    --btn-primary-bg: #5cb85c;
    --btn-primary-hover: #4cae4c;
    --btn-secondary-bg: #007bff;
    --btn-secondary-hover: #0056b3;
    --btn-filter-active-bg: #7394b8;

    /* Altura real do header (atualizada via JS) */
    --header-height: 70px;

    /* Altura da barra inferior no mobile */
    --bottom-nav-height: 56px;

    /* Cor da barra inferior (mobile) */
    --bottom-nav-bg: #eef0f3; /* tema claro: cinza um pouco mais forte */
    --bottom-nav-border: #dfe3e8;
}

html.dark-mode {
    --bg-primary: #18191a;
    --bg-secondary: #242526;
    /* --bg-header foi REMOVIDO daqui para manter o azul */
    --bg-input: #3a3b3c;
    --bg-hover: #3a3b3c;
    --bg-action: #3a3b3c;
    --bg-action-hover: #4e4f50;
    --bg-comment: #3a3b3c;
    --bg-anuncio: #242526;
    --bg-slider: #4e4f50;
    
    --text-primary: #e4e6eb;
    --text-secondary: #b0b3b8;
    --text-header: #e4e6eb;
    --text-link: #4599ff;
    --text-placeholder: #b0b3b8;
    --text-anuncio: #b0b3b8;

    --border-color: #3e4042;
    --border-anuncio: #3e4042;
    --shadow-color: rgba(0, 0, 0, 0.3);

    --btn-filter-active-bg: #4599ff;

    /* No tema escuro, borda do botão de câmera fica branca */
    --camera-border-color: #ffffff;
    /* No tema escuro, ícone de câmera fica branco */
    --camera-icon-color: #ffffff;

    /* Barra inferior no tema escuro */
    --bottom-nav-bg: #0f0f10; /* tema escuro: preto um pouco mais claro */
    --bottom-nav-border: #2a2a2a;
}
/* Fim das Variáveis */


body {
    font-family: sans-serif;
    background: var(--bg-primary); 
    color: var(--text-primary); 
    display: flex;
    flex-direction: column;
    align-items: center;
    min-height: 100vh;
    overflow-x: hidden; /* Evita rolagem lateral em qualquer página */
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

/* Cabeçalho */
header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: var(--bg-header); /* Aplicado (sempre #7394b8) */
    padding: 14px 22px;
    box-shadow: 0 4px 8px var(--shadow-color); 
    color: var(--text-header); 
    width: 100%;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 2000; /* sempre acima de overlays */
    height: auto;
    min-height: 92px;
    transition: transform 220ms ease;
    will-change: transform;
}

/* Cabeçalho some ao rolar (mobile) */
header.header-hidden {
    transform: translateY(-120%);
}

/* Quando o menu lateral (mobile) está aberto: não rola o fundo */
html.mobile-sidebar-open,
body.mobile-sidebar-open {
    overflow: hidden;
    height: 100%;
}

/* Barra inferior (mobile) */
.mobile-bottom-nav {
    display: none;
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    height: var(--bottom-nav-height);
    background: var(--bottom-nav-bg);
    border-top: 1px solid var(--bottom-nav-border);
    z-index: 1900; /* acima de overlays, abaixo do header */
    align-items: center;
    justify-content: space-between;
    padding: 6px 8px;
    box-sizing: border-box;
    gap: 6px;
}

.mobile-bottom-nav .mbn-btn {
    appearance: none;
    border: none;
    background: transparent;
    cursor: pointer;
    line-height: 1;
    padding: 10px 10px;
    border-radius: 999px;
    color: var(--text-primary);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 1 1 0;
    min-width: 44px; /* área de toque */
}

.mobile-bottom-nav .mbn-btn i {
    font-size: 18px;
    color: var(--text-primary); /* monocromático */
    opacity: 0.92;
}

.mobile-bottom-nav .mbn-btn:active {
    background: var(--bg-hover);
}
.logo-box { 
    display: flex; 
    align-items: center; 
    gap: 10px;
    cursor: pointer;           /* Mostra a “mãozinha/seta de link” ao passar o mouse */
    user-select: none;         /* Evita parecer apenas texto selecionável */
}
.logo-box img { width: 64px; height: 64px; border-radius: 50%; object-fit: cover; border: none; }
.logo-box h1 { font-family: 'Kingthings Foundation', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; font-size: 32px; margin: 0; color: #081a2e; font-weight: 900; -webkit-text-stroke: 0.3px #081a2e; } 
.header-actions {
    flex-grow: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
}
.search { flex-grow: 1; max-width: 400px; padding: 8px 15px; border: none; border-radius: 20px; background: var(--bg-input); color: var(--text-primary); margin: 0 20px; }
.search::placeholder { color: var(--text-placeholder); } 

/* Layout específico do cabeçalho em telas grandes (desktop) */
@media (min-width: 769px) {
    /* ordem: logo à esquerda, busca no centro, sino e usuário à direita */
    .logo-box {
        order: 1;
        margin-right: 20px;
    }

    .header-actions {
        order: 2;
    }

    /* Sino fica visualmente ao lado da foto (lado esquerdo dela) */
    #notificacoes-container {
        order: 3;
        position: absolute !important;
        top: 50% !important;
        right: 250px !important;     /* ajusta um pouco mais para a direita para alinhar com a foto */
        transform: translateY(-50%) !important;
        margin: 0 !important;
        margin-right: 0 !important;
        margin-left: 0 !important;
        display: flex;
        align-items: center;
    }

    .user-info {
        order: 4;
        margin-left: 10px;
    }

    /* Desktop sempre mostra a barra de busca, sem precisar da lupa */
    .search-toggle {
        display: none;
    }

    .search {
        display: block;
    }
    
    /* Remover rolagem vertical das postagens em todas as telas maiores */
    .post {
        overflow-y: visible !important;
        max-height: none !important;
        height: auto !important;
    }
    
    .post-comments {
        overflow-y: visible !important;
        max-height: none !important;
        height: auto !important;
    }
    
    .post-comments .comment-list {
        overflow-y: visible !important;
        max-height: none !important;
    }
    
    /* Garantir que postagens no perfil não tenham rolagem */
    .secao-perfil .post,
    #secao-postagens .post,
    .minhas-postagens .post {
        overflow-y: visible !important;
        max-height: none !important;
        height: auto !important;
    }
}

/* Botão de lupa (usado apenas no mobile) */
.search-toggle {
    display: none;
    background: none;
    border: none;
    color: var(--text-header);
    font-size: 20px;
    cursor: pointer;
    margin-left: 0;
}

#search-results {
  position: fixed;
  top: calc(var(--header-height, 70px) + 6px); /* sempre abaixo do cabeçalho */
  left: 50%;
  transform: translateX(-50%);
  width: min(600px, 90%);
  z-index: 999; /* abaixo do header */
}

.search-results-box {
  /* Fundo mais escuro para destacar as opções de perfil */
  background: rgba(15, 15, 20, 0.97);
  color: #ffffff;
  border-radius: 10px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.6);
  padding: 10px 15px;
  max-height: 380px;
  overflow-y: auto;
}

.search-section h4 {
  margin: 8px 0 4px;
  font-size: 0.9rem;
  color: #b0b3b8;
}

.search-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 4px;
  cursor: pointer;
  border-radius: 6px;
}

.search-item:hover {
  background: rgba(255, 255, 255, 0.06);
}

.search-avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  object-fit: cover;
}

.search-title {
  font-size: 0.95rem;
  font-weight: 600;
  color: #ffffff;
}

.search-subtitle {
  font-size: 0.8rem;
  color: #b0b3b8;
}

.search-results-empty {
  background: rgba(15, 15, 20, 0.97);
  color: #b0b3b8;
  border-radius: 10px;
  box-shadow: 0 4px 16px rgba(0,0,0,0.1);
  padding: 12px 16px;
  font-size: 0.9rem;
}

#search-results-backdrop {
  position: fixed;
  inset: var(--header-height, 70px) 0 0 0; /* não cobre o cabeçalho */
  background: rgba(0, 0, 0, 0.4);
  z-index: 900;
  display: none;
}

#search-results-backdrop.visible {
  display: block;
}
.user-info { display: flex; align-items: center; gap: 15px; }
.user-avatar-header { 
    width: 62px; 
    height: 62px; 
    border-radius: 50%; 
    object-fit: cover; 
    object-position: center center;
    border: 2px solid white;
    image-rendering: auto;
}
.user-info span { font-weight: bold; color: var(--text-header); } 
#logout-button { background-color: var(--btn-primary-bg); color: white; border: none; padding: 10px 16px; border-radius: 7px; cursor: pointer; font-size: 15px; transition: background-color 0.2s; }
#logout-button:hover { background-color: var(--btn-primary-hover); } 

/* Mobile: esconde o botão "Sair" do cabeçalho em todas as páginas */
@media (max-width: 768px) {
    header #logout-button {
        display: none !important;
    }
}
#feed-button, #profile-button { background-color: var(--btn-primary-bg); color: white; border: none; padding: 8px 12px; border-radius: 5px; cursor: pointer; font-size: 16px; transition: background-color 0.2s; line-height: 1; }
#feed-button:hover, #profile-button:hover { background-color: var(--btn-primary-hover); } 

/* Botão flutuante lateral (mobile) para filtros / ações rápidas / times */
.mobile-sidebar-toggle {
    position: static;
    margin: 0 0 10px 0;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    border: none;
    background: linear-gradient(135deg, #007bff, #00a4ff);
    color: #ffffff;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
    display: none;
    align-items: center;
    justify-content: center;
    font-size: 22px;
    cursor: pointer;
    z-index: 1;
}

/* Backdrop para o painel lateral no mobile */
#mobile-sidebar-backdrop {
    position: fixed;
    inset: 70px 0 0 0;
    background: rgba(0, 0, 0, 0.45);
    z-index: 880;
    display: none;
}

#mobile-sidebar-backdrop.visible {
    display: block;
}

/* Botão de fechar (X) do painel lateral no mobile */
.mobile-sidebar-close {
    display: none;
    position: absolute;
    top: 10px;
    right: 10px;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    border: none;
    background: rgba(0, 0, 0, 0.2);
    color: var(--text-primary);
    cursor: pointer;
    font-size: 18px;
    line-height: 1;
}

/* Layout, Categorias, Filtros, Configurações... */
.conteudo { display: flex; justify-content: center; gap: 25px; padding: 25px 20px; max-width: 1400px; margin: 90px auto 0 auto; width: 100%; box-sizing: border-box; overflow-x: hidden; }
@media (max-width: 768px) {
    .conteudo {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }
}
.categorias { flex-basis: 250px; flex-shrink: 1; min-width: 220px; background: var(--bg-secondary); border-radius: 8px; padding: 20px; box-shadow: 0 2px 5px var(--shadow-color); height: fit-content; position: sticky; top: 115px; box-sizing: border-box; max-width: 100%; overflow-x: hidden; }
.categorias h2 { font-size: 1.5em; color: var(--text-primary); margin-bottom: 10px; text-align: center; word-wrap: break-word; } 
.categorias p { font-size: 14px; color: var(--text-secondary); margin-bottom: 15px; text-align: center; word-wrap: break-word; } 
.filtro-botoes { display: flex; flex-direction: column; gap: 10px; margin-bottom: 20px; width: 100%; box-sizing: border-box; }
.filtro-btn { width: 100%; padding: 10px; font-size: 14px; font-weight: bold; border: 1px solid var(--border-color); border-radius: 5px; background-color: var(--bg-secondary); color: var(--text-secondary); cursor: pointer; transition: all 0.2s ease; text-align: left; box-sizing: border-box; word-wrap: break-word; white-space: normal; }
.filtro-btn i { margin-right: 10px; width: 20px; text-align: center; }
.filtro-btn:hover { background-color: var(--bg-hover); border-color: var(--border-color); } 
.filtro-btn.ativo { background-color: var(--btn-filter-active-bg); color: white; border-color: var(--btn-filter-active-bg); }
.filtro-localizacao { border-top: 1px solid var(--border-color); padding-top: 15px; width: 100%; box-sizing: border-box; overflow-x: hidden; } 
.filtro-localizacao h4 { font-size: 16px; color: var(--text-primary); margin-bottom: 10px; word-wrap: break-word; } 
#filtro-cidade { width: 100%; padding: 8px; border: 1px solid var(--border-color); background-color: var(--bg-input); color: var(--text-primary); border-radius: 5px; margin-bottom: 10px; box-sizing: border-box; }
#filtro-cidade-btn { width: 100%; padding: 8px; background: transparent; color: #000000; border: 1px solid #000000; border-radius: 5px; cursor: pointer; transition: opacity 0.2s, border-color 0.2s, color 0.2s; box-sizing: border-box; } 
#filtro-cidade-btn:hover { opacity: 0.85; } 
html.dark-mode #filtro-cidade-btn { color: #ffffff; border-color: #ffffff; }
.filtro-configuracoes { border-top: 1px solid var(--border-color); padding-top: 15px; margin-top: 20px; padding-bottom: 30px; width: 100%; box-sizing: border-box; overflow-x: hidden; } 
.filtro-configuracoes h4 { font-size: 16px; color: var(--text-primary); margin-bottom: 10px; } 

/* ---------------------------------------------------------------------- */
/* Filtros no feed (compacto, entre "Crie uma Publicação" e o feed)         */
/* ---------------------------------------------------------------------- */
.feed-filtros {
    margin: 0 0 6px;
    padding: 0;
    border: none;
    border-radius: 0;
    background: transparent;
    box-sizing: border-box;
}

.feed-filtros-row {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 6px;
    flex-wrap: nowrap;
    padding-left: 2px; /* evita cortar a borda do select quando fica muito colado na esquerda */
}

.feed-filtros-left {
    display: flex;
    align-items: center;
    gap: 8px;
    flex: 0 1 auto;
    min-width: 0;
}

/* Select único: "Filtrar: Todos" */
.feed-filtro-tipo {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 7px 12px;
    border: 1px solid var(--border-color);
    border-radius: 999px;
    background: var(--bg-primary);
    box-sizing: border-box;
    box-shadow: none;
    transition: border-color 0.12s ease;
}

.feed-filtro-tipo:hover {
    border-color: color-mix(in srgb, var(--border-color) 65%, var(--btn-primary-bg) 35%);
}

.feed-filtro-tipo:focus-within {
    border-color: color-mix(in srgb, var(--btn-primary-bg) 70%, var(--border-color) 30%);
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--btn-primary-bg) 22%, transparent);
}

.feed-filtro-tipo select {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    border: none;
    outline: none;
    background: transparent;
    color: var(--text-primary);
    font-size: 12.5px;
    font-weight: 700;
    padding-right: 18px; /* espaço para o ícone */
    cursor: pointer;
    width: auto; /* JS vai ajustar com base no texto selecionado */
}

.feed-filtro-tipo select:focus {
    outline: none;
}

/* Ajuste visual dos itens do dropdown (limitado pelo navegador, mas ajuda) */
.feed-filtro-tipo select option {
    background: var(--bg-secondary);
    color: var(--text-primary);
}

.feed-filtro-tipo i {
    position: absolute;
    right: 8px;
    color: var(--text-secondary);
    font-size: 12px;
    pointer-events: none;
}

.feed-filtros-right {
    flex: 0 0 auto;
    min-width: 0;
    max-width: 240px;
    width: 240px;
}

.feed-filtro-cidade {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 7px 12px;
    border: 1px solid var(--border-color);
    border-radius: 999px;
    background: var(--bg-primary);
    box-sizing: border-box;
    transition: box-shadow 0.12s ease, border-color 0.12s ease;
    width: 100%;
}

.feed-filtro-cidade:focus-within {
    border-color: color-mix(in srgb, var(--btn-primary-bg) 70%, var(--border-color) 30%);
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--btn-primary-bg) 18%, transparent);
}

.feed-filtro-cidade i {
    color: var(--text-secondary);
    width: 18px;
    text-align: center;
    flex: 0 0 auto;
}

.feed-filtros #filtro-cidade {
    width: auto;
    margin: 0;
    padding: 0;
    border: none;
    outline: none;
    background: transparent;
    flex: 1 1 auto;
    min-width: 80px;
    font-size: 13px;
}

/* Remove a “seta”/indicador nativo do datalist em alguns navegadores (Chromium/Edge) */
#filtro-cidade[list]::-webkit-calendar-picker-indicator { display: none !important; }
#filtro-cidade[list]::-webkit-list-button { display: none !important; }

.feed-filtros #filtro-cidade-btn {
    width: auto;
    padding: 7px 14px;
    border-radius: 999px;
    font-size: 12px;
    flex: 0 0 auto;
    white-space: nowrap;
    min-width: fit-content;
}

@media (max-width: 767px) {
    .feed-filtros {
        padding: 4px 4px;
        border-radius: 10px;
    }

    .feed-filtros-row {
        flex-wrap: nowrap; /* mantém filtro + cidade lado a lado */
        gap: 4px;
        padding-left: 2px;
    }

    .feed-filtros-left {
        flex: 0 0 auto;
        min-width: 0;
    }

    .feed-filtros-right {
        flex: 0 1 auto;
        min-width: 0;
        max-width: 160px; /* mantém limite em telas médias/estreitas */
        width: auto;
    }

    .feed-filtro-cidade {
        width: 100%;
        gap: 5px;
        padding: 6px 10px;
    }

    .feed-filtros #filtro-cidade {
        font-size: 11px;
        min-width: 50px;
        padding: 0;
    }

    .feed-filtros #filtro-cidade-btn {
        padding: 6px 12px;
        font-size: 10px;
        white-space: nowrap;
    }

    .feed-filtro-tipo {
        padding: 6px 10px;
    }
    .feed-filtro-tipo select {
        width: auto; /* não força 100% no mobile, pra caber ao lado da cidade */
        font-size: 11px;
        padding: 4px 18px 4px 6px;
    }
    .feed-filtro-tipo i {
        right: 6px;
        font-size: 10px;
    }
    
    .feed-filtro-cidade i {
        width: 14px;
        font-size: 11px;
    }
}

/* Em telas menores (≤480px), a caixa de cidade vai até a borda direita */
@media (max-width: 480px) {
    .feed-filtros {
        padding: 4px 0;
    }

    .feed-filtros-row {
        padding-right: 0;
        justify-content: space-between; /* empurra a caixa de cidade para a direita */
    }

    .feed-filtros-right {
        flex: 1 1 auto;
        max-width: none; /* remove limite para chegar até a borda direita */
        display: flex;
        justify-content: flex-end; /* alinha o conteúdo interno à direita */
    }
}

/* Em telas EXTREMAMENTE estreitas (só abaixo de 280px), volta a empilhar */
@media (max-width: 280px) {
    .feed-filtros-row {
        flex-wrap: wrap;
    }
    .feed-filtros-right {
        flex: 1 1 100%;
        width: auto;
        max-width: none;
    }
}
.filtro-config-btn { display: block; padding: 8px 10px; font-size: 14px; color: var(--text-secondary); text-decoration: none; border-radius: 5px; transition: background-color 0.2s; }
.filtro-config-btn i { margin-right: 10px; width: 20px; text-align: center; color: var(--text-secondary); } 
.filtro-config-btn:hover { background-color: var(--bg-hover); } 
.filtro-config-item { display: flex; justify-content: space-between; align-items: center; padding: 8px 10px; font-size: 14px; color: var(--text-secondary); } 
.filtro-config-item i { margin-right: 10px; width: 20px; text-align: center; color: var(--text-secondary); } 

/* Toggle genérico usado nas configurações (Preferências, Notificações, Personalização) */
.switch {
    position: relative;
    display: inline-block;
    width: 44px;
    height: 24px;
    flex-shrink: 0; /* impede o botão de “amassar” quando o texto é longo */
}

.switch input {
    opacity: 0;
    width: 0;
    height: 0;
}

.switch .slider {
    position: absolute;
    cursor: pointer;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: var(--bg-slider);
    transition: .4s;
}

.switch .slider:before {
    position: absolute;
    content: "";
    height: 18px;
    width: 18px;
    left: 3px;
    bottom: 3px;
    background-color: white;
    transition: .4s;
}

.switch input:checked + .slider {
    background-color: var(--btn-filter-active-bg);
}

.switch input:checked + .slider:before {
    transform: translateX(20px);
}

.switch .slider.round {
    border-radius: 24px;
}

.switch .slider.round:before {
    border-radius: 50%;
}

/* Área Central do Feed */
main { flex-grow: 1; max-width: 850px; min-width: 550px; box-sizing: border-box; flex: 1 1 auto; overflow-x: hidden; }
@media (max-width: 768px) {
    main {
        min-width: 0 !important;
        max-width: 100% !important;
        width: 100% !important;
        padding: 0 !important;
        margin: 0 !important;
    }
}

/* Área de Publicação */
.publicar { background: var(--bg-secondary); border-radius: 8px; padding: 20px; margin-bottom: 8px; box-shadow: 0 2px 5px var(--shadow-color); max-width: 100%; box-sizing: border-box; overflow-x: hidden; } 
.publicar h2 { font-size: 1.3em; color: var(--text-primary); margin-bottom: 15px; } 

textarea#post-content-input {
    width: 100%;
    max-width: 100%;
    padding: 10px;
    margin-bottom: 15px;
    border: 1px solid var(--border-color); 
    background-color: var(--bg-input); 
    color: var(--text-primary); 
    border-radius: 5px;
    font-size: 1em;
    resize: none; 
    overflow-y: hidden; 
    overflow-x: hidden;
    height: auto; 
    min-height: 80px; 
    box-sizing: border-box;
}
textarea#post-content-input::placeholder { color: var(--text-placeholder); } 

.botoes-postar { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 10px; }
.upload-area { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.upload-button {
    background: transparent;
    color: var(--camera-icon-color);
    padding: 0;
    border-radius: 50%;
    cursor: pointer;
    font-size: 18px;
    transition: opacity 0.2s, color 0.2s;
    flex-shrink: 0;
    width: 38px;
    height: 38px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: none;
}
.upload-button i { margin: 0; }
.upload-button:hover { background: transparent; opacity: 0.75; }
#post-media-input { display: none !important; }

/* Removido: nome de arquivo e previews antigos de imagem/vídeo na criação de post */

.btn-enviar {
    background: transparent;
    color: var(--btn-secondary-bg);
    padding: 10px 20px;
    border: 1px solid var(--btn-secondary-bg);
    border-radius: 5px;
    cursor: pointer;
    font-size: 1em;
    transition: opacity 0.2s, border-color 0.2s, color 0.2s;
}
.btn-enviar:hover {
    background: transparent;
    color: var(--btn-secondary-hover);
    border-color: var(--btn-secondary-hover);
    opacity: 0.95;
}

/* Feed: botão "Publicar" como ícone (sem fundo) */
.publicar .btn-enviar {
    background: transparent !important;
    border: none !important;
    padding: 0 !important;
    width: 44px !important;
    height: 44px !important;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: opacity 0.2s;
}
.publicar .btn-enviar:hover { opacity: 0.75; }
.publicar .btn-enviar .publish-icon {
    width: 30px;
    height: 30px;
    display: block;
    object-fit: contain;
    pointer-events: none;
    user-select: none;
}
.form-message { padding: 10px; border-radius: 5px; margin-top: 15px; font-size: 0.9em; text-align: center; }
.form-message.success { background-color: #d4edda; color: #155724; border: 1px solid #c3e6cb; }
.form-message.error { background-color: #f8d7da; color: #721c24; border: 1px solid #f5c6cb; }
.form-message.info { background-color: #d1ecf1; color: #0c5460; border: 1px solid #bee5eb; }
#posts-container { padding-top: 5px; }
.post { background: var(--bg-secondary); border-radius: 8px; padding: 15px; margin-bottom: 20px; box-shadow: 0 2px 5px var(--shadow-color); word-wrap: break-word; position: relative; transition: opacity 0.3s ease, transform 0.3s ease, height 0.3s ease; max-width: 100%; box-sizing: border-box; overflow: visible !important; overflow-x: hidden !important; overflow-y: visible !important; max-height: none !important; } 
.post.hidden { opacity: 0; transform: scale(0.95); height: 0; padding: 0; margin: 0; overflow: hidden; border: none; }

/* Garantir que postagens antigas não apareçam no grid de miniaturas */
.postagens-grid .post {
    display: none !important;
}

/* Garantir que apenas thumbnails apareçam no grid */
.postagens-grid > .post-thumbnail {
    display: block !important;
}

/* Grid de miniaturas de postagens no perfil - padrão celular */
.postagens-grid {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 6px !important;
    padding: 10px 0 !important;
    max-width: 100% !important;
}

/* Entre celular e tablet - transição gradual */
@media (min-width: 481px) and (max-width: 767px) {
    .postagens-grid {
        grid-template-columns: repeat(4, 1fr) !important;
        gap: 8px !important;
    }
}

/* Tablets - tamanho próximo de celulares, 4 lado a lado */
@media (min-width: 768px) and (max-width: 1023px) {
    .postagens-grid {
        grid-template-columns: repeat(4, 1fr) !important;
        gap: 8px !important;
    }
    
    .post-thumbnail {
        min-width: 0 !important;
    }
    
    /* Remover rolagem vertical das postagens em tablets */
    .post {
        overflow-y: visible !important;
        max-height: none !important;
        height: auto !important;
    }
    
    .post-comments {
        overflow-y: visible !important;
        max-height: none !important;
        height: auto !important;
    }
    
    .post-comments .comment-list {
        overflow-y: visible !important;
        max-height: none !important;
    }
}

/* Desktop pequeno - transição gradual até tablets */
@media (min-width: 1024px) and (max-width: 1439px) {
    .postagens-grid {
        grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)) !important;
        gap: 12px !important;
    }
    
    /* Remover rolagem vertical das postagens em telas maiores */
    .post {
        overflow-y: visible !important;
        max-height: none !important;
        height: auto !important;
    }
    
    .post-comments {
        overflow-y: visible !important;
        max-height: none !important;
        height: auto !important;
    }
    
    .post-comments .comment-list {
        overflow-y: visible !important;
        max-height: none !important;
    }
}

/* Desktop grande */
@media (min-width: 1440px) {
    .postagens-grid {
        grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)) !important;
        gap: 12px !important;
    }
    
    /* Remover rolagem vertical das postagens em telas grandes */
    .post {
        overflow-y: visible !important;
        max-height: none !important;
        height: auto !important;
    }
    
    .post-comments {
        overflow-y: visible !important;
        max-height: none !important;
        height: auto !important;
    }
    
    .post-comments .comment-list {
        overflow-y: visible !important;
        max-height: none !important;
    }
    
    /* Garantir que postagens no perfil não tenham rolagem */
    .secao-perfil .post,
    #secao-postagens .post,
    .minhas-postagens .post {
        overflow-y: visible !important;
        max-height: none !important;
        height: auto !important;
    }
}

/* Em telas menores - celulares 3 lado a lado */
@media (max-width: 480px) {
    .postagens-grid {
        grid-template-columns: repeat(3, 1fr) !important;
        gap: 6px !important;
    }
    
    .post-thumbnail {
        min-width: 0 !important;
    }
}

.post-thumbnail {
    position: relative;
    width: 100% !important;
    aspect-ratio: 1 !important;
    border-radius: 4px;
    overflow: hidden;
    cursor: pointer;
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    max-width: 100% !important;
    min-width: 0 !important;
}

/* Garantir que as imagens dentro das miniaturas não ultrapassem */
.post-thumbnail .thumbnail-image,
.post-thumbnail .thumbnail-video {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    display: block !important;
}

.post-thumbnail:hover {
    transform: scale(1.05);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

.post-thumbnail .thumbnail-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.post-thumbnail .thumbnail-video-wrapper {
    width: 100%;
    height: 100%;
    position: relative;
    background: #000;
}

.post-thumbnail .thumbnail-video {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.post-thumbnail .thumbnail-play-icon {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: 28px;
    color: rgba(255, 255, 255, 0.9);
    z-index: 2;
}

.post-thumbnail .thumbnail-text-icon {
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 15px;
    color: var(--text-secondary);
}

.post-thumbnail .thumbnail-text-icon i {
    font-size: 24px;
    margin-bottom: 6px;
}

.post-thumbnail .thumbnail-text-preview {
    font-size: 10px;
    text-align: center;
    color: var(--text-secondary);
    margin: 0;
    line-height: 1.2;
}

/* Reduz tamanho dos ícones em telas maiores */
@media (min-width: 768px) {
    .post-thumbnail .thumbnail-text-icon i {
        font-size: 20px;
        margin-bottom: 4px;
    }
    
    .post-thumbnail .thumbnail-text-preview {
        font-size: 9px;
    }
    
    .post-thumbnail .thumbnail-play-icon {
        font-size: 24px;
    }
}

@media (min-width: 1024px) {
    .post-thumbnail .thumbnail-text-icon i {
        font-size: 18px;
        margin-bottom: 3px;
    }
    
    .post-thumbnail .thumbnail-text-preview {
        font-size: 8px;
    }
    
    .post-thumbnail .thumbnail-play-icon {
        font-size: 20px;
    }
    
    .post-thumbnail .thumbnail-info {
        font-size: 10px;
        gap: 8px;
    }
    
    .post-thumbnail .thumbnail-info i {
        font-size: 12px;
    }
}

.post-thumbnail .thumbnail-overlay {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    background: linear-gradient(to top, rgba(0, 0, 0, 0.7), transparent);
    padding: 8px;
    opacity: 0;
    transition: opacity 0.2s ease;
}

.post-thumbnail:hover .thumbnail-overlay {
    opacity: 1;
}

.post-thumbnail .thumbnail-info {
    display: flex;
    gap: 12px;
    align-items: center;
    color: white;
    font-size: 12px;
}

.post-thumbnail .thumbnail-info i {
    font-size: 14px;
}

.post-thumbnail .thumbnail-info i.liked {
    color: #007bff;
}

/* Limite de tamanho para imagem no modal */
#modal-postagem-completa .post-image {
    max-width: 100%;
    max-height: 600px;
    width: auto;
    height: auto;
    object-fit: contain;
    margin-left: auto;
    margin-right: auto;
    display: block;
    margin-top: 15px;
    margin-bottom: 15px;
}

/* Modal de Imagem Flutuante para Pedidos */
.image-modal-overlay {
    display: none !important;
    position: fixed !important;
    z-index: 99999 !important;
    left: 0 !important;
    top: 0 !important;
    width: 100% !important;
    height: 100% !important;
    background-color: rgba(0, 0, 0, 0.9) !important;
    justify-content: center !important;
    align-items: center !important;
    opacity: 0 !important;
    visibility: hidden !important;
    transition: opacity 0.3s ease;
}

.image-modal-overlay.hidden {
    display: none !important;
}

/* Modal só aparece quando NÃO tem classe hidden E tem display flex no style inline */
.image-modal-overlay:not(.hidden)[style*="display: flex"],
#image-modal-pedido:not(.hidden)[style*="display: flex"] {
    display: flex !important;
    opacity: 1 !important;
    visibility: visible !important;
    z-index: 99999 !important;
}

/* Garantir que mesmo com classe hidden removida via JS, o modal apareça apenas se tiver display flex no style */
#image-modal-pedido[style*="display: flex"] {
    display: flex !important;
}

.image-modal-content {
    max-width: 90vw;
    max-height: 90vh;
    border-radius: 5px;
    background-color: var(--bg-secondary);
    object-fit: contain;
    position: relative;
}

#image-modal-pedido {
    position: relative;
    display: none !important; /* Começar oculto por padrão */
    align-items: center;
    justify-content: center;
}

#image-modal-pedido.hidden {
    display: none !important;
}

#image-modal-pedido > div {
    position: relative;
    display: inline-block;
    max-width: 90vw;
    max-height: 90vh;
}

#image-modal-pedido .image-modal-content {
    position: relative;
    display: block;
    max-width: 100%;
    max-height: 100%;
}

#close-image-modal-pedido {
    position: absolute;
    top: 5px;
    right: 5px;
    color: #fff;
    font-size: 35px;
    font-weight: bold;
    cursor: pointer;
    z-index: 10002;
    background: rgba(0, 0, 0, 0.7);
    width: 45px;
    height: 45px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.3s;
    margin: 0;
    padding: 0;
    line-height: 1;
}

#close-image-modal-pedido:hover {
    background: rgba(0, 0, 0, 0.9);
}

/* Ajustar posição do X em telas menores */
@media (max-width: 768px) {
    #close-image-modal-pedido {
        top: 3px;
        right: 3px;
        width: 40px;
        height: 40px;
        font-size: 30px;
    }
}

#close-image-modal-pedido:hover {
    background: rgba(0, 0, 0, 0.9);
}

.close-btn-modal {
    position: absolute;
    top: 5px;
    right: 5px;
    color: #fff;
    font-size: 35px;
    font-weight: bold;
    cursor: pointer;
    z-index: 10002;
    background: rgba(0, 0, 0, 0.7);
    width: 45px;
    height: 45px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.3s;
}

.close-btn-modal:hover {
    background: rgba(0, 0, 0, 0.9);
}

/* Aumentar espaço da área da postagem */
#modal-postagem-completa .post-header {
    padding-top: 15px;
    padding-bottom: 10px;
}

#modal-postagem-completa .post-content {
    padding-top: 10px;
    padding-bottom: 15px;
}

#modal-postagem-completa .post-actions {
    padding-top: 15px;
    padding-bottom: 15px;
}

/* Aumentar espaço da área da postagem */
#modal-postagem-completa .post-header {
    padding-top: 15px;
    padding-bottom: 10px;
}

#modal-postagem-completa .post-content {
    padding-top: 10px;
    padding-bottom: 15px;
}

#modal-postagem-completa .post-actions {
    padding-top: 15px;
    padding-bottom: 15px;
}

/* Comentários sem scroll individual - fazem parte do scroll da postagem */
#modal-postagem-completa .post-comments {
    display: flex;
    flex-direction: column;
    overflow: visible;
    overflow-x: hidden;
    max-width: 100%;
    box-sizing: border-box;
}

/* Ajustes para formulário de comentários no modal - fixo na parte inferior */
#modal-postagem-completa .comment-form {
    display: flex;
    gap: 5px;
    margin-top: auto;
    padding: 10px;
    padding-bottom: 10px;
    flex-wrap: nowrap;
    align-items: center;
    position: sticky;
    bottom: 0;
    background-color: var(--bg-secondary);
    border-top: 1px solid var(--border-color);
    z-index: 10;
    flex-shrink: 0;
    width: 100%;
    box-sizing: border-box;
}

#modal-postagem-completa .comment-input {
    flex: 1;
    min-width: 0;
    border: 1px solid var(--border-color);
    background-color: var(--bg-input);
    color: var(--text-primary);
    border-radius: 20px;
    padding: 8px 12px;
    font-size: 14px;
}

#modal-postagem-completa .btn-send-comment {
    flex-shrink: 0;
    border: none;
    background: transparent;
    color: var(--text-primary);
    border-radius: 50%;
    padding: 0;
    cursor: pointer;
    font-size: 18px;
    line-height: 1;
    white-space: nowrap;
    transition: opacity 0.2s;
    width: 38px;
    height: 38px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

#modal-postagem-completa .btn-send-comment:hover {
    background: transparent;
    opacity: 0.75;
}

/* Ajustes específicos para tablets e celulares */
@media (max-width: 1023px) {
    #modal-postagem-completa .modal-content {
        max-height: none !important;
        max-width: 75vw !important;
        width: 75vw !important;
        padding: 12px;
        padding-bottom: 12px;
        overflow: visible !important;
        overflow-y: visible !important;
        display: flex;
        flex-direction: column;
        height: auto !important;
        margin: 0 auto;
        border-radius: 12px;
    }
    
    /* Toda a postagem sem scroll - expande completamente */
    #modal-postagem-completa .post {
        display: flex;
        flex-direction: column;
        max-height: none !important;
        overflow-y: visible !important;
        overflow-x: hidden;
        min-height: 0;
        padding-bottom: 0;
        height: auto !important;
        overflow: visible !important;
    }
    
    /* Área da postagem - sem scroll individual, faz parte do scroll geral */
    #modal-postagem-completa .post-header,
    #modal-postagem-completa .post-content,
    #modal-postagem-completa .post-actions {
        flex-shrink: 0;
        overflow: visible;
    }
    
    /* Comentários com scroll, formulário fixo */
    #modal-postagem-completa .post-comments {
        padding-bottom: 0;
        display: flex;
        flex-direction: column;
        flex-shrink: 0;
        overflow: hidden !important;
        overflow-x: hidden !important;
        max-width: 100% !important;
        width: 100% !important;
        box-sizing: border-box !important;
        max-height: calc(100vh - 300px) !important;
        position: relative;
    }
    
    #modal-postagem-completa .comment-list {
        overflow-y: auto !important;
        overflow-x: hidden !important;
        padding-bottom: 10px;
        max-height: calc(100vh - 380px) !important;
        max-width: 100% !important;
        flex: 1;
        min-height: 0;
        box-sizing: border-box !important;
        padding-right: 5px;
    }
    
    #modal-postagem-completa .comment {
        max-width: 100%;
        width: 100%;
        overflow-x: hidden;
        box-sizing: border-box;
    }
    
    #modal-postagem-completa .comment-body-container {
        max-width: 100%;
        width: 100%;
        overflow-x: hidden;
        box-sizing: border-box;
    }
    
    #modal-postagem-completa .comment-body {
        max-width: 100%;
        width: 100%;
        overflow-x: hidden;
        box-sizing: border-box;
    }
    
    #modal-postagem-completa .comment-body p {
        overflow-x: hidden;
    }
    
    #modal-postagem-completa .comment-actions {
        max-width: 100%;
        width: 100%;
        overflow-x: hidden;
        box-sizing: border-box;
    }
    
    /* Formulário sempre visível no final - fixo */
    #modal-postagem-completa .comment-form {
        flex-shrink: 0 !important;
        background-color: var(--bg-secondary) !important;
        border-top: 1px solid var(--border-color) !important;
        margin-top: auto !important;
        margin-bottom: 0 !important;
        position: sticky !important;
        bottom: 0 !important;
        z-index: 20 !important;
        padding: 10px !important;
        padding-bottom: 10px !important;
        width: 100% !important;
        box-sizing: border-box !important;
        display: flex !important;
    }
}

/* Ajustes específicos para celular */
@media (max-width: 767px) {
    #modal-postagem-completa .modal-content {
        padding: 12px;
        padding-bottom: 12px;
        max-height: none !important;
        max-width: 75vw !important;
        width: 75vw !important;
        overflow: visible !important;
        overflow-y: visible !important;
        height: auto !important;
        margin: 0 auto;
        border-radius: 12px;
        box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
    }
    
    /* Toda a postagem com scroll em celular - adapta sem cortar */
    #modal-postagem-completa .post {
        overflow-y: visible !important;
        overflow-x: hidden;
        max-height: none !important;
        padding-bottom: 0;
        height: auto !important;
    }
    
    /* Comentários com scroll, formulário fixo */
    #modal-postagem-completa .post-comments {
        padding-bottom: 0;
        display: flex !important;
        flex-direction: column !important;
        margin-top: 10px;
        overflow: hidden !important;
        overflow-x: hidden;
        max-width: 100%;
        max-height: calc(100vh - 300px) !important;
        box-sizing: border-box;
        position: relative;
    }
    
    #modal-postagem-completa .comment-list {
        overflow-y: auto !important;
        overflow-x: hidden !important;
        padding-bottom: 10px;
        max-height: calc(100vh - 380px) !important;
        max-width: 100% !important;
        flex: 1;
        min-height: 0;
        box-sizing: border-box !important;
        padding-right: 5px;
    }
    
    #modal-postagem-completa .comment {
        max-width: 100%;
        width: 100%;
        overflow-x: hidden;
        box-sizing: border-box;
    }
    
    #modal-postagem-completa .comment-body-container {
        max-width: 100%;
        width: 100%;
        overflow-x: hidden;
        box-sizing: border-box;
    }
    
    #modal-postagem-completa .comment-body {
        max-width: 100%;
        width: 100%;
        overflow-x: hidden;
        box-sizing: border-box;
    }
    
    #modal-postagem-completa .comment-body p {
        overflow-x: hidden;
    }
    
    #modal-postagem-completa .comment-actions {
        max-width: 100%;
        width: 100%;
        overflow-x: hidden;
        box-sizing: border-box;
    }
    
    /* Formulário sempre visível no final - fixo */
    #modal-postagem-completa .comment-form {
        position: sticky !important;
        bottom: 0 !important;
        z-index: 10;
        background-color: var(--bg-secondary);
        border-top: 1px solid var(--border-color);
        padding: 10px;
        padding-bottom: 10px;
        margin-top: auto;
        margin-bottom: 0;
        flex-shrink: 0;
        width: 100%;
        box-sizing: border-box;
    }
    
    /* Garantir que a imagem não seja cortada */
    #modal-postagem-completa .post-image {
        max-height: none !important;
        margin-top: 15px;
        margin-bottom: 15px;
        height: auto !important;
    }
    
    /* Aumentar espaçamento em celular */
    #modal-postagem-completa .post-header {
        padding-top: 10px;
        padding-bottom: 10px;
    }
    
    #modal-postagem-completa .post-content {
        padding-top: 10px;
        padding-bottom: 15px;
    }
    
    #modal-postagem-completa .post-actions {
        padding-top: 15px;
        padding-bottom: 15px;
    }
    
    #modal-postagem-completa .comment-form {
        padding: 10px;
        padding-bottom: 10px;
        gap: 4px;
        margin-top: auto;
        margin-bottom: 0;
        flex-shrink: 0;
        position: sticky !important;
        bottom: 0 !important;
        background-color: var(--bg-secondary);
        border-top: 1px solid var(--border-color);
        z-index: 10;
        width: 100%;
        box-sizing: border-box;
    }
    
    /* Garantir estrutura flex para fixar formulário */
    #modal-postagem-completa .post-comments {
        display: flex;
        flex-direction: column;
        overflow: hidden;
        max-height: calc(100vh - 300px) !important;
        position: relative;
    }
    
    #modal-postagem-completa .comment-list {
        overflow-y: auto !important;
        max-height: calc(100vh - 380px) !important;
    }
    
    #modal-postagem-completa .comment-form {
        z-index: 20 !important;
        background-color: var(--bg-secondary) !important;
    }
    
    /* Estilo específico para o botão "Carregar Mais" no modal */
    #modal-postagem-completa .load-more-comments-text {
        cursor: pointer !important;
        user-select: none !important;
        -webkit-user-select: none !important;
        pointer-events: auto !important;
        z-index: 15 !important;
        position: relative;
        transition: opacity 0.2s ease, color 0.2s ease;
        padding: 4px 0 !important;
        margin-top: -12px !important;
        margin-bottom: -3px !important;
        background: transparent !important;
        border: none !important;
    }
    
    #modal-postagem-completa .load-more-comments-text:hover {
        opacity: 0.8;
        text-decoration: underline;
        color: var(--text-link) !important;
    }
    
    #modal-postagem-completa .load-more-comments-text:active {
        opacity: 0.6;
    }
    
    #modal-postagem-completa .comment-list {
        overflow-y: visible !important;
        overflow-x: hidden !important;
        flex: 1;
        min-height: 0;
        max-height: none !important;
    }
    
    #modal-postagem-completa .comment-input {
        padding: 8px 10px;
        font-size: 13px;
        flex: 1;
        min-width: 0;
    }
    
    #modal-postagem-completa .btn-send-comment {
        padding: 8px 14px;
        font-size: 13px;
        flex-shrink: 0;
        white-space: nowrap;
    }
    
    /* Garantir que o modal não corte o botão */
    #modal-postagem-completa .modal-content {
        padding-bottom: 20px;
        max-height: none !important;
        overflow: visible !important;
        overflow-y: visible !important;
        display: flex;
        flex-direction: column;
        height: auto !important;
    }
    
    /* Postagem com estrutura flex para fixar formulário */
    #modal-postagem-completa .post {
        display: flex;
        flex-direction: column;
        max-height: none !important;
        overflow-y: visible !important;
        overflow-x: hidden;
        height: auto !important;
    }
    
    /* Seção de comentários com flex para fixar formulário */
    #modal-postagem-completa .post-comments {
        display: flex;
        flex-direction: column;
        flex: 1;
        overflow: hidden;
        overflow-x: hidden;
        max-height: calc(100vh - 300px) !important;
        margin-top: 10px;
        position: relative;
    }
    
    /* Lista de comentários com scroll */
    #modal-postagem-completa .comment-list {
        overflow-y: auto !important;
        overflow-x: hidden !important;
        max-height: calc(100vh - 380px) !important;
        max-width: 100% !important;
        flex: 1;
        min-height: 0;
        padding-bottom: 10px;
        padding-right: 5px;
        box-sizing: border-box !important;
    }
    
    /* Formulário fixo */
    #modal-postagem-completa .comment-form {
        position: sticky !important;
        bottom: 0 !important;
        margin-top: auto !important;
        flex-shrink: 0 !important;
        z-index: 20 !important;
        background-color: var(--bg-secondary) !important;
        border-top: 1px solid var(--border-color) !important;
    }
    
    #modal-postagem-completa .comment {
        max-width: 100%;
        width: 100%;
        overflow-x: hidden;
        box-sizing: border-box;
    }
    
    #modal-postagem-completa .comment-body-container {
        max-width: 100%;
        width: 100%;
        overflow-x: hidden;
        box-sizing: border-box;
    }
    
    #modal-postagem-completa .comment-body {
        max-width: 100%;
        width: 100%;
        overflow-x: hidden;
        box-sizing: border-box;
    }
    
    #modal-postagem-completa .comment-body p {
        overflow-x: hidden;
    }
    
    #modal-postagem-completa .comment-actions {
        max-width: 100%;
        width: 100%;
        overflow-x: hidden;
        box-sizing: border-box;
    }
}

/* Estilos para telas maiores (desktop) - apenas comentários com scroll */
@media (min-width: 1024px) {
    #modal-postagem-completa .modal-content {
        max-height: none !important;
        max-width: 500px !important;
        width: 500px !important;
        padding: 20px;
        overflow: visible !important;
        overflow-y: visible !important;
        height: auto !important;
    }
    
    /* Postagem sem scroll - altura automática */
    #modal-postagem-completa .post {
        display: flex;
        flex-direction: column;
        max-height: none;
        overflow: visible !important;
        overflow-y: visible !important;
        overflow-x: visible !important;
        height: auto;
    }
    
    /* Reduzir largura da lista de comentários em telas maiores */
    #modal-postagem-completa .comment-list {
        max-width: 85% !important;
        width: 85% !important;
        margin: 0 auto;
    }
    
    /* Reduzir padding da área da postagem */
    #modal-postagem-completa .post-header {
        padding-top: 5px;
        padding-bottom: 4px;
        flex-shrink: 0;
        overflow: visible;
        margin-bottom: 3px;
    }
    
    #modal-postagem-completa .post-content {
        padding-top: 4px;
        padding-bottom: 5px;
        flex-shrink: 0;
        overflow: visible;
        margin-bottom: 3px;
    }
    
    #modal-postagem-completa .post-actions {
        padding-top: 5px;
        padding-bottom: 5px;
        flex-shrink: 0;
        overflow: visible;
        margin-bottom: 3px;
    }
    
    /* Reduzir altura máxima da imagem */
    #modal-postagem-completa .post-image {
        max-height: 250px !important;
        margin-top: 5px;
        margin-bottom: 5px;
    }
    
    /* Seção de comentários com altura máxima e scroll */
    #modal-postagem-completa .post-comments {
        display: flex;
        flex-direction: column;
        flex-shrink: 0;
        max-height: calc(100vh - 300px) !important;
        overflow: hidden !important;
        overflow-x: hidden;
        max-width: 100%;
        margin-top: 5px;
        box-sizing: border-box;
        position: relative;
    }
    
    /* Lista de comentários com scroll - reduzida em telas maiores */
    #modal-postagem-completa .comment-list {
        overflow-y: auto !important;
        overflow-x: hidden !important;
        max-height: calc(100vh - 380px) !important;
        max-width: 85% !important;
        width: 85% !important;
        padding-right: 5px;
        flex: 1;
        min-height: 0;
        box-sizing: border-box !important;
        margin: 0 auto;
    }
    
    /* Formulário fixo */
    #modal-postagem-completa .comment-form {
        position: sticky !important;
        bottom: 0 !important;
        margin-top: auto !important;
        flex-shrink: 0 !important;
        z-index: 20 !important;
        background-color: var(--bg-secondary) !important;
        border-top: 1px solid var(--border-color) !important;
    }
    
    #modal-postagem-completa .comment {
        max-width: 100%;
        width: 100%;
        overflow-x: hidden;
        box-sizing: border-box;
    }
    
    #modal-postagem-completa .comment-body-container {
        max-width: 100%;
        width: 100%;
        overflow-x: hidden;
        box-sizing: border-box;
    }
    
    #modal-postagem-completa .comment-body {
        max-width: 100%;
        width: 100%;
        overflow-x: hidden;
        box-sizing: border-box;
    }
    
    #modal-postagem-completa .comment-body p {
        overflow-x: hidden;
    }
    
    #modal-postagem-completa .comment-actions {
        max-width: 100%;
        width: 100%;
        overflow-x: hidden;
        box-sizing: border-box;
    }
    
    /* Formulário sempre visível - fixo */
    #modal-postagem-completa .comment-form {
        flex-shrink: 0;
        background-color: var(--bg-secondary);
        border-top: 1px solid var(--border-color);
        margin-top: auto;
        padding-top: 6px;
        padding-bottom: 6px;
        position: sticky !important;
        bottom: 0 !important;
        width: 100%;
        box-sizing: border-box;
    }

    /* Evita que o final (últimos comentários / "Carregar Mais") fique escondido atrás do formulário fixo */
    #modal-postagem-completa .comment-list {
        padding-bottom: 30px !important;
    }

    /* Dá um respiro e "desce" um pouco o bloco de escrever comentário + enviar */
    #modal-postagem-completa .comment-form {
        padding-top: 14px !important;
    }

    #modal-postagem-completa .load-more-comments-text {
        margin: 10px 0 14px 0 !important;
    }

    /* ====== FIX: no desktop, NÃO rolar a caixa principal; rolar SOMENTE a .comment-list ====== */
    #modal-postagem-completa.modal-overlay {
        overflow: hidden !important;
    }

    #modal-postagem-completa .modal-content.modal-grande {
        display: flex !important;
        flex-direction: column !important;
        /* mantém o tamanho “do jeito que está”, mas limita para não gerar scroll do overlay */
        max-height: calc(100vh - 140px) !important;
        /* trava de vez: não cresce ao carregar mais comentários */
        height: calc(100vh - 140px) !important;
        overflow: hidden !important;
    }

    /* O body do modal precisa ser flex e ocupar o restante da altura */
    #modal-postagem-completa #modal-postagem-content {
        flex: 1 1 auto !important;
        min-height: 0 !important;
        overflow: hidden !important;
        display: flex !important;
        flex-direction: column !important;
    }

    #modal-postagem-completa .post {
        display: flex !important;
        flex-direction: column !important;
        flex: 1 1 auto !important;
        min-height: 0 !important; /* essencial para o flex permitir scroll interno */
        overflow: hidden !important;
        transition: none !important; /* evita “animação de crescimento” ao inserir comentários */
    }

    /* Cabeçalho/conteúdo/ações sempre fixos (não rolam) */
    #modal-postagem-completa .post-header,
    #modal-postagem-completa .post-content,
    #modal-postagem-completa .post-actions {
        flex-shrink: 0 !important;
    }

    /* Área de comentários ocupa o resto e não expande o modal */
    #modal-postagem-completa .post-comments {
        display: flex !important;
        flex-direction: column !important;
        flex: 1 1 auto !important;
        min-height: 0 !important;
        overflow: hidden !important;
        max-height: none !important;
    }

    /* Só aqui tem rolagem */
    #modal-postagem-completa .comment-list {
        flex: 1 1 auto !important;
        min-height: 0 !important;
        overflow-y: auto !important;
        overflow-x: hidden !important;
        padding-bottom: 70px !important; /* espaço para não esconder atrás do form fixo */
        max-height: none !important;
    }

    /* Formulário não “desce”: fica sempre visível */
    #modal-postagem-completa .comment-form {
        display: flex !important;
        flex: 0 0 auto !important;
        margin-top: 0 !important;
        position: static !important;
        bottom: auto !important;
    }
}

/* Scroll sem barra em celulares */
@media (max-width: 767px) {
    #modal-postagem-completa .post-comments {
        scrollbar-width: none; /* Firefox */
        -ms-overflow-style: none; /* IE e Edge */
    }
    
    #modal-postagem-completa .post-comments::-webkit-scrollbar {
        display: none; /* Chrome, Safari, Opera */
    }
}

/* Scroll com barra em tablets e computadores */
@media (min-width: 768px) {
    #modal-postagem-completa .post-comments {
        scrollbar-width: thin;
        scrollbar-color: rgba(155, 155, 155, 0.5) transparent;
    }
    
    #modal-postagem-completa .post-comments::-webkit-scrollbar {
        width: 8px;
    }
    
    #modal-postagem-completa .post-comments::-webkit-scrollbar-track {
        background: transparent;
    }
    
    #modal-postagem-completa .post-comments::-webkit-scrollbar-thumb {
        background-color: rgba(155, 155, 155, 0.5);
        border-radius: 10px;
    }
    
    #modal-postagem-completa .post-comments::-webkit-scrollbar-thumb:hover {
        background-color: rgba(155, 155, 155, 0.7);
    }
}
.post-header { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.post-header .post-avatar { width: 48px; height: 48px; border-radius: 50%; object-fit: cover; flex-shrink: 0; cursor: pointer; }
.post-header .post-meta { display: flex; flex-direction: column; flex-grow: 1; }
.post-header .user-name { font-weight: bold; color: var(--text-primary); font-size: 1.1em; cursor: pointer; } 
.post-header .user-name:hover { text-decoration: underline; }
.post-header .post-date-display { font-size: 0.8em; color: var(--text-secondary); display: inline; } 
.post-author-city { font-size: 0.8em; color: var(--text-secondary); display: inline; } 
.delete-post-btn { background-color: transparent; color: var(--text-secondary); padding: 5px; margin-left: auto; display: flex; align-items: center; gap: 5px; border: none; cursor: pointer; font-size: 12px; border-radius: 5px; } 
.delete-post-btn:hover { background-color: var(--bg-hover); color: #dc3545; } 
.post-content { margin-bottom: 10px; color: var(--text-primary); line-height: 1.5; max-width: 100%; word-wrap: break-word; overflow-wrap: break-word; box-sizing: border-box; } 
.post-image { 
    max-width: 100% !important; 
    width: 100% !important;
    max-height: 600px; 
    height: auto; 
    border-radius: 8px; 
    margin-top: 10px; 
    display: block; 
    object-fit: contain; 
    margin-left: auto;
    margin-right: auto;
    box-sizing: border-box;
}
.post-video { max-width: 100% !important; width: 100% !important; height: auto; border-radius: 8px; margin-top: 10px; display: block; background-color: #000; box-sizing: border-box; }
.post-actions { display: flex; gap: 10px; padding: 10px 0; border-top: none; margin-top: 10px; } 
.action-btn { background-color: var(--bg-action); border: none; border-radius: 5px; padding: 8px 12px; cursor: pointer; color: var(--text-secondary); font-weight: bold; display: flex; align-items: center; gap: 5px; transition: background-color 0.2s; font-size: 14px; } 
.action-btn:hover { background-color: var(--bg-action-hover); } 
.action-btn i { font-size: 16px; }
.btn-like.liked { color: var(--text-link); } 
.btn-like.liked i { color: var(--text-link); } 

/* --- Seção de Comentários (Base) --- */
.post-comments { 
    padding: 10px 0 0 0; 
    border-top: none; 
    margin-top: 10px; 
    display: none;
    position: relative;
    max-height: none !important;
    max-width: 100%;
    overflow: visible !important;
    overflow-x: hidden !important;
    overflow-y: visible !important;
    box-sizing: border-box;
    height: auto !important;
} 

.post-comments.visible { 
    display: flex !important;
    flex-direction: column !important;
    position: relative !important;
    overflow: visible !important;
    overflow-x: hidden !important;
    overflow-y: visible !important;
    max-height: none !important;
    height: auto !important;
}

/* Área de comentários sem rolagem - expande conforme necessário */
.post-comments .comment-list {
    flex: 1;
    overflow: visible !important;
    overflow-x: hidden !important;
    overflow-y: visible !important;
    max-height: none;
    max-width: 100%;
    padding-right: 5px;
    margin-bottom: 0;
    box-sizing: border-box;
    position: relative;
    z-index: 1;
}

/* Garantir que nomes e botões dos comentários sempre fiquem visíveis */
.post-comments .comment-list .comment {
    overflow: visible !important;
    max-height: none !important;
    position: relative;
}

.post-comments .comment-list .comment .comment-body-container {
    overflow: visible !important;
    max-height: none !important;
    position: relative;
}

/* Garantir que o menu de opções não seja cortado pela div post-comments e comment-list */
.post-comments .comment-options-menu,
.post-comments .reply-options-menu,
.comment-list .comment-options-menu,
.comment-list .reply-options-menu {
    overflow: visible !important;
    position: absolute !important;
    z-index: 10000 !important;
    pointer-events: auto !important;
}

/* Garantir que as divs post-comments e comment-list não cortem os menus */
.post-comments,
.post-comments.visible,
.comment-list {
    overflow: visible !important;
    overflow-x: hidden !important;
    overflow-y: visible !important;
    clip-path: none !important;
    contain: none !important;
}

/* Mobile: após clicar "Carregar mais", a lista vira uma área com rolagem (não deixa o post gigante) */
@media (max-width: 767px) {
    .post-comments.visible .comment-list.comment-list-scroll {
        overflow-y: auto !important;
        overflow-x: hidden !important;
        max-height: var(--comment-list-max-height, 280px) !important;
        padding-right: 6px !important;
        overscroll-behavior: contain;
        -webkit-overflow-scrolling: touch;
        scrollbar-gutter: stable;
    }
}

.post-comments .comment-list .comment .comment-body strong {
    position: relative;
    z-index: 2;
    overflow: visible !important;
}

.post-comments .comment-list .comment .comment-actions {
    position: relative;
    z-index: 2;
    overflow: visible !important;
    visibility: visible !important;
    opacity: 1 !important;
}

/* Regras específicas para postagens no perfil - garantir visibilidade completa */
.secao-perfil .post,
#secao-postagens .post,
.minhas-postagens .post {
    overflow-y: visible !important;
    overflow-x: hidden !important;
    max-height: none !important;
    height: auto !important;
    overflow: visible !important;
    position: relative !important;
}

/* Garantir que a caixa principal da postagem não tenha rolagem vertical */
.secao-perfil .post > *,
#secao-postagens .post > *,
.minhas-postagens .post > * {
    overflow-y: visible !important;
    max-height: none !important;
}

/* Remover TODA rolagem vertical da caixa principal em telas maiores */
@media (min-width: 769px) {
    .secao-perfil .post,
    #secao-postagens .post,
    .minhas-postagens .post {
        overflow: visible !important;
        overflow-y: visible !important;
        overflow-x: hidden !important;
        max-height: none !important;
        height: auto !important;
        position: relative !important;
    }
    
    /* Garantir que nenhum elemento interno tenha rolagem */
    .secao-perfil .post *,
    #secao-postagens .post *,
    .minhas-postagens .post * {
        overflow-y: visible !important;
        max-height: none !important;
    }
    
    /* Garantir que o formulário fique sempre visível */
    .secao-perfil .post-comments .comment-form,
    #secao-postagens .post-comments .comment-form,
    .minhas-postagens .post-comments .comment-form {
        position: sticky !important;
        bottom: 0 !important;
        z-index: 100 !important;
        background: var(--bg-secondary) !important;
    }
}

.secao-perfil .post-comments,
#secao-postagens .post-comments,
.minhas-postagens .post-comments {
    display: flex !important;
    flex-direction: column !important;
    position: relative !important;
    overflow-y: visible !important;
    overflow-x: hidden !important;
    max-height: none !important;
    height: auto !important;
}

.secao-perfil .post-comments .comment-list,
#secao-postagens .post-comments .comment-list,
.minhas-postagens .post-comments .comment-list {
    overflow-y: visible !important;
    overflow-x: hidden !important;
    max-height: none !important;
    flex: 1 !important;
    min-height: 0 !important;
}

.secao-perfil .post-comments .comment,
#secao-postagens .post-comments .comment,
.minhas-postagens .post-comments .comment {
    overflow: visible !important;
    max-height: none !important;
    min-height: auto !important;
}

.secao-perfil .post-comments .comment .comment-body strong,
#secao-postagens .post-comments .comment .comment-body strong,
.minhas-postagens .post-comments .comment .comment-body strong {
    overflow: visible !important;
    visibility: visible !important;
    opacity: 1 !important;
    display: block !important;
    position: relative !important;
    z-index: 2 !important;
}

.secao-perfil .post-comments .comment .comment-actions,
#secao-postagens .post-comments .comment .comment-actions,
.minhas-postagens .post-comments .comment .comment-actions {
    overflow: visible !important;
    visibility: visible !important;
    opacity: 1 !important;
    display: flex !important;
    position: relative !important;
    z-index: 2 !important;
    flex-shrink: 0 !important;
}

/* Garantir que o formulário de comentários fique sempre visível nas postagens do perfil */
.secao-perfil .post-comments .comment-form,
#secao-postagens .post-comments .comment-form,
.minhas-postagens .post-comments .comment-form {
    position: sticky !important;
    bottom: 0 !important;
    z-index: 20 !important;
    background: var(--bg-secondary) !important;
    padding: 10px 0 !important;
    margin-top: auto !important;
    border-top: 1px solid var(--border-color) !important;
    display: flex !important;
    gap: 5px !important;
    align-items: center !important;
    flex-wrap: nowrap !important;
    visibility: visible !important;
    opacity: 1 !important;
    overflow: visible !important;
    flex-shrink: 0 !important;
    width: 100% !important;
    box-sizing: border-box !important;
}

.secao-perfil .post-comments .comment-form .comment-input,
#secao-postagens .post-comments .comment-form .comment-input,
.minhas-postagens .post-comments .comment-form .comment-input {
    flex: 1 !important;
    min-width: 0 !important;
    visibility: visible !important;
    opacity: 1 !important;
    display: block !important;
}

.secao-perfil .post-comments .comment-form .btn-send-comment,
#secao-postagens .post-comments .comment-form .btn-send-comment,
.minhas-postagens .post-comments .comment-form .btn-send-comment {
    flex-shrink: 0 !important;
    visibility: visible !important;
    opacity: 1 !important;
    display: inline-block !important;
    white-space: nowrap !important;
}

/* Barra de rolagem personalizada para comentários */
.post-comments .comment-list::-webkit-scrollbar {
    width: 6px;
}

.post-comments .comment-list::-webkit-scrollbar-track {
    background: transparent;
    border-radius: 10px;
}

.post-comments .comment-list::-webkit-scrollbar-thumb {
    background: var(--text-secondary);
    border-radius: 10px;
    opacity: 0.3;
}

.post-comments .comment-list::-webkit-scrollbar-thumb:hover {
    background: var(--text-secondary);
    opacity: 0.6;
}

/* Formulário de comentário fixo na parte inferior */
.post-comments .comment-form {
    position: sticky !important;
    bottom: 0 !important;
    background: var(--bg-secondary) !important;
    padding: 10px 0 !important;
    margin-top: auto !important;
    border-top: 1px solid var(--border-color) !important;
    z-index: 100 !important;
    display: flex !important;
    gap: 5px !important;
    align-items: center !important;
    flex-wrap: nowrap !important;
    visibility: visible !important;
    opacity: 1 !important;
    overflow: visible !important;
    width: 100% !important;
    box-sizing: border-box !important;
}

/* Em telas maiores, garantir que o formulário fique sempre visível */
@media (min-width: 769px) {
    .post-comments .comment-form {
        position: sticky !important;
        bottom: 0 !important;
        z-index: 100 !important;
        background: var(--bg-secondary) !important;
        margin-top: auto !important;
    }
    
    /* Garantir que a postagem não tenha rolagem que esconda o formulário */
    .post {
        overflow: visible !important;
        overflow-y: visible !important;
        max-height: none !important;
        height: auto !important;
    }
    
    .post-comments {
        overflow: visible !important;
        overflow-y: visible !important;
        max-height: none !important;
        height: auto !important;
    }
}

/* 🆕 Faixa de miniaturas sobre o feed (estilo stories, menor) */
.top-strip {
    display: flex;
    gap: 8px;
    align-items: center;
    margin-bottom: 12px;
}
.top-strip .mobile-sidebar-toggle {
    flex: 0 0 auto;
}
.top-strip .barra-destaques {
    flex: 1 1 auto;
    min-width: 0;
    margin-bottom: 0;
}

.barra-destaques {
    margin-bottom: 12px;
    position: relative;
}
.destaques-scroll {
    display: flex;
    gap: 12px;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 12px 12px 14px 12px;
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    scrollbar-width: thin;
    min-height: 130px;
    max-height: 160px;
    mask-image: linear-gradient(90deg, transparent 0, #000 12px, #000 calc(100% - 12px), transparent 100%);
    -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 12px, #000 calc(100% - 12px), transparent 100%);
    scrollbar-width: none; /* Firefox */
}
.destaques-scroll::-webkit-scrollbar {
    display: none; /* Chrome/Safari */
}
.btn-scroll-destaques {
    position: absolute;
    right: 4px;
    top: 50%;
    transform: translateY(-50%);
    width: 38px;
    height: 78px;
    border: none;
    background: linear-gradient(90deg, rgba(0,0,0,0) 0%, rgba(0,0,0,0.35) 100%);
    color: #fff;
    font-size: 18px;
    cursor: pointer;
    border-radius: 10px;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: opacity 0.12s ease;
    opacity: 0.7;
    display: none; /* controlado via JS */
    z-index: 2;
}
.btn-scroll-destaques.show { display: flex; }
.btn-scroll-destaques:hover {
    opacity: 1;
}
.btn-scroll-destaques:focus { outline: none; }

.btn-scroll-esq {
    left: 4px;
    right: auto;
    transform: translateY(-50%);
}

.thumb-destaque {
    position: relative;
    width: clamp(80px, 20vw, 122px);
    height: clamp(80px, 20vw, 122px);
    border-radius: 12px;
    overflow: hidden;
    flex: 0 0 auto;
    border: 1px solid var(--border-color);
    cursor: pointer;
    transition: transform 0.12s ease, box-shadow 0.12s ease;
    background: var(--bg-primary);
}
.thumb-destaque:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 12px rgba(0,0,0,0.08);
}
.thumb-destaque img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.thumb-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,0.3) 50%, rgba(0,0,0,0.7) 100%);
    pointer-events: none;
}

/* Container para informações sobrepostas na foto */
.thumb-info-overlay {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: 2px 8px 8px 8px;
    pointer-events: none;
    z-index: 2;
}

/* Profissão - aparece no topo da foto, perto da borda superior */
.thumb-profissao {
    background: rgba(0, 0, 0, 0.4);
    color: #fff;
    padding: 3px 6px;
    border-radius: 8px;
    font-weight: 600;
    font-size: 10px;
    margin-top: 0;
    text-align: center;
    backdrop-filter: blur(4px);
    overflow: visible;
    word-wrap: break-word;
    white-space: normal;
    align-self: stretch;
    line-height: 1.3;
}

/* Avaliação/Estrelas - aparece na parte inferior */
.thumb-avaliacao {
    background: rgba(0, 0, 0, 0.5);
    color: #fff;
    padding: 3px 8px;
    border-radius: 8px;
    font-size: 12px;
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 4px;
    backdrop-filter: blur(4px);
    align-self: center;
    margin-top: auto;
}

.thumb-avaliacao i {
    color: #f5a623;
    font-size: 12px;
}

.thumb-avaliacao span {
    color: #fff;
    font-weight: 700;
}

/* Botão "Tempo Real" para localização */
.btn-tempo-real {
    background: rgba(0, 123, 255, 0.15);
    border: 1px solid rgba(0, 123, 255, 0.3);
    color: var(--text-primary);
    padding: 6px 12px;
    border-radius: 6px;
    font-size: 12px;
    font-weight: 600;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    transition: all 0.2s ease;
    white-space: nowrap;
}

.btn-tempo-real:hover {
    background: rgba(0, 123, 255, 0.25);
    border-color: rgba(0, 123, 255, 0.5);
    transform: translateY(-1px);
}

.btn-tempo-real:active {
    transform: translateY(0);
}

.btn-tempo-real:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

.btn-tempo-real i {
    font-size: 11px;
}

/* Estilos antigos mantidos para compatibilidade */
.thumb-more {
    position: absolute;
    bottom: 8px;
    right: 8px;
    background: rgba(0,0,0,0.65);
    color: #fff;
    padding: 3px 8px;
    border-radius: 12px;
    font-size: 12px;
    font-weight: 700;
    z-index: 3;
}
.thumb-badge {
    position: absolute;
    top: 8px;
    left: 8px;
    background: rgba(255,255,255,0.9);
    color: var(--text-primary);
    padding: 4px 8px;
    border-radius: 11px;
    font-weight: 700;
    font-size: 12px;
    max-width: 88%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    z-index: 3;
}
.thumb-note {
    position: absolute;
    bottom: 8px;
    left: 8px;
    background: rgba(0,0,0,0.65);
    color: #fff;
    padding: 3px 7px;
    border-radius: 11px;
    font-size: 12px;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    z-index: 3;
}

.thumb-destaque.anuncio-nativo {
    background: linear-gradient(145deg, #0f172a, #1e293b);
    border: 1px solid rgba(255,255,255,0.08);
    color: #e2e8f0;
    padding: 10px;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 6px;
}
.anuncio-nativo-titulo {
    font-weight: 800;
    font-size: 13px;
    color: #38bdf8;
}
.anuncio-nativo-loja {
    font-weight: 700;
    font-size: 12px;
}
.anuncio-nativo-endereco {
    font-size: 11px;
    color: #cbd5e1;
    line-height: 1.3;
}
.btn-como-chegar {
    margin-top: auto;
    background: #22c55e;
    color: #0b121f;
    border: none;
    border-radius: 10px;
    padding: 6px 8px;
    font-weight: 700;
    font-size: 12px;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
}
.btn-como-chegar:hover {
    background: #16a34a;
}

.anuncio-card {
    position: relative;
    border-radius: 12px;
    overflow: hidden;
    border: none;
    color: #e2e8f0;
    display: flex;
    min-height: 220px;
    width: min(520px, 100%);
    height: 100%;
    cursor: pointer;
}
.anuncio-nativo-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.anuncio-nativo-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(0,0,0,0.15) 0%, rgba(0,0,0,0.7) 100%);
    padding: 14px;
    display: flex;
    flex-direction: column;
    gap: 6px;
    justify-content: flex-end;
    box-sizing: border-box;
}
.anuncio-nativo-badge {
    position: absolute;
    top: 8px;
    left: 8px;
    background: rgba(0,0,0,0.55);
    color: #e2e8f0;
    padding: 3px 7px;
    border-radius: 10px;
    font-size: 10px;
    font-weight: 700;
    z-index: 3;
    pointer-events: none;
}
.anuncio-nativo-overlay.feed {
    background: linear-gradient(180deg, rgba(0,0,0,0.25) 0%, rgba(0,0,0,0.75) 100%);
}
.anuncio-nativo-feed {
    position: relative;
    overflow: hidden;
    padding: 0;
    border: 1px solid rgba(255,255,255,0.08);
}
.anuncio-nativo-feed .anuncio-nativo-img {
    width: 100%;
    height: 220px;
    object-fit: cover;
    display: block;
}
.anuncio-nativo-feed .anuncio-nativo-overlay {
    position: absolute;
    inset: 0;
    padding: 14px;
    display: flex;
    flex-direction: column;
    gap: 6px;
    justify-content: flex-end;
    box-sizing: border-box;
}
.anuncio-nativo-feed .btn-como-chegar {
    width: auto;
    align-self: flex-start;
    margin-top: 6px;
}

/* Modal Enviar Proposta Rápida */
#modal-enviar-proposta .modal-content {
    max-width: 420px;
    width: 92%;
    max-height: none;
    overflow: visible;
}
#modal-enviar-proposta .form-group input,
#modal-enviar-proposta .form-group select,
#modal-enviar-proposta .form-group textarea {
    width: 100%;
}
#modal-enviar-proposta .form-actions {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
}
#modal-enviar-proposta .btn-close-modal[data-modal="modal-enviar-proposta"] {
    position: static;
    width: auto;
    height: auto;
    font-size: 14px;
    padding: 10px 16px;
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: 6px;
    color: var(--text-primary);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
}
#modal-enviar-proposta .btn-close-modal[data-modal="modal-enviar-proposta"]:hover {
    background: var(--bg-hover);
}
.anuncio-nativo-titulo {
    font-weight: 800;
    font-size: 14px;
    color: #38bdf8;
}
.anuncio-nativo-loja {
    font-weight: 700;
    font-size: 13px;
}
.anuncio-nativo-endereco {
    font-size: 12px;
    color: #cbd5e1;
    line-height: 1.3;
}
/* Modal de destaque */
.destaque-modal-info {
    margin-bottom: 12px;
}
#modal-destaque-servico .modal-content {
    max-width: 900px;
    width: 96%;
}
.destaque-modal-imagens {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 12px;
}
.destaque-modal-imagens img {
    width: 100%;
    height: clamp(200px, 32vw, 280px);
    object-fit: cover;
    border-radius: 10px;
    border: 1px solid var(--border-color);
}
.destaque-modal-actions {
    display: flex;
    gap: 10px;
    margin-top: 14px;
}
.comment-list { 
    margin-top: 10px; 
    display: flex;
    flex-direction: column;
}

/* Comentários ocultos inicialmente */
.comment-hidden {
    display: none !important;
}

/* Texto "Carregar mais" - apenas texto, não botão */
.load-more-comments {
    color: var(--text-link);
    cursor: pointer;
    font-size: 14px;
    padding: 8px 12px;
    text-align: left;
    transition: color 0.2s;
    user-select: none;
    margin-top: 5px;
}

.load-more-comments:hover {
    color: var(--text-primary);
    text-decoration: underline;
}

/* Texto "Carregar Mais" no modal - apenas texto, não botão */
.load-more-comments-text {
    color: var(--text-link);
    cursor: pointer;
    font-size: 14px;
    padding: 0;
    margin-top: -15px;
    margin-bottom: -5px;
    text-align: center;
    transition: color 0.2s;
    user-select: none;
    background: none;
    border: none;
    font-family: inherit;
    font-weight: normal;
    text-decoration: none;
    display: block;
    width: 100%;
    line-height: 1.2;
}

.load-more-comments-text:hover {
    color: var(--text-primary);
    text-decoration: underline;
}

/* Comentários expandidos com rolagem lateral em telas menores */
@media (max-width: 767px) {
    #modal-postagem-completa .comment-list.comments-expanded {
        display: flex;
        flex-direction: row;
        overflow-x: auto;
        overflow-y: visible;
        max-height: none !important;
        gap: 15px;
        padding: 10px 0;
        scroll-snap-type: x mandatory;
        -webkit-overflow-scrolling: touch;
    }
    
    #modal-postagem-completa .comment-list.comments-expanded .comment {
        flex: 0 0 auto;
        min-width: calc(100% - 30px);
        max-width: calc(100% - 30px);
        scroll-snap-align: start;
    }
    
    /* Barra de rolagem personalizada para comentários horizontais */
    #modal-postagem-completa .comment-list.comments-expanded::-webkit-scrollbar {
        height: 6px;
    }
    
    #modal-postagem-completa .comment-list.comments-expanded::-webkit-scrollbar-track {
        background: transparent;
        border-radius: 10px;
    }
    
    #modal-postagem-completa .comment-list.comments-expanded::-webkit-scrollbar-thumb {
        background: var(--text-secondary);
        border-radius: 10px;
        opacity: 0.3;
    }
    
    #modal-postagem-completa .comment-list.comments-expanded::-webkit-scrollbar-thumb:hover {
        background: var(--text-secondary);
        opacity: 0.6;
    }
} 
/* .comment-form já está definido acima com estilos completos */
/* .comment-form já está definido acima com position sticky */

.comment-input { 
    flex-grow: 1; 
    border: 1px solid var(--border-color); 
    background-color: var(--bg-input); 
    color: var(--text-primary); 
    border-radius: 20px; 
    padding: 10px 16px; 
    font-size: 14px;
    font-family: inherit;
    resize: none;
    overflow-y: auto;
    min-height: 44px;
    max-height: 120px;
    line-height: 1.5;
    width: 100%;
    transition: border-color 0.2s, max-height 0.2s;
} 

/* Expansão automática em telas maiores */
@media (min-width: 768px) {
    .comment-input {
        min-height: 50px;
        max-height: 200px;
    }
    
    /* Aplica as mesmas regras de telas menores para evitar rolagem lateral */
    .post-comments {
        max-width: 100%;
        overflow-x: hidden;
        overflow-y: visible;
    }
    
    .comment-list {
        max-width: 100%;
        overflow-x: hidden;
        word-wrap: break-word;
    }
    
    .comment {
        max-width: 100%;
        overflow-x: hidden;
    }
    
    .comment-body-container {
        max-width: 100%;
        width: 100%;
        min-width: 0;
        overflow-x: hidden;
        box-sizing: border-box;
    }
    
    .comment-body {
        max-width: 100%;
        width: 100%;
        min-width: 0;
        word-wrap: break-word;
        overflow-wrap: break-word;
        overflow-x: hidden;
        box-sizing: border-box;
    }
    
    .comment-body p {
        overflow-x: hidden;
    }
    
    .comment-actions {
        overflow-x: hidden;
    }
}

/* Limite de 3 linhas em telas menores */
@media (max-width: 767px) {
    .comment-input {
        min-height: 44px;
        max-height: 66px; /* Aproximadamente 3 linhas (22px por linha) */
        overflow-y: auto;
    }
    
    /* Largura máxima para evitar rolagem lateral */
    .post-comments {
        max-width: 100%;
        overflow-x: hidden;
    }
    
    .comment-list {
        max-width: 100%;
        overflow-x: hidden;
        word-wrap: break-word;
    }
    
    .comment {
        max-width: 100%;
        overflow-x: hidden;
    }
    
    .comment-body-container {
        max-width: 100%;
        overflow-x: hidden;
    }
    
    .comment-body {
        max-width: 100%;
        width: 100%;
        min-width: 0;
        word-wrap: break-word;
        overflow-wrap: break-word;
        box-sizing: border-box;
    }
    
    .comment-body-container {
        max-width: 100%;
        width: 100%;
        min-width: 0;
        box-sizing: border-box;
    }
    
    /* Limitar comentários publicados a 5 linhas em mobile - APENAS para comentários longos */
    .comment-body p.comment-long {
        max-height: 110px !important; /* Aproximadamente 5 linhas */
        overflow: hidden !important;
        position: relative;
        transition: max-height 0.3s ease;
        display: -webkit-box;
        -webkit-line-clamp: 5;
        line-clamp: 5;
        -webkit-box-orient: vertical;
    }
    
    .comment-body p.comment-long.expanded {
        max-height: none !important;
        overflow: visible !important;
        display: block;
        -webkit-line-clamp: unset;
        line-clamp: unset;
        -webkit-box-orient: unset;
    }
    
    /* Botão "Carregar comentário" posicionado após o texto limitado */
    .comment-body p.comment-long::after {
        content: '';
        position: absolute;
        bottom: 0;
        right: 0;
        width: 100%;
        height: 20px;
        background: linear-gradient(to bottom, transparent, var(--bg-comment));
        pointer-events: none;
    }
    
    .comment-body p.comment-long.expanded::after {
        display: none;
    }
    
    /* Garantir que comentários SEM a classe comment-long não tenham limite */
    .comment-body p:not(.comment-long) {
        max-height: none !important;
        overflow: visible !important;
        overflow-y: visible !important;
        overflow-x: visible !important;
        height: auto !important;
    }
    
    /* Garantir que a área de comentários possa expandir */
    .post-comments {
        max-height: none !important;
        overflow-y: visible !important;
    }
    
    .comment-list {
        max-height: none !important;
        overflow-y: visible !important;
    }
    
    /* Botão "Carregar comentário" posicionado após o parágrafo */
    .load-comment-text {
        color: var(--text-link);
        cursor: pointer;
        font-size: 13px;
        margin-top: 5px;
        display: block;
        transition: color 0.2s;
        padding: 0;
        position: relative;
        z-index: 2;
        background: var(--bg-comment);
        padding-top: 3px;
        width: 100%;
    }
    
    .load-comment-text:hover {
        color: var(--text-primary);
        text-decoration: underline;
    }
}

/* Barra de rolagem personalizada para o textarea */
.comment-input::-webkit-scrollbar {
    width: 6px;
}

.comment-input::-webkit-scrollbar-track {
    background: transparent;
    border-radius: 10px;
}

.comment-input::-webkit-scrollbar-thumb {
    background: var(--text-secondary);
    border-radius: 10px;
    opacity: 0.4;
}

.comment-input::-webkit-scrollbar-thumb:hover {
    background: var(--text-secondary);
    opacity: 0.7;
}

.comment-input:focus { 
    outline: none; 
    border-color: var(--btn-filter-active-bg); 
} 

.comment-input::placeholder { 
    color: var(--text-placeholder); 
} 

.btn-send-comment { 
    border: none; 
    background: transparent;
    color: var(--text-primary);
    border-radius: 50%;
    padding: 0;
    cursor: pointer; 
    font-size: 18px;
    line-height: 1;
    transition: opacity 0.2s;
    flex-shrink: 0;
    width: 38px;
    height: 38px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
} 

.btn-send-comment:hover { 
    background: transparent;
    opacity: 0.75;
} 

.btn-send-comment .send-comment-icon,
#modal-postagem-completa .btn-send-comment .send-comment-icon {
    width: 24px;
    height: 24px;
    display: block;
    object-fit: contain;
    pointer-events: none;
    user-select: none;
} 


/* 🛑 ESTILOS DOS COMENTÁRIOS AVANÇADOS (CURTIR, RESPONDER, DELETAR)
   Importante: não forçar display aqui, para a seção ficar oculta até clicar em "Comentários". */
.post-comments.visible {
    /* Remove limite de altura - permite expansão conforme necessário */
    max-height: none !important;
    max-width: 100%;
    overflow-y: visible !important;
    overflow-x: hidden !important; /* Remove rolagem lateral */
    padding-right: 5px;
    box-sizing: border-box;
    position: relative !important;
    height: auto !important;
    overflow: visible !important;
}

/* Barra de rolagem personalizada para comentários */
.post-comments::-webkit-scrollbar {
    width: 6px;
}

.post-comments::-webkit-scrollbar-track {
    background: transparent;
    border-radius: 10px;
}

.post-comments::-webkit-scrollbar-thumb {
    background: var(--text-secondary);
    border-radius: 10px;
    opacity: 0.3;
}

.post-comments::-webkit-scrollbar-thumb:hover {
    background: var(--text-secondary);
    opacity: 0.6;
}

.comment-list {
    display: flex;
    flex-direction: column;
    overflow: visible;
    overflow-x: hidden; /* Remove rolagem lateral */
    max-height: none;
}

/* Comentários ocultos inicialmente */
.comment-hidden {
    display: none !important;
}

/* Texto "Carregar mais" */
.load-more-comments {
    color: var(--text-link);
    cursor: pointer;
    font-size: 14px;
    padding: 8px 12px;
    text-align: left;
    transition: color 0.2s;
    user-select: none;
}

.load-more-comments:hover {
    color: var(--text-primary);
    text-decoration: underline;
}

.comment {
    display: flex;
    gap: 8px;
    margin-bottom: 10px;
    position: relative;
    overflow: visible;
    overflow-x: hidden; /* Remove rolagem lateral */
    max-height: none;
    max-width: 100%;
    width: 100%;
    box-sizing: border-box;
}
.comment-avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
    transition: opacity 0.2s;
}

.comment-avatar:hover {
    opacity: 0.8;
}
.comment-body-container {
    display: flex;
    flex-direction: column;
    width: 100%;
    max-width: 100%;
    overflow: visible;
    overflow-x: visible; /* Permite menu aparecer ao lado */
    max-height: none;
    min-width: 0; /* Permite que o elemento encolha */
    box-sizing: border-box;
    position: relative;
}
.comment-body {
    background-color: var(--bg-comment);
    border-radius: 10px;
    padding: 8px 12px;
    font-size: 14px;
    display: inline-block;
    width: fit-content;
    max-width: calc(100% - 50px); /* Espaço para o menu lateral */
    min-width: 0; /* Permite que o elemento encolha */
    word-wrap: break-word;
    overflow-wrap: break-word;
    position: relative;
    padding-right: 30px; /* Espaço para o botão de opções */
    overflow: visible !important;
    overflow-x: visible !important; /* Permite menu aparecer ao lado */
    max-height: none !important;
    box-sizing: border-box; /* Inclui padding no cálculo da largura */
}
.comment-body strong,
.comment-body a {
    display: block;
    font-size: 13px;
    color: var(--text-primary);
    flex-shrink: 0; /* Garante que o nome não seja cortado */
    white-space: nowrap; /* Evita quebra de linha no nome */
    overflow: visible !important;
    max-width: calc(100% - 40px); /* Espaço para o botão de opções */
    text-overflow: ellipsis; /* Se o nome for muito longo, mostra ... */
    margin-right: 35px; /* Espaço maior entre nome e botão */
    padding-right: 8px; /* Espaçamento adicional */
}

.comment-body a {
    text-decoration: none;
    transition: opacity 0.2s;
}

.comment-body a:hover {
    opacity: 0.8;
    text-decoration: underline;
}
.comment-body p {
    margin: 0;
    color: var(--text-primary);
    line-height: 1.4;
    word-wrap: break-word;
    overflow-wrap: break-word;
    overflow: visible !important;
    overflow-x: hidden !important; /* Remove rolagem lateral */
    max-height: none !important;
    height: auto !important;
}

/* Garantir que comentários normais não tenham rolagem */
.comment-body p:not(.comment-long) {
    overflow: visible !important;
    overflow-x: hidden !important; /* Remove rolagem lateral */
    max-height: none !important;
    height: auto !important;
    overflow-y: visible !important;
}

/* Botão de opções (3 pontos) - horizontal */
.btn-comment-options,
.btn-reply-options {
    position: absolute;
    top: 8px;
    right: 8px;
    background: none;
    border: none;
    font-size: 16px;
    color: var(--text-secondary);
    cursor: pointer;
    padding: 0;
    line-height: 1;
    letter-spacing: 2px;
    z-index: 10;
    transition: color 0.2s;
    display: block !important;
    width: 20px;
    height: 20px;
    text-align: center;
    font-family: Arial, sans-serif;
}

.btn-comment-options:hover,
.btn-reply-options:hover {
    color: var(--text-primary);
}

/* Menu de opções - lateral ao comentário */
.comment-options-menu,
.reply-options-menu {
    position: absolute;
    top: 0;
    left: calc(100% + 10px);
    background: transparent !important;
    border: none !important;
    border-radius: 0;
    padding: 0;
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    gap: 12px !important;
    z-index: 10000 !important;
    box-shadow: none !important;
    overflow: visible !important;
    white-space: nowrap;
    min-width: auto;
    width: auto;
    align-items: center;
    justify-content: center;
}

/* Em telas menores: menu de opções acima do comentário APENAS quando necessário */
@media (max-width: 767px) {
    .comment-options-menu.comentario-multiplas-linhas,
    .reply-options-menu.comentario-multiplas-linhas {
        /* Posição será controlada via JavaScript quando necessário */
        max-width: calc(100vw - 16px);
        overflow: visible;
    }
    
    /* Garante que o menu nunca saia da tela */
    .comment-options-menu,
    .reply-options-menu {
        max-width: calc(100vw - 16px);
        white-space: nowrap;
        position: absolute;
    }
    
    /* Botão de opções permanece no lugar original (dentro do comentário) */
}

.comment-options-menu button,
.reply-options-menu button {
    background: none !important;
    border: none !important;
    font-size: 12px;
    cursor: pointer;
    padding: 2px;
    border-radius: 0;
    transition: opacity 0.2s;
    line-height: 1;
    display: block !important;
    position: relative !important;
    align-items: center;
    justify-content: center;
    min-width: 20px;
    width: 20px;
    height: 20px;
    flex-shrink: 0;
    margin: 0 !important;
    float: none !important;
    opacity: 0.8;
}

/* Popup de confirmação de exclusão - pequeno ao lado da lixeira */
.delete-confirm-popup {
    /* No tema claro, mantém cinza (não branco estourado). No tema escuro continua escuro via variáveis. */
    background: var(--bg-comment);
    border: 1px solid var(--border-color);
    border-radius: 6px;
    padding: 8px;
    box-shadow: 0 4px 12px var(--shadow-color);
    min-width: auto;
    width: auto;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.delete-confirm-text {
    color: var(--text-primary);
    font-size: 12px;
    text-align: center;
    margin-bottom: 2px;
    white-space: nowrap;
}

.delete-confirm-buttons {
    display: flex;
    flex-direction: row;
    gap: 6px;
    align-items: center;
    justify-content: center;
}

.delete-confirm-popup .btn-confirm-yes,
.delete-confirm-popup .btn-confirm-no {
    background: var(--bg-hover);
    border: 1px solid var(--border-color);
    color: var(--text-primary);
    font-size: 11px;
    padding: 4px 10px;
    border-radius: 4px;
    cursor: pointer;
    transition: all 0.2s;
    font-weight: 500;
    min-width: 35px;
    text-align: center;
}

/* "Sim" com ênfase em vermelho (tema claro/escuro) */
.delete-confirm-popup .btn-confirm-yes {
    background: rgba(220, 53, 69, 0.12);
    border-color: rgba(220, 53, 69, 0.35);
    color: #dc3545;
}

.delete-confirm-popup .btn-confirm-yes:hover {
    background: #dc3545;
    border-color: #dc3545;
    color: #ffffff;
}

.delete-confirm-popup .btn-confirm-no:hover {
    background: var(--bg-action-hover);
    border-color: var(--border-color);
}

.comment-options-menu button:hover,
.reply-options-menu button:hover {
    opacity: 1;
    background: var(--bg-comment) !important;
}

/* Botões de confirmação/cancelamento na edição */
.comment-edit-actions,
.reply-edit-actions {
    display: inline-flex;
    gap: 4px;
    margin-left: 8px;
    vertical-align: middle;
}

.btn-confirm-edit,
.btn-cancel-edit,
.btn-confirm-edit-reply,
.btn-cancel-edit-reply {
    background: none;
    border: none;
    font-size: 18px;
    cursor: pointer;
    padding: 2px 4px;
    line-height: 1;
    transition: color 0.2s;
}

.btn-confirm-edit,
.btn-confirm-edit-reply {
    color: #28a745;
}

.btn-cancel-edit,
.btn-cancel-edit-reply {
    color: #dc3545;
}

.btn-confirm-edit:hover,
.btn-confirm-edit-reply:hover {
    color: #218838;
}

.btn-cancel-edit:hover,
.btn-cancel-edit-reply:hover {
    color: #c82333;
}

/* Input de edição */
.comment-edit-input,
.reply-edit-input {
    background: var(--bg-primary);
    border: 1px solid var(--border-color);
    border-radius: 6px;
    padding: 6px 10px;
    font-size: 14px;
    color: var(--text-primary);
    width: 100%;
    min-width: 200px;
    max-width: 100%;
    font-family: inherit;
}

/* Garantir que os botões de ação não sejam cortados */
.comment-actions {
    margin-top: 5px;
    flex-shrink: 0;
    overflow: visible;
    overflow-x: hidden; /* Remove rolagem lateral */
    position: relative;
    z-index: 1;
    max-width: 100%;
    width: 100%;
    box-sizing: border-box;
    display: flex;
    align-items: center;
    gap: 15px;
    font-size: 12px;
    color: var(--text-secondary);
    padding-left: 12px; 
    margin-top: 2px;
    white-space: nowrap; /* Garante que os botões não quebrem linha */
}

/* Ações do Comentário (Curtir, Responder, Deletar) - removido duplicação */
.comment-action-btn {
    background: none;
    border: none;
    color: var(--text-secondary);
    font-weight: bold;
    cursor: pointer;
    padding: 2px;
    font-size: 12px;
}
.comment-action-btn:hover {
    text-decoration: underline;
}
.comment-action-btn i {
    margin-right: 3px;
}
.btn-like-comment.liked {
    color: var(--text-link); 
}
.btn-delete-comment {
    background: none;
    border: none;
    color: var(--text-secondary);
    cursor: pointer;
    font-size: 11px;
    padding: 2px 4px;
    border-radius: 3px;
    position: absolute; 
    top: 5px;
    right: 5px;
    display: inline-block;
    opacity: 0.6;
    transition: opacity 0.2s, color 0.2s;
}
.btn-delete-comment:hover {
    color: #dc3545; 
    opacity: 1;
    background-color: rgba(220, 53, 69, 0.1);
}


/* Área de Respostas */
.reply-list {
    padding-left: 20px;
    margin-top: 10px;
    border-left: 2px solid var(--border-color);
}
.reply {
    display: flex;
    gap: 8px;
    margin-bottom: 8px;
    position: relative;
}
.reply-avatar {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
    transition: opacity 0.2s;
}

.reply-avatar:hover {
    opacity: 0.8;
}
.reply-body-container {
    width: 100%;
    position: relative;
    overflow: visible;
    overflow-x: visible;
}
.reply-body {
    background-color: var(--bg-comment);
    border-radius: 10px;
    padding: 8px 12px;
    font-size: 13px;
    display: inline-block;
    width: fit-content;
    max-width: calc(100% - 50px); /* Espaço para o menu lateral */
    word-wrap: break-word;
    position: relative;
    padding-right: 30px;
    overflow: visible !important;
    overflow-x: visible !important; /* Permite menu aparecer ao lado */
}

/* Nome da pessoa - aparece primeiro */
.reply-body > a:first-of-type {
    display: block;
    font-size: 13px;
    color: var(--text-primary);
    font-weight: bold;
    margin-bottom: 4px;
}

.reply-body a {
    text-decoration: none;
    transition: opacity 0.2s;
}

.reply-body a:hover {
    opacity: 0.8;
    text-decoration: underline;
}

/* Conteúdo da resposta - aparece ABAIXO do nome em uma nova linha */
.reply-body > p.reply-content {
    display: block;
    margin: 0;
    margin-top: 0;
    color: var(--text-primary);
    line-height: 1.4;
}

.reply-body p {
    margin: 0;
    color: var(--text-primary);
    line-height: 1.4;
}

/* Em telas maiores e médias, garante que o nome não seja espremido */
@media (min-width: 768px) {
    .reply-body {
        max-width: calc(100% - 60px); /* Mais espaço para o menu lateral em telas maiores */
    }
    
    /* Nome sempre primeiro - não pode ser espremido */
    .reply-body > a:first-of-type {
        white-space: nowrap;
        display: block;
        margin-bottom: 4px;
    }
    
    /* Conteúdo sempre depois do nome */
    .reply-body > p.reply-content {
        display: block;
        margin: 0;
    }
}
.reply-actions {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 11px;
    color: var(--text-secondary);
    padding-left: 5px;
    margin-top: 1px;
}
.reply-action-btn {
    background: none;
    border: none;
    color: var(--text-secondary);
    font-weight: bold;
    cursor: pointer;
    padding: 1px;
    font-size: 11px;
}
.btn-like-reply.liked {
    color: var(--text-link);
}
.btn-delete-reply {
    background: none;
    border: none;
    color: var(--text-secondary);
    cursor: pointer;
    font-size: 11px;
    padding: 2px 4px;
    border-radius: 3px;
    position: absolute;
    top: 5px;
    right: 5px;
    display: inline-block;
    opacity: 0.6;
    transition: opacity 0.2s, color 0.2s;
}
.btn-delete-reply:hover {
    color: #dc3545;
    opacity: 1;
    background-color: rgba(220, 53, 69, 0.1);
}

/* Formulário de Resposta (Oculto) */
.reply-form {
    display: flex;
    gap: 5px;
    margin-top: 8px;
    padding-left: 12px; 
}
.reply-input {
    flex-grow: 1;
    border: 1px solid var(--border-color);
    background-color: var(--bg-input);
    color: var(--text-primary);
    border-radius: 20px;
    padding: 6px 10px;
    font-size: 13px;
}
.btn-send-reply {
    border: none;
    background: transparent;
    color: var(--text-primary);
    border-radius: 50%;
    padding: 0;
    cursor: pointer;
    font-size: 18px;
    line-height: 1;
    transition: opacity 0.2s;
    flex-shrink: 0;
    width: 38px;
    height: 38px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
}

.btn-send-reply:hover { opacity: 0.75; }

.btn-send-reply .send-reply-icon {
    width: 24px;
    height: 24px;
    display: block;
    object-fit: contain;
    pointer-events: none;
    user-select: none;
}
/* Fim dos Estilos de Comentários Avançados */


/* --- Resto (Anúncio, Modais, Responsividade) --- */
.anuncio { width: min(360px, 100%); flex: 0 1 auto; flex-shrink: 1; min-width: 250px; max-width: 360px; background: transparent; border-radius: 0; padding: 0; box-shadow: none; height: auto; position: static; top: auto; box-sizing: border-box; } 
.anuncio h3 { display: none; } 
.caixa-anuncio { background: transparent; border: none; border-radius: 0; padding: 0; text-align: center; color: var(--text-anuncio); font-size: 0.9em; overflow: hidden; display: flex; width: 100%; justify-content: center; } 
.caixa-anuncio img,
.caixa-anuncio iframe {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 5px;
}
.popup-escolha { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background-color: rgba(0, 0, 0, 0.6); display: flex; justify-content: center; align-items: center; z-index: 5000; }
.popup-conteudo { background-color: var(--bg-secondary); padding: 30px; border-radius: 10px; text-align: center; box-shadow: 0 5px 15px rgba(0, 0, 0, 0.3); max-width: 400px; width: 90%; } 
.popup-conteudo h3 { margin-bottom: 20px; color: var(--text-primary); } 
.popup-conteudo button { background-color: var(--btn-secondary-bg); color: white; border: none; padding: 12px 25px; border-radius: 5px; cursor: pointer; font-size: 1.1em; margin: 5px; transition: background-color 0.2s; } 
.popup-conteudo button:hover { background-color: var(--btn-secondary-hover); } 
.oculto { display: none !important; }
.modal-overlay { position: fixed; top: 0; left: 0; width: 100%; height: 100dvh; background-color: rgba(0, 0, 0, 0.6); display: flex; justify-content: center; align-items: flex-start; z-index: 5000; padding: 20px; box-sizing: border-box; overflow-y: auto; -webkit-overflow-scrolling: touch; overscroll-behavior: contain; }

/* Procurar pedidos: controles responsivos (evita “espremer” em telas menores) */
.procurar-pedidos-controls {
    margin-bottom: 15px;
    display: flex;
    gap: 10px;
    align-items: center;
    flex-wrap: wrap;
}

.procurar-pedidos-top {
    /* Aproxima do filtro de categorias */
    margin: -6px 0 6px;
    display: flex;
    justify-content: flex-end;
}

.procurar-pedidos-filter {
    display: flex;
    align-items: center;
    gap: 8px;
    flex: 1 1 240px;
    min-width: 0;
}

/* Botão “Ativos” com visual limpo (sem fundo azul) */
.btn-clean {
    background: transparent !important;
    color: var(--text-primary) !important;
    border: none !important;
    box-shadow: none !important;
}
.btn-clean:hover {
    background: var(--bg-hover) !important;
}

/* Borda fina SOMENTE no botão "Ativos" */
#btn-servicos-ativos.btn-clean {
    border: 1px solid var(--border-color) !important;
}

/* Topbar do modal "Ativos": botão à esquerda e sem “empurrar” layout */
.servicos-ativos-topbar {
    margin: 0 0 10px;
    display: flex;
    justify-content: flex-start;
    align-items: center;
}

/* Botão "Arquivados" / "Voltar" (mesmo id): maior e mais fácil de clicar */
#btn-ver-cancelados.btn-clean {
    padding: 10px 14px;
    font-size: 15px;
    line-height: 1;
    border-radius: 10px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 42px;
}

#btn-ver-cancelados.btn-clean i {
    font-size: 16px;
}

/* Evita rolagem no container do modal; rola apenas a lista */
#modal-servicos-ativos .modal-content.modal-grande {
    display: flex;
    flex-direction: column;
    overflow: hidden !important;
}
#modal-servicos-ativos .modal-body {
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}
#modal-servicos-ativos #lista-servicos-ativos {
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
    overflow-x: hidden;
}

/* Procurar pedidos / Ativos: remove a “linha” do header do modal */
#modal-pedidos-urgentes-profissional .modal-header,
#modal-servicos-ativos .modal-header {
    border-bottom: none !important;
    padding-bottom: 0 !important;
    margin-bottom: 12px !important;
}

/* Mobile: reduz espaço abaixo do título e compensa acima do botão "Ativos" */
@media (max-width: 520px) {
    #modal-pedidos-urgentes-profissional .modal-header {
        margin-bottom: 6px !important; /* menos espaço abaixo do título */
    }
    .procurar-pedidos-top {
        /* remove o “puxão” pra cima (evita cortar o botão) */
        margin: 0 0 6px !important;
        padding-top: 6px; /* usa o espaço economizado no header */
    }
}

/* Em telas médias+ o header é fixo e pode “cortar” o topo do modal.
   Empurra o conteúdo do modal para baixo do header. */
@media (min-width: 769px) {
    .modal-overlay:not(#modal-notificacoes):not(#image-modal-pedido) {
        padding-top: calc(var(--header-height, 70px) + 20px);
    }
}

/* Mobile: modais grandes não podem ficar por baixo do header/barra inferior.
   Mantém os cabeçalhos visíveis e faz a rolagem acontecer só dentro do modal. */
@media (max-width: 768px) {
    /* Overlay ocupa a tela toda, mas com padding para “respeitar” os cabeçalhos */
    .modal-overlay:not(#modal-notificacoes):not(#modal-aviso-notificacoes):not(#image-modal-pedido) {
        position: fixed;
        inset: 0;
        /* espaço acima/abaixo conforme altura real do header e da barra inferior */
        padding:
            calc(var(--header-height, 70px) + env(safe-area-inset-top, 0px))
            10px
            calc(var(--bottom-nav-height, 56px) + env(safe-area-inset-bottom, 0px))
            10px !important;
        box-sizing: border-box;
        overflow: hidden; /* evita scroll do overlay */
        align-items: stretch;
        justify-content: center;
    }

    /* Só para modais “grandes”: ocupa o espaço útil inteiro */
    .modal-overlay:not(#modal-notificacoes):not(#modal-aviso-notificacoes):not(#image-modal-pedido) .modal-content.modal-grande,
    .modal-overlay:not(#modal-notificacoes):not(#modal-aviso-notificacoes):not(#image-modal-pedido) .modal-content.modal-large {
        width: 100% !important;
        max-width: none !important;
        height: 100% !important;
        max-height: none !important;
        margin: 0 !important;
        border-radius: 0 !important;
        display: flex !important;
        flex-direction: column !important;
        overflow: hidden !important; /* evita scroll do content */
    }

    /* Rola apenas o conteúdo do modal */
    .modal-overlay:not(#modal-notificacoes):not(#modal-aviso-notificacoes):not(#image-modal-pedido) .modal-body,
    .modal-overlay:not(#modal-notificacoes):not(#modal-aviso-notificacoes):not(#image-modal-pedido) .lista-propostas {
        flex: 1 1 auto;
        min-height: 0;
        overflow-y: scroll; /* barra sempre visível (onde suportado) */
        overflow-x: hidden;
        -webkit-overflow-scrolling: touch;
        overscroll-behavior: contain;
        scrollbar-gutter: stable;
    }
}

/* =========================================================
   Scrollbar mais bonita (modais/listas)
   ========================================================= */
.modal-overlay,
#lista-pedidos-urgentes,
#lista-propostas,
.lista-propostas,
.agendamento-horarios-lista {
    scrollbar-width: thin;
    scrollbar-color: rgba(255, 255, 255, 0.35) rgba(255, 255, 255, 0.12);
}

.modal-overlay::-webkit-scrollbar,
#lista-pedidos-urgentes::-webkit-scrollbar,
#lista-propostas::-webkit-scrollbar,
.lista-propostas::-webkit-scrollbar,
.agendamento-horarios-lista::-webkit-scrollbar {
    width: 10px;
    height: 10px;
}

.modal-overlay::-webkit-scrollbar-track,
#lista-pedidos-urgentes::-webkit-scrollbar-track,
#lista-propostas::-webkit-scrollbar-track,
.lista-propostas::-webkit-scrollbar-track,
.agendamento-horarios-lista::-webkit-scrollbar-track {
    background: rgba(255, 255, 255, 0.08);
    border-radius: 999px;
}

.modal-overlay::-webkit-scrollbar-thumb,
#lista-pedidos-urgentes::-webkit-scrollbar-thumb,
#lista-propostas::-webkit-scrollbar-thumb,
.lista-propostas::-webkit-scrollbar-thumb,
.agendamento-horarios-lista::-webkit-scrollbar-thumb {
    background: linear-gradient(180deg, rgba(0, 123, 255, 0.85), rgba(0, 86, 179, 0.85));
    border-radius: 999px;
    border: 2px solid rgba(255, 255, 255, 0.10);
}

.modal-overlay::-webkit-scrollbar-thumb:hover,
#lista-pedidos-urgentes::-webkit-scrollbar-thumb:hover,
#lista-propostas::-webkit-scrollbar-thumb:hover,
.lista-propostas::-webkit-scrollbar-thumb:hover,
.agendamento-horarios-lista::-webkit-scrollbar-thumb:hover {
    background: linear-gradient(180deg, rgba(0, 140, 255, 0.95), rgba(0, 86, 179, 0.95));
}

/* =========================================================
   Select "Tempo de Chegada" (proposta) mais moderno
   ========================================================= */
.select-tempo-chegada {
    width: 100%;
    padding: 12px 44px 12px 12px;
    border-radius: 12px;
    border: 1px solid rgba(255, 255, 255, 0.18);
    background: rgba(255, 255, 255, 0.06);
    color: var(--text-primary);
    outline: none;
    font-size: 14px;
    font-weight: 600;
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.18);
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    background-image:
        linear-gradient(45deg, transparent 50%, rgba(255,255,255,0.75) 50%),
        linear-gradient(135deg, rgba(255,255,255,0.75) 50%, transparent 50%),
        linear-gradient(to right, rgba(255,255,255,0.10), rgba(255,255,255,0.10));
    background-position:
        calc(100% - 18px) calc(50% - 4px),
        calc(100% - 12px) calc(50% - 4px),
        calc(100% - 36px) 50%;
    background-size:
        6px 6px,
        6px 6px,
        1px 60%;
    background-repeat: no-repeat;
}

.select-tempo-chegada:focus {
    border-color: rgba(0, 123, 255, 0.75);
    box-shadow: 0 0 0 3px rgba(0, 123, 255, 0.18), 0 10px 24px rgba(0, 0, 0, 0.22);
}

.select-tempo-chegada option {
    color: #111;
}

/* Modal de propostas deve aparecer acima de outros modais */
#modal-propostas.modal-overlay {
    z-index: 2000 !important;
}

#modal-propostas .modal-content {
    position: relative;
    z-index: 2001 !important;
}

/* Garantir margens adequadas no overlay para telas menores */
@media (max-width: 767px) {
    .modal-overlay {
        padding: 15px;
        align-items: flex-start;
        padding-top: 20px;
    }

    /* Reduz o espaço acima do modal de postagem completa (distância do topo da tela) */
    #modal-postagem-completa.modal-overlay {
        padding-top: 4px !important;
    }

    /* Em telas menores, o modal grande não pode "cortar": limita pela altura da tela e permite rolagem interna */
    .modal-overlay .modal-content.modal-grande {
        max-height: calc(100dvh - 16px) !important;
        overflow-y: auto !important;
        overflow-x: hidden !important;
    }

    /* Modal de postagem completa: não rolar o "container" (rola só a lista de comentários interna) */
    #modal-postagem-completa.modal-overlay {
        overflow: hidden !important;
    }
    #modal-postagem-completa .modal-content.modal-grande {
        overflow: hidden !important;
    }
}

@media (max-width: 480px) {
    .modal-overlay {
        padding: 10px;
        padding-top: 15px !important;
    }

    /* Ainda menor em telas bem pequenas */
    #modal-postagem-completa.modal-overlay {
        padding-top: 3px !important;
    }

    .modal-overlay .modal-content.modal-grande {
        max-height: calc(100dvh - 12px) !important;
    }
}
.modal-content { background-color: var(--bg-secondary); padding: 30px; border-radius: 10px; text-align: center; box-shadow: 0 5px 15px rgba(0, 0, 0, 0.3); max-width: 400px; width: 90%; max-height: none !important; overflow-y: visible !important; height: auto !important; overflow: visible !important; box-sizing: border-box; }
.modal-grande { max-width: 500px; text-align: left; }

/* Reduzir largura do modal de postagem em todas as telas */
#modal-postagem-completa .modal-content.modal-grande {
    max-width: 500px !important;
    width: 500px !important;
}

/* Em telas maiores, o overlay usa align-items:flex-start e o modal pode ficar "alto".
   Empurra a caixa um pouco para baixo só no modal de postagem completa. */
@media (min-width: 1024px) {
    #modal-postagem-completa.modal-overlay {
        padding-top: 120px;
    }
}

/* Tablets */
@media (min-width: 768px) and (max-width: 1023px) {
    #modal-postagem-completa .modal-content.modal-grande {
        max-width: 480px !important;
        width: 480px !important;
    }
}

/* Reduzir bastante a largura do modal em telas menores */
@media (max-width: 767px) {
    .modal-grande {
        max-width: 75vw !important;
        width: 75vw !important;
    }
    
    #modal-postagem-completa .modal-content.modal-grande {
        max-width: 75vw !important;
        width: 75vw !important;
        /* reduz um pouco a parte de baixo (altura visual) em telas menores */
        padding: 2px 12px 0 !important;
        margin: 0 auto;                                                  
        border-radius: 12px;
        box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
    }

    /* Aumenta o espaço interno da postagem (article.post) no modal em telas menores */
    #modal-postagem-completa article.post {
        padding: 18px !important;
    }
}

@media (max-width: 480px) {
    .modal-grande {
        max-width: 80vw !important;
        width: 80vw !important;
    }
    
    #modal-postagem-completa .modal-content.modal-grande {
        max-width: 80vw !important;
        width: 80vw !important;
        /* reduz um pouco a parte de baixo (altura visual) em telas menores */
        padding: 2px 10px 0 !important;
        margin: 0 auto;
        border-radius: 12px;
        box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
    }

    #modal-postagem-completa article.post {
        padding: 16px !important;
    }
}

@media (max-width: 360px) {
    .modal-grande {
        max-width: 85vw !important;
        width: 85vw !important;
    }
    
    #modal-postagem-completa .modal-content.modal-grande {
        max-width: 85vw !important;
        width: 85vw !important;
        /* reduz um pouco a parte de baixo (altura visual) em telas menores */
        padding: 1px 8px 0 !important;
        margin: 0 auto;
        border-radius: 10px;
        box-shadow: 0 6px 20px rgba(0, 0, 0, 0.4);
    }

    #modal-postagem-completa article.post {
        padding: 14px !important;
    }
}
.modal-grande h2 { text-align: center; margin-bottom: 20px; color: var(--text-primary); }
.modal-grande .form-group { margin-bottom: 15px; }
.modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
}
.modal-grande .form-group label { display: block; margin-bottom: 5px; color: var(--text-primary); font-weight: bold; }
.modal-grande .form-group input,
.modal-grande .form-group select,
.modal-grande .form-group textarea { width: 100%; padding: 10px; border: 1px solid var(--border-color); border-radius: 5px; font-size: 14px; background: var(--bg-primary); color: var(--text-primary); }
.modal-grande .form-group textarea { min-height: 80px; resize: vertical; } 
.modal-content h3 { margin-bottom: 25px; color: var(--text-primary); } 
.modal-buttons { display: flex; justify-content: center; gap: 15px; }
.modal-buttons button { padding: 10px 25px; border: none; border-radius: 5px; cursor: pointer; font-size: 1em; transition: background-color 0.2s; }
.btn-confirm-yes { background-color: #dc3545; color: white; }
.btn-confirm-yes:hover { background-color: #c82333; }
.btn-confirm-no { background-color: #6c757d; color: white; }
.btn-confirm-no:hover { background-color: #5a6268; }
.hidden { display: none !important; }

/* Exceção para modal de imagem - deve aparecer quando não tiver classe hidden E tiver display flex no style */
#image-modal-pedido:not(.hidden)[style*="display: flex"],
.image-modal-overlay:not(.hidden)[style*="display: flex"] {
    display: flex !important;
    opacity: 1 !important;
    visibility: visible !important;
}

/* Dropdown compacto de notificações no header */
#modal-notificacoes.modal-overlay {
    /* Remove o fundo escuro e deixa o overlay em tela cheia,
       mas o conteúdo será empurrado para baixo do cabeçalho */
    background-color: transparent;
    justify-content: flex-end;
    align-items: flex-start;
    top: 0;
    height: 100%;
    padding-top: 0;
    z-index: 1700; /* abaixo do header e da barra inferior */
}

#modal-notificacoes .modal-content.modal-grande {
    max-width: 360px;
    width: 360px;
    max-height: 420px;
    text-align: left;
    padding: 15px 15px 10px;
    margin-top: 110px; /* desce mais a caixinha em relação ao cabeçalho */
    overflow: hidden; /* Remove barra de rolagem externa */
    display: flex;
    flex-direction: column;
    /* Fundo da caixa de notificações: diferente dos cards */
    background: var(--bg-secondary);
}

/* Ajuste extra para telas bem estreitas: empurra um pouco mais para baixo */
@media (max-width: 480px) {
    #modal-notificacoes .modal-content.modal-grande {
        margin-top: 115px;
    }
}

#lista-notificacoes {
    max-height: 340px;
    overflow-y: scroll; /* deixa a barra sempre visível (onde suportado) */
    overflow-x: hidden;
    flex: 1; /* Ocupa o espaço disponível */
    padding: 10px; /* Mesmo padding do lista-propostas */
    scrollbar-gutter: stable;
}

/* Estilização da barra de rolagem para #lista-notificacoes - igual ao destaques-scroll */
#lista-notificacoes::-webkit-scrollbar {
    width: 6px;
    height: 6px;
}

#lista-notificacoes::-webkit-scrollbar-track {
    background: transparent;
    border-radius: 10px;
}

#lista-notificacoes::-webkit-scrollbar-thumb {
    /* Tema claro: thumb escuro; no tema escuro sobrescrevemos abaixo */
    background: rgba(0, 0, 0, 0.25);
    border-radius: 10px;
    transition: background 0.2s;
}

#lista-notificacoes::-webkit-scrollbar-thumb:hover {
    background: rgba(0, 0, 0, 0.4);
}

/* Para Firefox */
#lista-notificacoes {
    scrollbar-width: thin;
    scrollbar-color: rgba(0, 0, 0, 0.25) transparent;
}

/* Tema escuro: thumb claro (mantém o visual original) */
html.dark-mode #lista-notificacoes::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.3);
}

html.dark-mode #lista-notificacoes::-webkit-scrollbar-thumb:hover {
    background: rgba(255, 255, 255, 0.5);
}

html.dark-mode #lista-notificacoes {
    scrollbar-color: rgba(255, 255, 255, 0.3) transparent;
}

/* Botão lixeira menor - quadrado */
.btn-lixeira {
    background-color: transparent;
    color: #dc3545;
    border: none;
    border-radius: 4px;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background-color 0.2s;
    padding: 0;
    font-size: 14px;
    z-index: 10;
}

.btn-lixeira:hover {
    background-color: rgba(220, 53, 69, 0.10);
}

.btn-lixeira.modo-selecao {
    background-color: rgba(220, 53, 69, 0.10);
}

.btn-lixeira i {
    color: #dc3545;
}

/* Notificações em tela cheia em telas menores (abaixo do cabeçalho) */
@media (max-width: 992px) {
    #modal-notificacoes.modal-overlay {
        background-color: rgba(0, 0, 0, 0.6);
        position: fixed;
        inset: var(--header-height, 70px) 0 0 0; /* abaixo do header */
        padding: 0 !important; /* sobrescreve padding padrão do .modal-overlay */
        margin: 0;
        justify-content: flex-start !important;
        align-items: stretch !important;
        z-index: 1700 !important; /* header e barra inferior ficam acima */
        overflow: hidden !important; /* evita scroll duplo do overlay */
    }

    #modal-notificacoes .modal-content.modal-grande {
        width: 100vw !important;
        max-width: none !important;
        height: 100% !important;
        max-height: none !important;
        margin: 0 !important;
        border-radius: 0 !important;
        padding: 10px 10px 8px !important;
        box-sizing: border-box !important;
        display: flex !important;
        flex-direction: column !important;
    }

    #lista-notificacoes {
        max-height: none;
        flex: 1 1 auto !important;
        min-height: 0 !important; /* CRÍTICO: permite scroll sem “cortar” */
        overflow-y: auto !important;
        overflow-x: hidden !important;
        padding: 6px 6px 12px !important; /* respiro em cima/baixo */
        overscroll-behavior: contain;
    }
}

/* Em mobile, não deixa notificações cobrir a barra inferior */
@media (max-width: 768px) {
    #modal-notificacoes.modal-overlay {
        inset: var(--header-height, 70px) 0 var(--bottom-nav-height) 0; /* recorta topo e base */
    }
}

/* Compacta as notificações para caber mais itens */
@media (max-width: 992px) {
    #lista-notificacoes {
        padding: 6px !important;
    }

    .notificacao-card {
        padding: 8px !important;
        margin-bottom: 5px !important;
        border-radius: 6px !important;
        border-left-width: 2px !important;
    }

    /* Override de estilos inline (HTML das notificações usa style="...") */
    .notificacao-card > div {
        gap: 10px !important;
    }

    .notificacao-card > div > div:first-child {
        font-size: 18px !important;
        line-height: 1 !important;
    }

    .notificacao-card strong {
        font-size: 12px !important;
        line-height: 1.12 !important;
    }

    .notificacao-card p {
        margin: 3px 0 !important;
        font-size: 12px !important;
        line-height: 1.15 !important;
    }

    .notificacao-card small {
        font-size: 11px !important;
        line-height: 1.1 !important;
    }
}

/* Checkbox nas notificações */
.notificacao-card.modo-selecao {
    cursor: pointer;
    position: relative;
}

.notificacao-card.modo-selecao::before {
    content: '';
    position: absolute;
    left: 10px;
    top: 50%;
    transform: translateY(-50%);
    width: 18px;
    height: 18px;
    border: 2px solid var(--text-secondary);
    border-radius: 3px;
    background-color: var(--bg-secondary);
    z-index: 1;
    box-sizing: border-box;
}

.notificacao-card.modo-selecao.selecionada::before {
    background-color: #4CAF50;
    border-color: #4CAF50;
}

.notificacao-card.modo-selecao.selecionada::after {
    content: '✓';
    position: absolute;
    left: 10px;
    top: 50%;
    transform: translateY(-50%);
    color: white;
    font-size: 12px;
    font-weight: bold;
    width: 18px;
    height: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 2;
    line-height: 1;
    padding: 0;
    margin: 0;
}

/* Esconde o botão antigo de "Marcar todas como lidas" (agora é automático ao abrir) */
#btn-marcar-todas-lidas {
    display: none;
}

/* Modal de confirmação menor e central */
.modal-confirmacao {
    max-width: 450px;
    padding: 25px;
    text-align: center;
}

.modal-confirmacao h3 {
    margin: 0 0 15px 0;
    color: var(--text-primary);
    font-size: 20px;
    font-weight: 600;
}

.modal-confirmacao #confirmacao-texto {
    color: var(--text-secondary);
    font-size: 15px;
    line-height: 1.5;
    margin-bottom: 20px;
}

.modal-confirmacao .modal-buttons {
    display: flex;
    gap: 12px;
    justify-content: center;
    margin-top: 20px;
}

.modal-confirmacao .btn-confirm-yes,
.modal-confirmacao .btn-confirm-no {
    padding: 10px 24px;
    border: none;
    border-radius: 6px;
    font-size: 15px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
    min-width: 120px;
}

.modal-confirmacao .btn-confirm-yes {
    background-color: #dc3545;
    color: white;
}

.modal-confirmacao .btn-confirm-yes:hover {
    background-color: #c82333;
    transform: translateY(-1px);
    box-shadow: 0 4px 8px rgba(220, 53, 69, 0.3);
}

.modal-confirmacao .btn-confirm-no {
    background-color: #6c757d;
    color: white;
}

.modal-confirmacao .btn-confirm-no:hover {
    background-color: #5a6268;
    transform: translateY(-1px);
    box-shadow: 0 4px 8px rgba(108, 117, 125, 0.3);
}

.modal-confirmacao #confirmacao-motivo-group {
    text-align: left;
    margin-bottom: 20px;
}

.modal-confirmacao #confirmacao-motivo-group label {
    display: block;
    margin-bottom: 8px;
    color: var(--text-primary);
    font-weight: 500;
    font-size: 14px;
}

.modal-confirmacao #confirmacao-motivo {
    width: 100%;
    padding: 10px;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    background-color: var(--bg-input);
    color: var(--text-primary);
    font-size: 14px;
    resize: vertical;
    min-height: 80px;
    font-family: inherit;
}

/* Estilização do modal de aviso customizado */
#modal-aviso-notificacoes .modal-content {
    /* Mantém um cinza suave no tema claro; no tema escuro continua escuro via variáveis */
    background-color: var(--bg-comment);
    border-radius: 12px;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
}

#modal-aviso-notificacoes #modal-aviso-icon {
    font-size: 48px;
    margin-bottom: 15px;
    display: block;
}

#modal-aviso-notificacoes #modal-aviso-titulo {
    font-size: 20px;
    font-weight: 600;
    margin: 0 0 15px 0;
    color: var(--text-primary);
}

#modal-aviso-notificacoes #modal-aviso-mensagem {
    font-size: 15px;
    line-height: 1.6;
    margin: 0 0 25px 0;
    color: var(--text-secondary);
    padding: 0 10px;
}

#modal-aviso-notificacoes #modal-aviso-btn-ok,
#modal-aviso-notificacoes #modal-aviso-btn-cancelar {
    min-width: 100px;
    padding: 10px 24px;
    font-size: 15px;
    border-radius: 8px;
    transition: all 0.2s;
}

#modal-aviso-notificacoes #modal-aviso-btn-ok:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
}

#modal-aviso-notificacoes #modal-aviso-btn-cancelar:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
}

/* Layout compacto do formulário de pedido urgente */
.pedido-form-grid {
    display: grid;
    grid-template-columns: 1.1fr 1fr;
    gap: 20px;
    align-items: flex-start;
}

/* Aviso de localização incompleta */
#aviso-localizacao-incompleta {
    background: #fff3cd;
    border: 1px solid #ffc107;
    border-radius: 4px;
    padding: 6px 10px;
    margin-bottom: 10px;
    color: #856404;
    font-size: 12px;
    animation: slideDown 0.3s ease-out;
    line-height: 1.4;
}

html.dark-mode #aviso-localizacao-incompleta {
    background: rgba(255, 193, 7, 0.15);
    border-color: #ffc107;
    color: #ffc107;
}

#aviso-localizacao-incompleta strong {
    display: block;
    margin-bottom: 3px;
    font-size: 12px;
    font-weight: 600;
}

#aviso-localizacao-incompleta i {
    font-size: 11px;
}

#campos-faltantes {
    margin-top: 4px;
    font-size: 11px;
    opacity: 0.9;
}

@keyframes slideDown {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.pedido-form-col .form-group {
    margin-bottom: 10px;
}

/* Área de fotos do pedido urgente */
.pedido-fotos-wrapper {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    flex-wrap: wrap;
}

.pedido-fotos-container {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    max-width: 100%;
    overflow: visible !important;
    overflow-x: visible !important;
    overflow-y: visible !important;
}

/* Remover rolagem das fotos em telas menores */
@media (max-width: 1023px) {
    .pedido-fotos-container {
        overflow: visible !important;
        overflow-x: visible !important;
        overflow-y: visible !important;
        max-height: none !important;
        height: auto !important;
    }
}

.pedido-foto-item {
    position: relative;
    width: 90px;
    height: 90px;
    border-radius: 8px;
    border: 2px solid var(--border-color);
    overflow: hidden;
    flex-shrink: 0;
}

.pedido-foto-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.pedido-foto-remove {
    position: absolute;
    top: 4px;
    right: 4px;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    border: none;
    background: #dc3545;
    color: #fff;
    font-size: 12px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
}

.pedido-foto-principal-btn,
.pedido-foto-add-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 6px 10px;
    font-size: 13px;
}

.pedido-foto-add-btn i {
    margin: 0;
}

/* Estilo transparente para o botão de adicionar mais imagens (combina com “Adicionar Projeto”) */
.pedido-foto-add-btn {
    background: transparent;
    border: none;
    color: var(--text-secondary);
}

.pedido-foto-add-btn:hover {
    color: var(--btn-filter-active-bg);
}

/* "+" maior no botão de adicionar foto do pedido */
#btn-adicionar-foto-pedido.pedido-foto-add-btn i {
    font-size: 22px;
    line-height: 1;
    transform: translateY(3px); /* desce só o "+" sem mudar tamanho */
}

/* Ajuste fino: “desce” o botão sem aumentar a altura total */
#btn-adicionar-foto-pedido.pedido-foto-add-btn {
    padding-top: 11px;  /* mantém área de toque */
    padding-bottom: 1px;
}

/* Área de fotos na criação de publicação do feed */
.post-fotos-wrapper {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.post-fotos-container {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    max-width: 100%;
}

.post-foto-item {
    position: relative;
    width: 85px;
    height: 85px;
    border-radius: 8px;
    border: 2px solid var(--border-color);
    overflow: hidden;
    flex-shrink: 0;
}

.post-foto-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.post-foto-remove {
    position: absolute;
    top: 3px;
    right: 3px;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    border: none;
    background: #dc3545;
    color: #fff;
    font-size: 11px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
}

.post-foto-principal-btn {
    /* Reaproveita visual do botão de upload (apenas ícone de câmera) */
    width: 40px;
    height: 40px;
    min-width: 40px;
    min-height: 40px;
    padding: 0 !important;
    border-radius: 50%;
    font-size: 24px;
    line-height: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    aspect-ratio: 1 / 1;
    flex: 0 0 auto;
}
.post-foto-principal-btn i {
    font-size: 24px;
    line-height: 1;
}

.post-foto-add-btn {
    background: transparent;
    border: 1px dashed var(--border-color);
    color: var(--text-secondary);
    padding: 6px 10px;
    border-radius: 6px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.post-foto-add-btn:hover {
    border-color: var(--btn-filter-active-bg);
    color: var(--btn-filter-active-bg);
}

@media (max-width: 900px) {
    .pedido-form-grid {
        grid-template-columns: 1fr;
    }
}

/* Telas grandes (desktop) - 993px em diante */
@media (min-width: 993px) {
    .conteudo {
        padding: 25px 15px;
        gap: 15px;
        max-width: 1400px;
        box-sizing: border-box;
        overflow-x: hidden;
    }
    .categorias {
        flex-basis: 250px;
        flex-shrink: 1;
        min-width: 220px;
        padding: 18px;
        box-sizing: border-box;
        top: 1px;
        display: block !important;
        position: sticky !important;
    }
    .mobile-sidebar-toggle {
        display: none !important;
    }
    .mobile-sidebar-close {
        display: none !important;
    }
    main {
        flex: 1 1 auto;
        min-width: 520px;
        max-width: 850px;
        box-sizing: border-box;
    }
    .anuncio {
        flex: 0 1 auto;
        flex-shrink: 1;
        width: min(360px, 100%);
        min-width: 240px;
        max-width: 360px;
        box-sizing: border-box;
    }
}

/* Ajuste para telas grandes mas mais estreitas - garante que tudo caiba */
@media (min-width: 993px) and (max-width: 1200px) {
    .conteudo {
        padding: 20px 15px;
        gap: 15px;
    }
    .categorias {
        min-width: 210px;
        padding: 15px;
    }
    main {
        min-width: 500px;
    }
    .anuncio {
        min-width: 220px;
    }
}

/* Telas médias (tablet) - 769px até 992px */
@media (min-width: 769px) and (max-width: 992px) {
    .conteudo {
        flex-direction: column;
        align-items: center;
        margin-top: 80px;
        padding: 20px 15px;
        gap: 20px;
        max-width: 100%;
        width: 100%;
        box-sizing: border-box;
        overflow-x: hidden;
    }
    .anuncio {
        width: 100%;
        max-width: 100%;
        margin-bottom: 25px;
        position: static;
        top: auto;
        box-sizing: border-box;
        overflow-x: hidden;
    }
    main {
        width: 100%;
        max-width: 100%;
        box-sizing: border-box;
        overflow-x: hidden;
    }
    
    /* Ajustes nos filtros para telas médias - dropdown ao lado dos destaques */
    .top-strip {
        display: flex !important;
        align-items: flex-start !important;
        gap: 8px !important;
        margin-bottom: 12px !important;
        position: relative !important;
    }
    
    .top-strip .mobile-sidebar-toggle {
        order: 1 !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        width: 44px !important;
        height: 44px !important;
        border-radius: 50% !important;
        background: var(--bg-secondary) !important;
        border: 1px solid var(--border-color) !important;
        color: var(--text-primary) !important;
        cursor: pointer !important;
        flex-shrink: 0 !important;
        margin: 0 !important;
        margin-top: 0 !important;
        transition: all 0.2s ease !important;
        position: relative !important;
        align-self: flex-start !important;
    }
    
    .top-strip .barra-destaques {
        order: 2 !important;
        flex: 1 1 auto !important;
        align-self: flex-start !important;
    }
    
    .top-strip .mobile-sidebar-toggle:hover {
        background: var(--bg-hover) !important;
        transform: scale(1.05) !important;
    }
    
    .top-strip .barra-destaques {
        order: 2 !important;
        flex: 1 1 auto !important;
    }
    
    /* Dropdown de filtros posicionado abaixo do botão */
    .categorias {
        display: none !important;
        position: fixed !important;
        width: auto !important;
        min-width: 320px !important;
        max-width: 400px !important;
        margin: 0 !important;
        z-index: 9999 !important;
        box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3) !important;
        border-radius: 8px !important;
        padding: 12px !important;
        background: var(--bg-secondary) !important;
        border: 1px solid var(--border-color) !important;
        max-height: calc(100vh - 200px) !important;
        overflow-y: auto !important;
        transform: none !important;
        flex-basis: auto !important;
        flex-shrink: 0 !important;
        height: auto !important;
        visibility: hidden !important;
        opacity: 0 !important;
        pointer-events: none !important;
    }
    
    .categorias.aberta {
        display: block !important;
        visibility: visible !important;
        opacity: 1 !important;
        pointer-events: auto !important;
    }
    
    /* Esconder backdrop em telas médias (não precisa) */
    #mobile-sidebar-backdrop {
        display: none !important;
    }
    
    /* Estilo compacto para o dropdown */
    .categorias h2 {
        font-size: 1.2em !important;
        margin-bottom: 8px !important;
        padding-bottom: 8px !important;
        border-bottom: 1px solid var(--border-color) !important;
    }
    
    .categorias p {
        font-size: 12px !important;
        margin-bottom: 10px !important;
    }
    
    .filtro-botoes {
        flex-direction: column !important;
        gap: 6px !important;
        margin-bottom: 12px !important;
    }
    
    .filtro-btn {
        width: 100% !important;
        padding: 8px 10px !important;
        font-size: 13px !important;
        min-width: auto !important;
        max-width: 100% !important;
    }
    
    .filtro-localizacao {
        display: flex !important;
        flex-direction: column !important;
        gap: 8px !important;
        padding-top: 12px !important;
        border-top: 1px solid var(--border-color) !important;
    }
    
    .filtro-localizacao h4 {
        display: block !important;
        font-size: 13px !important;
        margin-bottom: 4px !important;
    }
    
    #filtro-cidade {
        width: 100% !important;
        margin-bottom: 0 !important;
        padding: 8px !important;
    }
    
    /* Ajuste: só força 100% no botão dentro do sidebar antigo (.filtro-localizacao), não no .feed-filtros */
    .filtro-localizacao #filtro-cidade-btn {
        width: 100% !important;
        padding: 8px !important;
    }
    
    /* Garante que o botão dentro de .feed-filtros mantenha largura automática */
    .feed-filtros #filtro-cidade-btn {
        width: auto !important;
    }
    
    .filtro-acoes-rapidas {
        display: flex !important;
        flex-direction: column !important;
        gap: 8px !important;
        margin-top: 12px !important;
        padding-top: 12px !important;
        border-top: 1px solid var(--border-color) !important;
    }
    
    .filtro-acoes-rapidas h4 {
        font-size: 13px !important;
        margin-bottom: 4px !important;
    }
    
    .filtro-acoes-rapidas > button {
        width: 100% !important;
    }
    
    .btn-preciso-agora-lateral,
    .btn-acao-lateral {
        width: 100% !important;
        padding: 8px 12px !important;
        font-size: 13px !important;
    }
    
    .filtro-times-locais {
        display: flex !important;
        flex-direction: column !important;
        gap: 8px !important;
        margin-top: 12px !important;
        padding-top: 12px !important;
        border-top: 1px solid var(--border-color) !important;
    }
    
    .filtro-times-locais .section-header-lateral {
        flex-direction: row !important;
        align-items: center !important;
        justify-content: space-between !important;
        margin-bottom: 4px !important;
    }
    
    .filtro-times-locais .section-header-lateral h4 {
        font-size: 13px !important;
        margin-bottom: 0 !important;
    }
    
    .filtro-times-locais .times-container-lateral {
        width: 100% !important;
    }
    
    .filtro-configuracoes {
        margin-top: 12px !important;
        padding-top: 12px !important;
        border-top: 1px solid var(--border-color) !important;
        padding-bottom: 8px !important;
    }
    
    .filtro-configuracoes h4 {
        font-size: 13px !important;
        margin-bottom: 8px !important;
    }
    
    .filtro-config-btn {
        padding: 6px 8px !important;
        font-size: 13px !important;
    }
    
    .mobile-sidebar-close {
        display: block !important;
        position: absolute !important;
        top: 8px !important;
        right: 8px !important;
        width: 28px !important;
        height: 28px !important;
        border-radius: 50% !important;
        background: var(--bg-hover) !important;
        border: 1px solid var(--border-color) !important;
        color: var(--text-primary) !important;
        font-size: 18px !important;
        line-height: 1 !important;
        padding: 0 !important;
        cursor: pointer !important;
    }
}

/* =========================================================
   Feed: Configurações no menu lateral
   - Mobile (<=768): NÃO mostra (usa barra inferior)
   - Tablet/Desktop (>=769): MOSTRA
   Colocado aqui para não ser sobrescrito por outras regras.
   ========================================================= */
@media (max-width: 768px) {
    .categorias .filtro-configuracoes {
        display: none !important;
    }
}

@media (min-width: 769px) {
    .categorias .filtro-configuracoes {
        display: block !important;
    }
}

/* Telas pequenas (mobile) - até 768px */
@media (max-width: 768px) {
    header {
        flex-wrap: wrap;
        padding: 12px 12px;
        min-height: 96px;
        gap: 8px;
        align-items: center; /* Logo e avatar alinhados pela linha central */
    }

    .logo-box {
        margin-right: auto;
        order: 1;
    }

    /* Linha extra embaixo: barra de busca (quando aberta) */
    .header-actions {
        order: 3;
        width: 100%;
        display: none; /* no mobile, só aparece quando abrir a busca */
        align-items: center;
        justify-content: center;
        gap: 8px;
        margin-top: 6px;
    }

    header.search-open .header-actions {
        display: flex;
    }

    /* Campo de busca aparece entre a lupa e o sino */
    .search {
        order: 1;
        flex: 1;
        max-width: none;
        margin: 0;
        display: none;
    }

    header.search-open .header-actions .search {
        display: block;
    }

    .user-info {
        gap: 8px;
        flex-wrap: wrap;
        justify-content: flex-end;
        order: 2; /* Linha de cima, à direita */
    }

    #user-name-header {
        display: none;
    }

    /* Limpa o topo no mobile (lupa/sino saem do header) */
    .search-toggle,
    #notificacoes-container {
        display: none !important;
    }

    /* Remove o botão superior de menu no mobile (vai virar botão na barra inferior) */
    .mobile-sidebar-toggle {
        display: none !important;
    }

    /* Barra inferior fixa (mobile) */
    .mobile-bottom-nav {
        display: flex;
    }

    /* Espaço para não cobrir o fim do feed */
    body {
        padding-bottom: 68px;
    }

    .conteudo {
        /* Sempre respeita a altura real do header */
        margin-top: calc(var(--header-height, 92px) + 2px);
        flex-direction: column;
        padding: 10px 0 !important;
        max-width: 100% !important;
        width: 100% !important;
        box-sizing: border-box;
        overflow-x: hidden !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
    }

    /* Com --header-height atualizado via JS, não precisa de offset fixo aqui */
    header.search-open ~ .conteudo { margin-top: calc(var(--header-height, 92px) + 2px); }
    
    main {
        width: 100% !important;
        max-width: 100% !important;
        padding: 0 !important;
        margin: 0 !important;
        box-sizing: border-box;
        overflow-x: hidden !important;
    }
    
    .top-strip {
        width: 100% !important;
        max-width: 100% !important;
        box-sizing: border-box;
        overflow-x: hidden !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        padding: 0 8px !important;
    }
    
    .barra-destaques {
        width: 100% !important;
        max-width: 100% !important;
        box-sizing: border-box;
        overflow-x: hidden !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        padding-left: 8px !important;
        padding-right: 8px !important;
    }
    
    .destaques-scroll {
        width: 100% !important;
        max-width: 100% !important;
        box-sizing: border-box;
    }

    .categorias,
    .anuncio {
        width: 100%;
        position: static;
        top: auto;
        max-width: 100%;
        margin-bottom: 15px;
        box-sizing: border-box;
    }

    /* Aside vira painel sobreposto quando aberto pelo botão flutuante */
    .categorias {
        display: none;
        position: fixed;
        inset: var(--header-height, 70px) 0 var(--bottom-nav-height, 56px) 0; /* abaixo do header e acima da barra inferior */
        z-index: 900; /* abaixo dos modais (1000) para que eles apareçam por cima */
        max-width: none;
        border-radius: 0;
        overflow-y: auto;
        height: calc(100dvh - var(--header-height, 70px) - var(--bottom-nav-height, 56px));
        padding-top: 40px; /* espaço para o botão X */
        overscroll-behavior: contain;
    }

    .categorias.aberta {
        display: block;
    }

    /* Backdrop também respeita a barra inferior */
    #mobile-sidebar-backdrop {
        inset: var(--header-height, 70px) 0 var(--bottom-nav-height, 56px) 0;
    }

    .mobile-sidebar-toggle {
        display: flex;
        align-self: flex-start;
        margin: 0 0 10px 0;
        z-index: 1;
    }

    .mobile-sidebar-close {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        top: 45px;   /* desce mais o X para ficar abaixo da parte superior do painel */
        right: 15px; /* afasta um pouco da borda direita */
    }

    .publicar,
    .post {
        padding: 15px 10px !important;
        max-width: calc(100% - 4px) !important;
        width: calc(100% - 4px) !important;
        box-sizing: border-box;
        overflow-x: hidden !important;
        margin-left: 2px !important;
        margin-right: 2px !important;
    }
    
    .publicar *,
    .post * {
        max-width: 100% !important;
        box-sizing: border-box;
    }
    
    .post-header {
        width: 100% !important;
        max-width: 100% !important;
        box-sizing: border-box;
        overflow-x: hidden !important;
    }
    
    .post-content {
        max-width: 100% !important;
        word-wrap: break-word;
        overflow-wrap: break-word;
        box-sizing: border-box;
        overflow-x: hidden !important;
    }
    
    .post-image,
    .post-video {
        max-width: 100% !important;
        width: 100% !important;
        height: auto !important;
        box-sizing: border-box;
    }
    
    .post-actions {
        width: 100% !important;
        max-width: 100% !important;
        box-sizing: border-box;
        overflow-x: hidden !important;
        flex-wrap: wrap !important;
        gap: 8px !important;
    }
    
    .action-btn {
        flex-shrink: 1 !important;
        min-width: auto !important;
        padding: 8px 10px !important;
        font-size: 13px !important;
    }

    /* Em telas menores, manter os botões fixos nos cantos da área (como em telas maiores) */
    .botoes-postar {
        flex-direction: row !important;
        justify-content: space-between !important;
        align-items: center !important;
        gap: 8px !important;
        flex-wrap: wrap !important;
        width: 100% !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
    }

    .upload-area {
        width: auto !important;
        flex-shrink: 0 !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
    }

    .upload-button {
        flex-shrink: 0 !important;
        min-width: 38px !important;
        max-width: 38px !important;
        width: 38px !important;
    }

    .btn-enviar {
        flex-shrink: 1 !important;
        min-width: auto !important;
        padding: 10px 15px !important;
        font-size: 0.9em !important;
        white-space: nowrap !important;
    }
    
    .post-fotos-wrapper {
        max-width: 100% !important;
        box-sizing: border-box !important;
        overflow-x: hidden !important;
    }
    
    textarea#post-content-input {
        width: 100% !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
        padding: 10px 8px !important;
        overflow-x: hidden !important;
    }
    
    .publicar h2 {
        max-width: 100% !important;
        word-wrap: break-word !important;
    }

    .filtro-botoes {
        flex-direction: row;
        flex-wrap: wrap;
        justify-content: center;
    }

    .filtro-btn {
        flex-basis: 45%;
    }

    .post-header .post-avatar {
        width: 40px;
        height: 40px;
    }

    .post-header .user-name {
        font-size: 1em;
    }

    .post-content {
        font-size: 0.95em;
    }

    .modal-content {
        padding: 20px;
        width: 95%;
        max-width: 400px;
    }

    .modal-content h3 {
        font-size: 18px;
    }

    .modal-buttons button {
        padding: 8px 20px;
        font-size: 14px;
    }

    .action-btn {
        padding: 6px 10px;
        font-size: 12px;
    }

    .action-btn i {
        font-size: 14px;
    }
}

@media (max-width: 480px) {
    header {
        padding: 8px 10px;
    }

    .logo-box img {
        width: 58px;
        height: 58px;
    }

    .logo-box h1 {
        font-size: 26px;
    }

    .user-avatar-header {
        width: 68px;
        height: 68px;
    }

    .user-info span {
        font-size: 0.9em;
    }

    #logout-button,
    #profile-button,
    #feed-button {
        padding: 8px 10px;
        font-size: 0.9em;
    }

    .thumb-destaque {
        width: clamp(100px, 28vw, 140px);
        height: clamp(100px, 28vw, 140px);
    }
    
    /* Ajusta fonte da profissão em telas menores */
    .thumb-profissao {
        font-size: 9px;
        padding: 2px 5px;
    }

    /* Importante: não aumentar o campo de busca no mobile */

    .conteudo {
        margin-top: calc(var(--header-height, 92px) + 2px);
        padding: 8px 0 !important;
        max-width: 100% !important;
        width: 100% !important;
        box-sizing: border-box;
        overflow-x: hidden !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
    }

    header.search-open ~ .conteudo {
        margin-top: calc(var(--header-height, 92px) + 2px);
    }
    
    main {
        width: 100% !important;
        max-width: 100% !important;
        padding: 0 !important;
        margin: 0 !important;
        box-sizing: border-box;
        overflow-x: hidden !important;
    }
    
    .top-strip {
        width: 100% !important;
        max-width: 100% !important;
        box-sizing: border-box;
        overflow-x: hidden !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        padding: 0 !important;
    }
    
    .barra-destaques {
        width: 100% !important;
        max-width: 100% !important;
        box-sizing: border-box;
        overflow-x: hidden !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        padding-left: 6px !important;
        padding-right: 6px !important;
    }
    
    .destaques-scroll {
        width: 100% !important;
        max-width: 100% !important;
        box-sizing: border-box;
    }
    
    .publicar {
        width: calc(100% - 4px) !important;
        max-width: calc(100% - 4px) !important;
        margin-left: 2px !important;
        margin-right: 2px !important;
        padding: 15px 8px !important;
        box-sizing: border-box;
        overflow-x: hidden !important;
    }
    
    .publicar * {
        max-width: 100% !important;
        box-sizing: border-box;
    }
    
    .botoes-postar {
        gap: 6px !important;
        flex-wrap: wrap !important;
    }
    
    .btn-enviar {
        padding: 10px 12px !important;
        font-size: 0.85em !important;
    }
    
    .post {
        width: calc(100% - 4px) !important;
        max-width: calc(100% - 4px) !important;
        margin-left: 2px !important;
        margin-right: 2px !important;
        padding: 15px 8px !important;
        box-sizing: border-box;
        overflow-x: hidden !important;
    }
    
    .post * {
        max-width: 100% !important;
        box-sizing: border-box;
    }
    
    .post-header {
        width: 100% !important;
        max-width: 100% !important;
        overflow-x: hidden !important;
        flex-wrap: wrap !important;
        gap: 8px !important;
    }
    
    .post-header .post-meta {
        min-width: 0 !important;
        flex: 1 1 auto !important;
        overflow-x: hidden !important;
    }
    
    .post-header .user-name,
    .post-header .post-date-display {
        word-wrap: break-word !important;
        overflow-wrap: break-word !important;
        max-width: 100% !important;
    }
    
    .post-content {
        width: 100% !important;
        max-width: 100% !important;
        overflow-x: hidden !important;
    }
    
    .post-actions {
        width: 100% !important;
        max-width: 100% !important;
        overflow-x: hidden !important;
        flex-wrap: wrap !important;
        gap: 6px !important;
    }
    
    .action-btn {
        padding: 8px 8px !important;
        font-size: 12px !important;
        flex-shrink: 1 !important;
        min-width: auto !important;
    }
    
    textarea#post-content-input {
        width: 100% !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
        padding: 10px 8px !important;
    }
    
    .botoes-postar {
        width: 100% !important;
        max-width: 100% !important;
        gap: 6px !important;
    }
    
    .btn-enviar {
        padding: 10px 10px !important;
        font-size: 0.8em !important;
        white-space: nowrap !important;
    }

    /* Ajuste específico do modal "Profissionais Próximos" para caber em telas estreitas */
    #modal-preciso-agora .filtro-servico > div {
        flex-direction: column;   /* empilha campo e botão um abaixo do outro */
        align-items: stretch;
    }

    #filtro-tipo-servico {
        width: 100%;
    }

    #modal-preciso-agora .filtro-servico button {
        width: 100%;
        text-align: center;
    }

    .publicar h2 {
        font-size: 1.2em;
    }

    textarea#post-content-input {
        min-height: 60px;
        font-size: 0.9em;
    }

    .upload-button,
    .btn-enviar {
        padding: 8px 12px;
        font-size: 0.9em;
    }

    .form-message {
        font-size: 0.8em;
    }

    .filtro-btn {
        flex-basis: 100%;
    }

    .post-header .user-name {
        font-size: 0.9em;
    }

    .post-content {
        font-size: 0.9em;
    }

    .comment-avatar {
        width: 28px;
        height: 28px;
    }

    .comment-body {
        padding: 6px 10px;
        font-size: 13px;
    }

    .comment-input {
        padding: 6px 10px;
        font-size: 13px;
    }

    .btn-send-comment {
        /* mantém o tamanho do botão (não “espreme” o input) */
        padding: 0;
        font-size: 18px;
        width: 38px;
        height: 38px;
        box-sizing: border-box;
    }
}

/* 🆕 NOVO: Estilos para elementos na lateral */
.filtro-disponibilidade {
    margin-top: 12px;
    padding: 10px 0;
    width: 100%;
    box-sizing: border-box;
}

.filtro-disponibilidade-row {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 8px;
    padding: 6px 0;
    border: none;
    border-radius: 0;
    background: transparent;
}

.filtro-disponibilidade-label {
    color: var(--text-primary);
    font-weight: 700;
    font-size: 14px;
}

/* Toggle verde quando ativo (apenas no bloco de disponibilidade do menu) */
.filtro-disponibilidade-row .switch input:checked + .slider {
    background-color: #28a745;
}

.filtro-acoes-rapidas,
.filtro-times-locais {
    margin-top: 20px;
    padding-top: 20px;
    border-top: 1px solid var(--border-color);
    width: 100%;
    box-sizing: border-box;
    overflow-x: hidden;
}

.filtro-acoes-rapidas h4,
.filtro-times-locais h4 {
    margin-bottom: 10px;
    color: var(--text-primary);
    font-size: 1em;
    word-wrap: break-word;
}

.btn-preciso-agora-lateral {
    background: linear-gradient(135deg, #ff6b6b, #ee5a6f);
    color: white;
    border: none;
    padding: 12px 20px;
    border-radius: 8px;
    font-size: 1em;
    font-weight: bold;
    cursor: pointer;
    box-shadow: 0 2px 8px rgba(255, 107, 107, 0.3);
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    margin: 5px 0;
    box-sizing: border-box;
    word-wrap: break-word;
    white-space: normal;
}

.btn-preciso-agora-lateral:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(255, 107, 107, 0.5);
}

/* Botões de ações rápidas secundários (menos chamativos) */
.btn-acao-lateral {
    background: var(--btn-secondary-bg);
    color: #ffffff;
    border: none;
    padding: 10px 18px;
    border-radius: 8px;
    font-size: 0.95em;
    cursor: pointer;
    transition: all 0.2s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    width: 100%;
    margin: 5px 0;
    box-sizing: border-box;
    word-wrap: break-word;
    white-space: normal;
}

.btn-acao-lateral:hover {
    background: var(--btn-secondary-hover);
    transform: translateY(-1px);
}

.section-header-lateral {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 10px;
}

.btn-criar-time-lateral {
    background: var(--btn-secondary-bg);
    color: white;
    border: none;
    border-radius: 50%;
    width: 30px;
    height: 30px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s;
    font-size: 1.2em;
}

.btn-criar-time-lateral:hover {
    background: var(--btn-secondary-hover);
    transform: scale(1.1);
}

.times-container-lateral {
    max-height: 300px;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

/* Estilização da barra de rolagem para times-container-lateral */
.times-container-lateral::-webkit-scrollbar {
    width: 6px;
    height: 6px;
}

.times-container-lateral::-webkit-scrollbar-track {
    background: var(--bg-primary);
    border-radius: 10px;
}

.times-container-lateral::-webkit-scrollbar-thumb {
    background: rgba(128, 128, 128, 0.4);
    border-radius: 10px;
    transition: background 0.2s;
}

.times-container-lateral::-webkit-scrollbar-thumb:hover {
    background: rgba(92, 184, 92, 0.6);
}

/* Para Firefox */
.times-container-lateral {
    scrollbar-width: thin;
    scrollbar-color: rgba(128, 128, 128, 0.4) var(--bg-primary);
}

.times-container-lateral .time-card {
    padding: 10px;
    font-size: 0.85em;
}

.times-container-lateral .time-header h3 {
    font-size: 0.9em;
}

.modal-large {
    max-width: 700px;
    width: 95%;
    max-height: 90vh;
    overflow-y: auto;
    overflow-x: hidden; /* Garante que o modal não crie rolagem lateral */
}

.modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
    padding-bottom: 15px;
    border-bottom: 2px solid var(--border-color);
}

.modal-header h3 {
    margin: 0;
    color: var(--text-primary);
    display: flex;
    align-items: center;
    gap: 10px;
}

.btn-close-modal {
    background: none;
    border: none;
    font-size: 2em;
    color: var(--text-secondary);
    cursor: pointer;
    padding: 0;
    width: 30px;
    height: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    transition: all 0.2s;
}

.btn-close-modal:hover {
    background: var(--bg-hover);
    color: var(--text-primary);
}

.modal-body {
    text-align: left;
}

/* Ajustes específicos para modal de pedidos urgentes em telas menores */
@media (max-width: 1023px) {
    #modal-pedidos-urgentes-profissional .modal-content.modal-grande {
        max-height: 95vh;
        height: auto;
        min-height: 200px;
        display: flex;
        flex-direction: column;
        overflow: visible;
        padding: 15px;
    }
    
    #modal-pedidos-urgentes-profissional .modal-body {
        flex: 1;
        display: flex;
        flex-direction: column;
        overflow: visible;
        min-height: 0;
        padding: 0;
    }
    
    #modal-pedidos-urgentes-profissional .lista-propostas,
    #modal-pedidos-urgentes-profissional #lista-pedidos-urgentes {
        flex: 1;
        overflow-y: auto;
        overflow-x: hidden;
        min-height: 0;
        padding: 10px;
        box-sizing: border-box;
        max-height: calc(95vh - 200px);
    }
    
    /* Garantir que os cards não ultrapassem o container */
    #modal-pedidos-urgentes-profissional .pedido-urgente-card {
        width: 100%;
        max-width: 100%;
        box-sizing: border-box;
        margin-left: 0;
        margin-right: 0;
    }
}

/* 🆕 Feedback visual (toast) para sucesso */
.toast-sucesso {
    position: fixed;
    top: 80px; /* 70px (header) + 10px (espaçamento) */
    right: 20px;
    background: #28a745;
    color: #fff;
    padding: 12px 18px;
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(0,0,0,0.2);
    display: flex;
    align-items: center;
    gap: 8px;
    opacity: 0;
    transform: translateY(-10px);
    transition: opacity 0.25s ease, transform 0.25s ease;
    z-index: 2000;
    font-size: 14px;
}

/* Ajuste para telas menores */
@media (max-width: 768px) {
    .toast-sucesso {
        top: 80px; /* Mantém abaixo do header em mobile também */
        right: 10px;
        left: 10px;
        max-width: calc(100% - 20px);
    }
}

@media (max-width: 480px) {
    .toast-sucesso {
        top: 80px;
        right: 10px;
        left: 10px;
        max-width: calc(100% - 20px);
        font-size: 13px;
        padding: 10px 15px;
    }
}

.toast-sucesso.show {
    opacity: 1;
    transform: translateY(0);
}

.check-animado {
    display: inline-flex;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    background: #fff;
    color: #28a745;
    align-items: center;
    justify-content: center;
    font-weight: bold;
    animation: pulse-check 0.6s ease-out;
}

@keyframes pulse-check {
    0% { transform: scale(0.4); opacity: 0; }
    60% { transform: scale(1.1); opacity: 1; }
    100% { transform: scale(1); opacity: 1; }
}

/* 🆕 Miniatura e overlay da foto do pedido nas propostas */
.pedido-propostas-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 16px;
    margin-bottom: 16px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--border-color);
}

.pedido-propostas-info p {
    margin: 6px 0 0 0;
}

.pedido-propostas-foto .pedido-foto-miniatura {
    width: 80px;
    height: 80px;
    object-fit: cover;
    border-radius: 6px;
    cursor: pointer;
    border: 2px solid var(--border-color);
}

.imagem-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.75);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 2100;
}

.imagem-overlay-content img {
    max-width: 95vw;
    max-height: 90vh;
    border-radius: 8px;
}

/* 🆕 Estilo para select de tempo de chegada (proposta) - contraste alto */
.select-tempo-chegada {
    width: 100%;
    padding: 12px 44px 12px 12px;
    border-radius: 12px;
    border: 1px solid rgba(255, 255, 255, 0.18);
    background: rgba(255, 255, 255, 0.06);
    color: rgba(255, 255, 255, 0.92);
    outline: none;
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.18);
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    background-image:
        linear-gradient(45deg, transparent 50%, rgba(255,255,255,0.85) 50%),
        linear-gradient(135deg, rgba(255,255,255,0.85) 50%, transparent 50%),
        linear-gradient(to right, rgba(255,255,255,0.10), rgba(255,255,255,0.10));
    background-position:
        calc(100% - 18px) calc(50% - 4px),
        calc(100% - 12px) calc(50% - 4px),
        calc(100% - 36px) 50%;
    background-size:
        6px 6px,
        6px 6px,
        1px 60%;
    background-repeat: no-repeat;
    transition: box-shadow 0.2s ease, transform 0.1s ease, border-color 0.2s ease;
}

.select-tempo-chegada:hover {
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.22);
    transform: translateY(-1px);
}

.select-tempo-chegada:focus {
    border-color: rgba(0, 123, 255, 0.75);
    box-shadow: 0 0 0 3px rgba(0, 123, 255, 0.18), 0 10px 24px rgba(0, 0, 0, 0.22);
}

/* Ajuda na leitura dentro do dropdown nativo (quando o browser permite) */
.select-tempo-chegada option {
    background: #ffffff;
    color: #111111;
}

.filtro-servico {
    display: flex;
    gap: 10px;
    margin-bottom: 20px;
}

.filtro-servico input {
    flex: 1;
    padding: 10px;
    border: 1px solid var(--border-color);
    border-radius: 5px;
    background: var(--bg-input);
    color: var(--text-primary);
}

.filtro-servico button {
    padding: 10px 20px;
    background: var(--btn-secondary-bg);
    color: white;
    border: none;
    border-radius: 5px;
    cursor: pointer;
}

/* "Preciso agora" (Profissionais Próximos): layout mais limpo */
#modal-preciso-agora .filtro-servico {
    display: block; /* evita empurrar o input para a direita */
    margin-bottom: 15px;
    /* Alinha com o card acima (que usa padding: 15px) */
    padding: 0 15px;
}

#modal-preciso-agora .filtro-servico-input-wrap {
    position: relative;
    max-width: 520px; /* reduz um pouco a largura em telas menores */
}

#modal-preciso-agora #filtro-tipo-servico {
    width: 100%;
    padding-right: 42px; /* espaço para a lupa dentro */
}

#modal-preciso-agora .filtro-servico-lupa {
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
    pointer-events: none;
    font-size: 20px;
    line-height: 1;
    /* tenta deixar o emoji mais “branco”/limpo onde suportado */
    filter: grayscale(1) brightness(2.2);
}

@media (max-width: 520px) {
    #modal-preciso-agora .filtro-servico-input-wrap {
        max-width: 460px;
    }
}

.profissionais-lista {
    display: grid;
    gap: 15px;
}

.profissional-card {
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: 10px;
    padding: 15px;
    display: flex;
    gap: 15px;
    transition: all 0.2s;
}

.profissional-card:hover {
    box-shadow: 0 2px 8px var(--shadow-color);
}

.profissional-card.com-selo {
    border: 2px solid #ffc107;
    background: linear-gradient(135deg, var(--bg-secondary), rgba(255, 193, 7, 0.1));
}

.selo-qualidade {
    font-size: 1.2em;
    margin-left: 5px;
}

.badge-mestre {
    font-size: 1.1em;
    margin-left: 5px;
}

.profissional-avatar {
    width: 60px;
    height: 60px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid var(--border-color);
    transition: transform 0.2s ease, opacity 0.2s ease;
    cursor: pointer;
}

.profissional-card a:hover .profissional-avatar {
    transform: scale(1.05);
    opacity: 0.9;
}

.profissional-avatar-link {
    text-decoration: none;
    display: block;
    cursor: pointer;
}

.profissional-nome-link {
    transition: color 0.2s ease;
    color: inherit;
    text-decoration: none;
    cursor: pointer;
    display: inline-block;
}

.profissional-nome-link:hover {
    color: var(--primary-color, #007bff) !important;
    text-decoration: underline;
}

.profissional-info {
    flex: 1;
}

.profissional-info h4 {
    margin: 0 0 8px 0;
    color: var(--text-primary);
}

.profissional-info p {
    margin: 5px 0;
    color: var(--text-secondary);
    font-size: 0.9em;
}

.profissional-info i {
    margin-right: 5px;
    color: var(--text-link);
}

.distancia-info {
    color: var(--btn-primary-bg) !important;
    font-weight: bold;
}

.btn-contatar {
    display: inline-block;
    margin-top: 10px;
    padding: 8px 15px;
    background: #25d366;
    color: white;
    text-decoration: none;
    border-radius: 5px;
    font-size: 0.9em;
    transition: background 0.2s;
}

.btn-contatar:hover {
    background: #20ba5a;
}

/* 🆕 NOVO: Estilos para Times Locais (mantido para compatibilidade, mas agora na lateral) */

.section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
}

.section-header h2 {
    margin: 0;
    color: var(--text-primary);
    display: flex;
    align-items: center;
    gap: 10px;
}

.btn-criar-time {
    padding: 10px 20px;
    background: var(--btn-secondary-bg);
    color: white;
    border: none;
    border-radius: 5px;
    cursor: pointer;
    font-weight: bold;
    transition: background 0.2s;
}

.btn-criar-time:hover {
    background: var(--btn-secondary-hover);
}

.times-container {
    display: grid;
    gap: 15px;
}

.time-card {
    background: var(--bg-primary);
    border: 1px solid var(--border-color);
    border-radius: 10px;
    padding: 20px;
    transition: all 0.2s;
}

.time-card:hover {
    box-shadow: 0 2px 8px var(--shadow-color);
}

.time-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 10px;
}

.time-header h3 {
    margin: 0;
    color: var(--text-primary);
}

.time-status {
    padding: 5px 10px;
    border-radius: 15px;
    font-size: 0.8em;
    font-weight: bold;
    text-transform: capitalize;
}

.status-aberto {
    background: #28a745;
    color: white;
}

.status-em_andamento {
    background: #ffc107;
    color: #333;
}

.status-concluido {
    background: #6c757d;
    color: white;
}

.time-descricao {
    color: var(--text-secondary);
    margin-bottom: 10px;
}

.time-localizacao {
    color: var(--text-secondary);
    margin-bottom: 15px;
    font-size: 0.9em;
}

.time-profissionais {
    margin-bottom: 10px;
}

.time-profissionais ul {
    list-style: none;
    padding-left: 0;
    margin: 5px 0;
}

.time-profissionais li {
    padding: 5px 0;
    color: var(--text-secondary);
}

.time-candidatos {
    margin-bottom: 15px;
    color: var(--text-secondary);
    display: flex;
    align-items: center;
    gap: 8px;
}

.btn-ver-candidatos {
    background: none;
    border: none;
    color: var(--text-secondary);
    padding: 2px;
    cursor: pointer;
    font-size: 14px;
    transition: all 0.2s;
    opacity: 0.7;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: auto;
    height: auto;
}

.btn-ver-candidatos:hover {
    opacity: 1;
    color: var(--btn-primary-bg);
}

/* Estilos do modal de candidatos - dropdown flutuante */
#modal-candidatos-time {
    position: fixed;
    z-index: 10000;
    background: transparent;
    pointer-events: none;
}

#modal-candidatos-time:not(.hidden) {
    pointer-events: auto;
}

#modal-candidatos-time .modal-content {
    position: absolute;
    max-width: 380px;
    width: auto;
    padding: 8px;
    margin: 0;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    border: 1px solid var(--border-color);
}

#modal-candidatos-time .modal-header {
    display: none;
}

#modal-candidatos-time .modal-body {
    max-height: none;
    overflow-y: visible;
    overflow-x: visible;
    padding: 0;
}

/* Em telas menores, mantém como modal centralizado */
@media (max-width: 767px) {
    #modal-candidatos-time {
        position: fixed;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        background: rgba(0, 0, 0, 0.5);
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 20px;
    }
    
    #modal-candidatos-time .modal-content {
        position: relative;
        max-width: 90vw;
        width: 100%;
    }
    
    /* Em telas menores, reorganiza o layout dos candidatos */
    .candidato-item {
        flex-direction: column;
        align-items: flex-start;
        gap: 10px;
    }
    
    .candidato-info {
        width: 100%;
    }
    
    .candidato-acoes {
        width: 100%;
        justify-content: flex-end;
        margin-top: 4px;
    }
}

/* Informações do criador do time no topo do card */
.time-criador-topo {
    margin-bottom: 12px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--border-color);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.criador-time-link {
    display: flex;
    align-items: center;
    gap: 8px;
    text-decoration: none;
    color: var(--text-primary);
    transition: opacity 0.2s;
    width: fit-content;
    flex: 1;
}

.btn-deletar-time {
    background: none;
    border: none;
    color: var(--text-secondary);
    cursor: pointer;
    font-size: 16px;
    padding: 4px 8px;
    border-radius: 4px;
    transition: all 0.2s ease;
    opacity: 0.7;
}

.btn-deletar-time:hover {
    color: #dc3545;
    opacity: 1;
    background: rgba(220, 53, 69, 0.1);
}

.btn-deletar-time:active {
    transform: scale(0.95);
}

.criador-time-link:hover {
    opacity: 0.8;
}

.criador-time-foto {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
}

.criador-time-nome {
    font-weight: 500;
    font-size: 13px;
    color: var(--text-primary);
}

.candidatos-lista {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.candidato-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    background: var(--bg-secondary);
    gap: 10px;
    transition: opacity 0.3s ease, background-color 0.3s ease, box-shadow 0.3s ease;
}

.candidato-item.candidato-destacado {
    background: linear-gradient(135deg, #7394b8 0%, rgba(115, 148, 184, 0.8) 100%);
    box-shadow: 0 0 15px rgba(115, 148, 184, 0.5);
    border-color: #7394b8;
    animation: destacarCandidato 0.6s ease-in-out;
}

html.dark-mode .candidato-item.candidato-destacado {
    background: linear-gradient(135deg, #4599ff 0%, rgba(69, 153, 255, 0.8) 100%);
    box-shadow: 0 0 15px rgba(69, 153, 255, 0.5);
    border-color: #4599ff;
}

@keyframes destacarCandidato {
    0%, 100% {
        transform: scale(1);
    }
    50% {
        transform: scale(1.02);
    }
}

/* Modal de confirmação de deletar time */
.modal-confirmacao-deletar {
    max-width: 200px;
    width: auto;
    padding: 12px 16px;
    background: var(--bg-secondary);
    border-radius: 6px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
    border: 1px solid var(--border-color);
}

.confirmacao-deletar-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    text-align: center;
}

.confirmacao-deletar-mensagem {
    font-size: 14px;
    font-weight: 500;
    color: var(--text-primary);
    margin: 0;
}

.confirmacao-deletar-botoes {
    display: flex;
    gap: 8px;
    width: 100%;
}

.btn-cancelar-deletar,
.btn-confirmar-deletar {
    flex: 1;
    padding: 6px 12px;
    border: none;
    border-radius: 4px;
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
}

.btn-cancelar-deletar {
    background: var(--bg-action);
    color: var(--text-primary);
}

.btn-cancelar-deletar:hover {
    background: var(--bg-action-hover);
}

.btn-confirmar-deletar {
    background: #dc3545;
    color: white;
}

.btn-confirmar-deletar:hover {
    background: #c82333;
}

@media (max-width: 992px) {
    .modal-confirmacao-deletar {
        max-width: 240px;
        padding: 24px 28px;
    }
    
    .confirmacao-deletar-mensagem {
        font-size: 15px;
    }
    
    .confirmacao-deletar-botoes {
        gap: 10px;
    }
    
    .btn-cancelar-deletar,
    .btn-confirmar-deletar {
        padding: 8px 14px;
        font-size: 13px;
    }
}

.candidato-info {
    display: flex;
    align-items: center;
    gap: 10px;
    flex: 1;
    min-width: 0;
}

.candidato-foto {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
}

.candidato-detalhes {
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 0;
    flex: 1;
}

.candidato-nome {
    font-weight: 600;
    color: var(--text-primary);
    text-decoration: none;
    font-size: 13px;
    transition: color 0.2s;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.candidato-nome:hover {
    color: var(--btn-primary-bg);
    text-decoration: underline;
}

.candidato-profissao {
    font-size: 12px;
    color: var(--text-secondary);
}

/* 🆕 NOVO: Estilos para campos de endereço no formulário de criar equipe */
.form-group-cidade-numero-estado {
    display: flex;
    gap: 15px;
    align-items: flex-end;
}

.form-group-inline {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.form-group-inline label {
    font-size: 14px;
    color: var(--text-primary);
    font-weight: 500;
}

.form-group-inline input {
    width: 100%;
    padding: 10px;
    border: 1px solid var(--border-color);
    border-radius: 5px;
    background: var(--bg-input);
    color: var(--text-primary);
    font-size: 14px;
    box-sizing: border-box;
}

.form-group-cidade {
    flex: 1;
}

.form-group-numero {
    flex: 0 0 120px;
    max-width: 120px;
}

.form-group-estado {
    flex: 0 0 80px;
    max-width: 80px;
}

/* Responsivo: em telas menores, cidade em uma linha e número/estado na mesma linha */
@media (max-width: 767px) {
    .form-group-cidade-numero-estado {
        flex-wrap: wrap;
        gap: 10px;
        align-items: flex-end;
    }
    
    .form-group-cidade {
        flex: 1 1 100%;
        max-width: 100%;
        margin-bottom: 0;
    }
    
    .form-group-numero {
        flex: 0 0 100px;
        max-width: 100px;
    }
    
    .form-group-estado {
        flex: 0 0 60px;
        max-width: 60px;
    }
}

.candidato-valor {
    display: flex;
    flex-direction: column;
    gap: 2px;
    margin-top: 4px;
}

.valor-aceito,
.valor-contraproposta {
    font-size: 11px;
    color: var(--text-secondary);
    display: flex;
    align-items: center;
    gap: 4px;
}

.valor-aceito i {
    color: #28a745;
}

.valor-contraproposta i {
    color: #ffc107;
}

.valor-aceito strong,
.valor-contraproposta strong {
    color: var(--text-primary);
    font-weight: 600;
}

.justificativa-contraproposta {
    font-size: 10px;
    color: var(--text-secondary);
    font-style: italic;
    margin-top: 2px;
    padding-left: 16px;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
}

.candidato-acoes {
    display: flex;
    gap: 4px;
    flex-shrink: 0;
}

.btn-aceitar-candidato,
.btn-recusar-candidato,
.btn-confirmar-perfil,
.btn-recusar-perfil {
    padding: 6px 12px;
    border: none;
    border-radius: 6px;
    cursor: pointer;
    font-size: 12px;
    font-weight: 600;
    transition: all 0.2s ease;
    white-space: nowrap;
    display: flex;
    align-items: center;
    gap: 6px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.btn-aceitar-candidato {
    background: var(--btn-primary-bg);
    color: white;
}

.btn-aceitar-candidato:hover {
    background: var(--btn-primary-hover);
    transform: translateY(-1px);
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.15);
}

.btn-confirmar-perfil {
    background: #28a745;
    color: white;
}

.btn-confirmar-perfil:hover {
    background: #218838;
    transform: translateY(-1px);
    box-shadow: 0 4px 6px rgba(40, 167, 69, 0.3);
}

.btn-recusar-candidato,
.btn-recusar-perfil {
    background: #dc3545;
    color: white;
}

.btn-recusar-candidato:hover,
.btn-recusar-perfil:hover {
    background: #c82333;
    transform: translateY(-1px);
    box-shadow: 0 4px 6px rgba(220, 53, 69, 0.3);
}

.btn-candidatar {
    padding: 10px 20px;
    background: var(--btn-primary-bg);
    color: white;
    border: none;
    border-radius: 5px;
    cursor: pointer;
    font-weight: bold;
    transition: all 0.3s ease;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    position: relative;
    overflow: hidden;
}

.btn-candidatar:hover:not(:disabled) {
    background: var(--btn-primary-hover);
    transform: translateY(-1px);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
}

.btn-candidatar:disabled {
    opacity: 0.7;
    cursor: wait;
}

.btn-candidatar i {
    transition: all 0.4s cubic-bezier(0.68, -0.55, 0.265, 1.55);
    display: inline-block;
}

/* Estado candidatado - com joia */
.btn-candidatar.candidatado {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    box-shadow: 0 4px 15px rgba(102, 126, 234, 0.4);
}

.btn-candidatar.candidatado:hover:not(:disabled) {
    background: linear-gradient(135deg, #764ba2 0%, #667eea 100%);
    box-shadow: 0 6px 20px rgba(102, 126, 234, 0.6);
    transform: translateY(-2px);
}

.btn-candidatar.candidatado i.fa-briefcase {
    color: #ffd700;
    text-shadow: 0 0 8px rgba(255, 215, 0, 0.6);
}

/* Animação da bolsa pulsando */
@keyframes bagPulse {
    0% {
        transform: scale(1);
        filter: brightness(1);
    }
    50% {
        transform: scale(1.3);
        filter: brightness(1.5);
        text-shadow: 0 0 15px rgba(255, 215, 0, 1);
    }
    100% {
        transform: scale(1);
        filter: brightness(1);
    }
}

/* Animação contínua sutil da bolsa quando candidatado */
.btn-candidatar.candidatado i.fa-briefcase {
    animation: bagShine 2s ease-in-out infinite;
}

@keyframes bagShine {
    0%, 100% {
        filter: brightness(1);
        text-shadow: 0 0 8px rgba(255, 215, 0, 0.6);
    }
    50% {
        filter: brightness(1.3);
        text-shadow: 0 0 12px rgba(255, 215, 0, 0.9);
    }
}

/* Popup de confirmação de cancelamento */
.popup-confirmacao-cancelar {
    position: absolute;
    z-index: 10000;
    animation: popupFadeIn 0.2s ease;
}

@keyframes popupFadeIn {
    from {
        opacity: 0;
        transform: scale(0.9) translateY(-5px);
    }
    to {
        opacity: 1;
        transform: scale(1) translateY(0);
    }
}

.popup-confirmacao-content {
    background: var(--bg-secondary, #ffffff);
    border-radius: 8px;
    padding: 10px 12px;
    box-shadow: 0 4px 12px var(--shadow-color, rgba(0, 0, 0, 0.15));
    border: 1px solid var(--border-color, #ddd);
    min-width: 160px;
    font-size: 13px;
}

.popup-confirmacao-content p {
    margin: 0 0 10px 0;
    color: var(--text-primary, #333);
    font-weight: 500;
}

.popup-confirmacao-buttons {
    display: flex;
    gap: 8px;
    justify-content: flex-end;
}

.popup-confirmacao-buttons button {
    padding: 5px 12px;
    border: none;
    border-radius: 5px;
    font-size: 12px;
    cursor: pointer;
    transition: all 0.2s;
    font-weight: 500;
}

.btn-confirmar-sim {
    background: #dc3545;
    color: white;
}

.btn-confirmar-sim:hover {
    background: #c82333;
    transform: translateY(-1px);
}

.btn-confirmar-nao {
    background: var(--bg-input, #6c757d);
    color: var(--text-primary, white);
}

.btn-confirmar-nao:hover {
    background: var(--bg-hover, #5a6268);
    transform: translateY(-1px);
}

/* Ajustes para tema escuro */
html.dark-mode .btn-confirmar-nao {
    background: var(--bg-input, #3a3b3c);
    color: var(--text-primary, #e4e6eb);
}

html.dark-mode .btn-confirmar-nao:hover {
    background: var(--bg-action-hover, #4e4f50);
}

/* 🆕 NOVO: Estilos para Formulário de Criar Time */
.form-group {
    margin-bottom: 20px;
}

.form-group label {
    display: block;
    margin-bottom: 5px;
    color: var(--text-primary);
    font-weight: bold;
}

.form-group input,
.form-group textarea {
    width: 100%;
    padding: 10px;
    border: 1px solid var(--border-color);
    border-radius: 5px;
    background: var(--bg-input);
    color: var(--text-primary);
    font-family: inherit;
}

.form-group textarea {
    min-height: 100px;
    resize: vertical;
}

.profissional-item {
    display: flex;
    gap: 10px;
    margin-bottom: 10px;
    align-items: center;
    position: relative;
    padding-right: 28px;
}

.profissional-item input {
    flex: 1;
}

.profissional-item .tipo-profissional {
    flex: 2;
}

.profissional-item .qtd-profissional {
    flex: 0.5;
}

.profissional-item .valor-profissional {
    flex: 1;
}

/* Remove setas (spinners) dos inputs number */
.profissional-item input[type="number"]::-webkit-inner-spin-button,
.profissional-item input[type="number"]::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.profissional-item input[type="number"] {
    -moz-appearance: textfield;
    appearance: textfield;
}

.profissional-item .valor-profissional:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    background: var(--bg-action);
}

.checkbox-a-combinar {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 4px;
    font-size: 10px;
    color: var(--text-primary);
    cursor: pointer;
    white-space: nowrap;
    flex-shrink: 0;
    padding: 5px 6px;
    background: var(--bg-action);
    border: 1px solid var(--border-color);
    border-radius: 5px;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    user-select: none;
    position: relative;
    overflow: hidden;
    min-width: 55px;
    text-align: center;
}

.checkbox-a-combinar::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 0;
    height: 0;
    border-radius: 50%;
    background: rgba(0, 123, 255, 0.1);
    transform: translate(-50%, -50%);
    transition: width 0.4s ease, height 0.4s ease;
}

.checkbox-a-combinar:hover {
    background: var(--bg-action-hover);
    border-color: var(--btn-primary-bg);
    transform: translateY(-1px);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.checkbox-a-combinar:active {
    transform: translateY(0);
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
}

.checkbox-a-combinar input[type="checkbox"] {
    width: 18px;
    height: 18px;
    cursor: pointer;
    margin: 0;
    accent-color: var(--btn-primary-bg);
    flex-shrink: 0;
    position: relative;
    z-index: 1;
    transition: transform 0.2s ease;
    align-self: center;
}

.checkbox-a-combinar:hover input[type="checkbox"] {
    transform: scale(1.1);
}

.checkbox-a-combinar.checked {
    background: rgba(0, 123, 255, 0.15);
    border-color: var(--btn-primary-bg);
    color: var(--btn-primary-bg);
    box-shadow: 0 0 0 2px rgba(0, 123, 255, 0.2);
}

.checkbox-a-combinar.checked::before {
    width: 100%;
    height: 100%;
}

.checkbox-a-combinar.checked span {
    font-weight: 600;
    position: relative;
    z-index: 1;
}

.checkbox-a-combinar.checked input[type="checkbox"] {
    transform: scale(1.15);
    animation: checkboxPulse 0.3s ease;
}

@keyframes checkboxPulse {
    0% {
        transform: scale(1);
    }
    50% {
        transform: scale(1.3);
    }
    100% {
        transform: scale(1.15);
    }
}

.checkbox-a-combinar span {
    user-select: none;
    line-height: 1.2;
    position: relative;
    z-index: 1;
    transition: color 0.2s ease;
    text-align: center;
    font-weight: 500;
    display: block;
    width: 100%;
}

/* Estilos para botões de candidatura */
.time-acoes-candidatar {
    display: flex;
    flex-direction: column;
    gap: 0;
    width: 100%;
}

.profissional-candidatura-item {
    display: flex;
    flex-direction: column;
    gap: 0;
    padding: 0;
    background: transparent;
    border: none;
}

.profissional-candidatura-linha {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 10px;
    padding: 4px 0;
    width: 100%;
}

.profissional-candidatura-tipo {
    font-size: 12px;
    font-weight: 500;
    color: var(--text-primary);
    flex: 1;
    min-width: 0;
    word-wrap: break-word;
    line-height: 1.4;
}

.profissional-separador {
    margin: 2px 0;
    border: none;
    border-top: 1px solid var(--border-color);
    opacity: 0.5;
}

.btn-candidatar-profissional {
    padding: 4px 6px;
    background: var(--btn-primary-bg);
    color: white;
    border: none;
    border-radius: 4px;
    font-size: 10px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 2px;
    width: 60px;
    min-width: 60px;
    max-width: 60px;
    flex-shrink: 0;
    text-align: center;
}

.btn-candidatar-profissional:hover {
    background: var(--btn-primary-hover);
    opacity: 0.9;
}

.btn-candidatar-profissional:active {
    opacity: 0.8;
}

.btn-candidatar-profissional .btn-candidatar-texto {
    font-size: 9px;
    line-height: 1;
    white-space: nowrap;
    display: block;
}

.btn-candidatar-profissional i {
    font-size: 14px;
    line-height: 1;
}

/* Modal de escolha de candidatura */
.modal-escolha-candidatura {
    max-width: 200px;
    width: 100%;
    padding: 10px;
}

.escolha-candidatura-content {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.escolha-candidatura-info {
    font-size: 11px;
    color: var(--text-secondary);
    margin: 0;
    padding: 4px 6px;
    background: var(--bg-action);
    border-radius: 3px;
    line-height: 1.3;
}

.escolha-candidatura-info strong {
    color: var(--text-primary);
    font-weight: 500;
}

.escolha-candidatura-botoes {
    display: flex;
    flex-direction: column;
    gap: 5px;
    margin-top: 2px;
}

.btn-escolher-aceitar,
.btn-escolher-contraproposta,
.btn-cancelar-escolha {
    padding: 6px 10px;
    border: none;
    border-radius: 4px;
    font-size: 11px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
}

.btn-escolher-aceitar {
    background: #28a745;
    color: white;
}

.btn-escolher-aceitar:hover {
    background: #218838;
    opacity: 0.9;
}

.btn-escolher-contraproposta {
    background: #ffc107;
    color: #212529;
}

.btn-escolher-contraproposta:hover {
    background: #e0a800;
    opacity: 0.9;
}

.btn-cancelar-escolha {
    background: var(--bg-action);
    color: var(--text-primary);
    border: 1px solid var(--border-color);
}

.btn-cancelar-escolha:hover {
    background: var(--bg-action-hover);
}

.btn-escolher-aceitar i,
.btn-escolher-contraproposta i {
    font-size: 10px;
}

/* Estilos para botões do modal de contraproposta */
.modal-contraproposta {
    max-width: 320px;
    width: 100%;
}

.contraproposta-content {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.contraproposta-info {
    font-size: 12px;
    color: var(--text-secondary);
    margin: 0;
    padding: 6px 8px;
    background: var(--bg-action);
    border-radius: 4px;
    line-height: 1.4;
}

.contraproposta-info strong {
    color: var(--text-primary);
    font-weight: 600;
}

.contraproposta-aviso {
    font-size: 11px;
    color: var(--text-secondary);
    font-style: italic;
    margin: -4px 0 4px 0;
    padding: 0 8px;
}

.contraproposta-botoes {
    display: flex;
    gap: 8px;
    margin-top: 4px;
    justify-content: flex-end;
}

.btn-enviar-contraproposta,
.btn-cancelar-contraproposta {
    padding: 8px 14px;
    border: none;
    border-radius: 5px;
    font-size: 12px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    min-width: 80px;
}

.btn-enviar-contraproposta {
    background: #28a745;
    color: white;
}

.btn-enviar-contraproposta:hover {
    background: #218838;
    transform: translateY(-1px);
    box-shadow: 0 2px 8px rgba(40, 167, 69, 0.3);
}

.btn-enviar-contraproposta:active {
    transform: translateY(0);
}

.btn-enviar-contraproposta:disabled {
    opacity: 0.6;
    cursor: not-allowed;
    transform: none;
}

.btn-cancelar-contraproposta {
    background: var(--bg-action);
    color: var(--text-primary);
    border: 1px solid var(--border-color);
}

.btn-cancelar-contraproposta:hover {
    background: var(--bg-action-hover);
    transform: translateY(-1px);
}

.btn-cancelar-contraproposta:active {
    transform: translateY(0);
}

.modal-contraproposta .form-group {
    margin-bottom: 12px;
}

.modal-contraproposta .form-group label {
    font-size: 12px;
    margin-bottom: 4px;
}

.modal-contraproposta .form-group input,
.modal-contraproposta .form-group textarea {
    font-size: 12px;
    padding: 8px;
}

/* Layout responsivo para telas menores - profissionais */
@media (max-width: 767px) {
    .profissional-item {
        flex-wrap: wrap;
        gap: 8px;
        align-items: flex-start;
    }
    
    /* Primeira linha: Tipo e Quantidade lado a lado */
    .profissional-item .tipo-profissional {
        flex: 1 1 calc(65% - 4px);
        min-width: 0;
        order: 1;
    }
    
    .profissional-item .qtd-profissional {
        flex: 1 1 calc(35% - 4px);
        min-width: 0;
        order: 2;
    }
    
    /* Segunda linha: Valor e A Combinar lado a lado */
    .profissional-item .valor-profissional {
        flex: 1 1 calc(65% - 4px);
        min-width: 0;
        order: 3;
    }
    
    .profissional-item .checkbox-a-combinar {
        flex: 1 1 calc(35% - 4px);
        min-width: 55px;
        order: 4;
    }
    
    /* Botão remover no canto superior direito */
    .profissional-item {
        padding-right: 28px;
    }
    
    .profissional-item .btn-remover-profissional {
        position: absolute;
        top: 0;
        right: 0;
        order: 5;
    }
}

.btn-remover-profissional {
    background: rgba(220, 53, 69, 0.9);
    color: white;
    border: none;
    border-radius: 4px;
    width: 22px;
    height: 22px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
    position: absolute;
    top: 0;
    right: 0;
    z-index: 10;
    padding: 0;
    margin: 0;
    flex-shrink: 0;
    pointer-events: auto;
    line-height: 1;
    box-sizing: border-box;
}

.btn-remover-profissional i {
    pointer-events: none;
    font-size: 10px;
    display: block;
    margin: 0;
    padding: 0;
    line-height: 1;
    width: 10px;
    height: 10px;
    text-align: center;
}

.btn-remover-profissional:hover {
    background: #dc3545;
    transform: scale(1.1);
}

.btn-remover-profissional i {
    font-size: 11px;
}

/* Ajustes para botões do modal de pedidos urgentes em telas menores */
@media (max-width: 768px) {
    #btn-filtrar-pedidos,
    #btn-servicos-ativos {
        padding: 8px 12px !important;
        font-size: 13px !important;
        white-space: nowrap !important;
        flex-shrink: 0 !important;
        min-width: auto !important;
    }
    
    #btn-servicos-ativos {
        max-width: 160px;
        overflow: hidden;
        text-overflow: ellipsis;
    }
    
    #btn-filtrar-pedidos {
        max-width: 100px;
    }
}

.btn-secondary {
    padding: 10px 20px;
    background: var(--btn-secondary-bg);
    color: #ffffff;
    border: none;
    border-radius: 5px;
    cursor: pointer;
    transition: all 0.2s ease;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
}

.btn-secondary:hover {
    background: var(--btn-secondary-hover);
    transform: translateY(-1px);
}

/* Botões de cancelar (ações destrutivas) em modais */
.btn-cancelar {
    background: #e74c3c;
}

.btn-cancelar:hover {
    background: #c0392b;
}

/* Versão do botão cancelar dentro de modais (como "Montar Time de Projeto") */
.modal-content .btn-cancelar {
    font-size: 0.9em;
    padding: 8px 16px;
    border-radius: 5px;
    min-width: 110px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.btn-primary {
    padding: 10px 20px;
    background: var(--btn-primary-bg);
    color: white;
    border: none;
    border-radius: 5px;
    cursor: pointer;
    font-weight: bold;
    transition: background 0.2s;
}

.btn-primary:hover {
    background: var(--btn-primary-hover);
}

.form-actions {
    display: flex;
    gap: 10px;
    justify-content: flex-end;
    margin-top: 20px;
}

.erro {
    color: #dc3545;
    text-align: center;
    padding: 20px;
}

/* 🆕 NOVO: Estilos para preview de mídia */
.media-preview-container {
    position: relative;
    margin-top: 10px;
    padding: 10px;
    background: var(--bg-primary);
    border-radius: 8px;
    border: 1px solid var(--border-color);
}

.btn-remover-preview {
    position: absolute;
    top: 5px;
    right: 5px;
    background: #dc3545;
    color: white;
    border: none;
    border-radius: 50%;
    width: 25px;
    height: 25px;
    cursor: pointer;
    font-size: 1.2em;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10;
}

.image-preview,
.video-preview {
    max-width: 100%;
    max-height: 300px;
    border-radius: 5px;
    margin-top: 10px;
}

.video-preview {
    width: 100%;
}

/* 🚨 NOVO: Estilos para Pedidos Urgentes e Propostas */
.lista-propostas {
    display: flex;
    flex-direction: column;
    gap: 15px;
    padding: 10px;
    max-height: 500px;
    overflow-y: auto;
    overflow-x: hidden;
}

/* Em telas menores, mantém rolagem principal mas remove do pedido */
@media (max-width: 1023px) {
    .lista-propostas {
        max-height: calc(90vh - 150px);
        overflow-y: auto !important;
        overflow-x: hidden !important;
        flex: 1;
        min-height: 0;
    }
    
    /* Garantir que os cards dentro da lista possam expandir completamente */
    .lista-propostas .pedido-urgente-card {
        flex-shrink: 0;
        flex-grow: 0;
    }
}

.proposta-card {
    background: var(--bg-primary);
    padding: 15px;
    border-radius: 8px;
    border-left: 4px solid #007bff;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.proposta-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.1);
}

.proposta-header {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 10px;
}

.proposta-avatar {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid #007bff;
}

.proposta-info-profissional {
    flex: 1;
}

.proposta-info-profissional strong {
    display: block;
    color: var(--text-primary);
    margin-bottom: 5px;
}

.proposta-meta {
    display: flex;
    gap: 10px;
    font-size: 12px;
    color: var(--text-secondary);
}

.proposta-detalhes {
    margin: 10px 0;
}

.proposta-valor {
    font-size: 24px;
    font-weight: bold;
    color: #28a745;
    margin-bottom: 5px;
}

.proposta-tempo {
    color: var(--text-secondary);
    font-size: 14px;
    margin-bottom: 10px;
}

.proposta-observacoes {
    color: var(--text-primary);
    font-size: 14px;
    margin-top: 10px;
    padding: 10px;
    background: var(--bg-secondary);
    border-radius: 5px;
}
.proposta-avatar-link {
    display: inline-flex;
}
.proposta-info-profissional .link-perfil-proposta {
    color: var(--text-primary);
    text-decoration: none;
}
.proposta-info-profissional .link-perfil-proposta:hover {
    text-decoration: underline;
}

.btn-aceitar-proposta {
    padding: 12px;
    background: #28a745;
    color: white;
    border: none;
    border-radius: 5px;
    font-weight: bold;
    cursor: pointer;
    transition: background 0.2s;
    flex: 1;
}

/* Quando está sozinho (sem botão de recusar ao lado), ocupa 100% */
.btn-aceitar-proposta:only-child {
    width: 100%;
    margin-top: 10px;
}

.btn-aceitar-proposta:hover {
    background: #218838;
}

/* 🏢 NOVO: Estilos para Times Locais */
.time-card-lateral {
    background: var(--bg-primary);
    padding: 10px;
    border-radius: 5px;
    margin-bottom: 8px;
    border-left: 3px solid #007bff;
}

.time-card-lateral strong {
    display: block;
    color: var(--text-primary);
    margin-bottom: 5px;
}

.time-card-lateral small {
    color: var(--text-secondary);
    font-size: 11px;
}

/* 📋 NOVO: Estilos para Projetos de Time */
.profissional-item-projeto {
    display: flex;
    gap: 8px;
    margin-bottom: 10px;
    align-items: center;
}

.profissional-item-projeto input {
    flex: 1;
    padding: 8px;
    border: 1px solid var(--border-color);
    border-radius: 5px;
    font-size: 14px;
}

.profissional-item-projeto .tipo-profissional-projeto {
    flex: 2;
}

.profissional-item-projeto .qtd-profissional-projeto {
    flex: 0.5;
    max-width: 80px;
}

.profissional-item-projeto .valor-profissional-projeto {
    flex: 1;
}

.btn-remover-profissional-projeto {
    background: #dc3545;
    color: white;
    border: none;
    border-radius: 50%;
    width: 30px;
    height: 30px;
    cursor: pointer;
    font-size: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.2s;
}

.btn-remover-profissional-projeto:hover {
    background: #c82333;
}

#profissionais-necessarios-container {
    margin: 20px 0;
}

#profissionais-necessarios-container label {
    display: block;
    margin-bottom: 10px;
    font-weight: bold;
    color: var(--text-primary);
}

/* 🚨 NOVO: Estilos para Pedidos Urgentes (vista profissional) */
.pedido-urgente-card {
    background: var(--bg-primary);
    padding: 15px;
    border-radius: 8px;
    border-left: 4px solid #ffc107;
    margin-bottom: 15px;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

/* Garantir que em telas menores o pedido apareça completo sem rolagem */
@media (max-width: 1023px) {
    .pedido-urgente-card,
    div.pedido-urgente-card,
    .lista-propostas .pedido-urgente-card,
    #lista-pedidos-urgentes .pedido-urgente-card,
    #modal-pedidos-urgentes-profissional .pedido-urgente-card {
        overflow: visible !important;
        overflow-x: visible !important;
        overflow-y: visible !important;
        max-height: none !important;
        height: auto !important;
        min-height: auto !important;
        width: 100%;
        box-sizing: border-box;
        padding: 15px !important;
        display: block !important;
        position: relative !important;
    }
    
    /* Garantir que TODOS os elementos dentro do pedido não tenham rolagem (exceto imagens) */
    .pedido-urgente-card *:not(img):not(video):not(canvas),
    .pedido-urgente-card *::before,
    .pedido-urgente-card *::after,
    div.pedido-urgente-card *:not(img):not(video):not(canvas),
    .lista-propostas .pedido-urgente-card *:not(img):not(video):not(canvas),
    #lista-pedidos-urgentes .pedido-urgente-card *:not(img):not(video):not(canvas),
    #modal-pedidos-urgentes-profissional .pedido-urgente-card *:not(img):not(video):not(canvas),
    .pedido-urgente-card > *:not(img):not(video):not(canvas),
    .pedido-urgente-card > * > *:not(img):not(video):not(canvas) {
        overflow: visible !important;
        overflow-x: visible !important;
        overflow-y: visible !important;
        max-height: none !important;
        height: auto !important;
        min-height: auto !important;
    }
    
    /* Imagens não precisam de overflow visible - apenas os containers */
    .pedido-urgente-card img,
    .pedido-urgente-card video,
    .pedido-urgente-card canvas {
        overflow: unset !important;
    }
    
    /* Garantir que nenhum wrapper tenha rolagem - regras mais específicas */
    .pedido-urgente-card,
    .pedido-urgente-card > div,
    .pedido-urgente-card > div > div,
    [class*="pedido-urgente-card"],
    [style*="pedido-urgente-card"] {
        overflow: visible !important;
        overflow-x: visible !important;
        overflow-y: visible !important;
        max-height: none !important;
        height: auto !important;
        min-height: auto !important;
    }
    
    /* Forçar remoção de rolagem mesmo com estilos inline */
    .pedido-urgente-card[style*="overflow"],
    .pedido-urgente-card[style*="max-height"],
    .pedido-urgente-card[style*="height"] {
        overflow: visible !important;
        overflow-x: visible !important;
        overflow-y: visible !important;
        max-height: none !important;
        height: auto !important;
    }
    
    /* Remover qualquer restrição de altura de elementos filhos */
    .pedido-urgente-card div:not(.pedido-foto-servico),
    .pedido-urgente-card p,
    .pedido-urgente-card span,
    .pedido-urgente-card strong,
    div.pedido-urgente-card div:not(.pedido-foto-servico),
    .lista-propostas .pedido-urgente-card div:not(.pedido-foto-servico),
    #lista-pedidos-urgentes .pedido-urgente-card div:not(.pedido-foto-servico) {
        max-height: none !important;
        height: auto !important;
        overflow: visible !important;
        overflow-x: visible !important;
        overflow-y: visible !important;
    }
    
    /* Container de fotos sem rolagem mas sem overflow nas imagens */
    .pedido-urgente-card .pedido-foto-servico {
        overflow: visible !important;
        overflow-x: visible !important;
        overflow-y: visible !important;
        max-height: none !important;
        height: auto !important;
    }
    
    .pedido-urgente-card .pedido-foto-servico img {
        overflow: unset !important;
    }
    
    /* Exceto para elementos que precisam de scroll (como textarea) */
    .pedido-urgente-card textarea {
        overflow-y: auto !important;
        max-height: 200px !important;
    }
    
    /* Garantir que elementos específicos do pedido não tenham restrições */
    .pedido-urgente-card .pedido-cliente-header,
    .pedido-urgente-card .pedido-header,
    .pedido-urgente-card .pedido-descricao,
    .pedido-urgente-card .pedido-localizacao,
    .pedido-urgente-card .pedido-info-atendimento {
        overflow: visible !important;
        overflow-x: visible !important;
        overflow-y: visible !important;
        max-height: none !important;
        height: auto !important;
    }
    
    /* Garantir que o container de fotos não tenha rolagem e não coma bordas */
    .pedido-urgente-card .pedido-foto-servico {
        overflow: visible !important;
        overflow-x: visible !important;
        overflow-y: visible !important;
        max-height: none !important;
        height: auto !important;
        width: 100%;
        box-sizing: border-box;
        margin: 10px 0 !important;
        padding: 0;
        gap: 5px;
        display: flex !important;
        flex-wrap: wrap !important;
    }
    
    /* Garantir que as imagens dentro do pedido não ultrapassem as bordas */
    .pedido-urgente-card .pedido-foto-servico img {
        max-width: calc(50% - 2.5px) !important;
        width: calc(50% - 2.5px) !important;
        box-sizing: border-box;
        flex-shrink: 0;
        height: auto !important;
        max-height: none !important;
        overflow: unset !important;
    }
    
    /* Se for apenas uma foto, ocupa 100% mas respeita padding */
    .pedido-urgente-card .pedido-foto-servico img:only-child {
        max-width: 100% !important;
        width: 100% !important;
    }
    
    /* Garantir que botões não sejam cortados */
    .pedido-urgente-card .btn-enviar-proposta {
        width: 100%;
        box-sizing: border-box;
        margin-top: 10px;
        overflow: visible !important;
    }
    
    /* REGRA FINAL: Garantir que o pedido inteiro não tenha rolagem */
    .pedido-urgente-card,
    .pedido-urgente-card *:not(textarea):not(img):not(video):not(canvas) {
        overflow: visible !important;
        overflow-x: visible !important;
        overflow-y: visible !important;
        max-height: none !important;
        height: auto !important;
    }
    
    /* Garantir que a lista de pedidos tenha rolagem apenas quando necessário */
    #modal-pedidos-urgentes-profissional .lista-propostas,
    #modal-pedidos-urgentes-profissional #lista-pedidos-urgentes {
        overflow-y: auto !important;
        overflow-x: hidden !important;
    }
    
    /* Garantir que o modal aumente de acordo com o conteúdo */
    #modal-pedidos-urgentes-profissional .modal-content.modal-grande {
        height: auto !important;
        max-height: 95vh !important;
    }
}

.pedido-urgente-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.1);
}

.pedido-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 10px;
}

.pedido-header strong {
    color: var(--text-primary);
    font-size: 18px;
}

.badge-status {
    display: inline-block;
    padding: 4px 10px;
    border-radius: 12px;
    font-size: 12px;
    font-weight: 600;
    margin-left: 8px;
}

.badge-aberto {
    background: #ffc107;
    color: #000;
}

.badge-aceito {
    background: #28a745;
    color: #fff;
}

.badge-concluido {
    background: #007bff;
    color: #fff;
}

.badge-cancelado {
    background: #dc3545;
    color: #fff;
}

.badge-categoria {
    background: #007bff;
    color: white;
    padding: 2px 8px;
    border-radius: 12px;
    font-size: 11px;
    margin-left: 8px;
}

.btn-ver-propostas {
    padding: 8px 15px;
    background: var(--primary-color);
    color: white;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    font-size: 14px;
    transition: background 0.2s;
}

.btn-ver-propostas:hover {
    background: #0056b3;
}

.tempo-restante {
    color: #dc3545;
    font-weight: bold;
    font-size: 14px;
}

.pedido-info-atendimento {
    color: var(--text-secondary);
    font-size: 13px;
    display: flex;
    align-items: center;
    gap: 6px;
    margin: 6px 0;
}

.pedido-tipo-atendimento {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 6px;
}

.pedido-tipo-atendimento label {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 14px;
    color: var(--text-primary);
}

/* Estilo dos campos de data e horário do agendamento (visíveis) */
#pedido-data-display,
#pedido-hora-display {
    width: 100%;
    box-sizing: border-box;
    padding: 8px 10px;
    border-radius: 6px;
    border: 1px solid var(--border-color);
    background-color: var(--bg-input);
    color: var(--text-primary);
    font-size: 14px;
    cursor: pointer;
}

#pedido-data-display:focus,
#pedido-hora-display:focus {
    outline: none;
    border-color: var(--btn-filter-active-bg);
    box-shadow: 0 0 0 2px rgba(0, 123, 255, 0.2);
}

/* Popup base para calendário / horários */
.agendamento-popup {
    position: absolute;
    z-index: 1200;
    background: var(--bg-secondary);
    border-radius: 8px;
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.25);
    border: 1px solid var(--border-color);
    margin-top: 6px;
    min-width: 260px;
}

/* =========================================================
   Popup de HORÁRIOS: mais contraste (texto + fundo)
   (pedido-hora-display / popup-horario-agendamento)
   ========================================================= */
#popup-horario-agendamento.agendamento-popup {
    background: rgba(12, 14, 20, 0.98);
    border: 1px solid rgba(255, 255, 255, 0.14);
    box-shadow: 0 14px 40px rgba(0, 0, 0, 0.55);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

#popup-horario-agendamento .agendamento-popup-header {
    background: rgba(255, 255, 255, 0.06);
    border-bottom: 1px solid rgba(255, 255, 255, 0.10);
    color: rgba(255, 255, 255, 0.92);
}

#popup-horario-agendamento .agendamento-nav-btn {
    color: rgba(255, 255, 255, 0.92);
}

#popup-horario-agendamento .agendamento-nav-btn:hover {
    background: rgba(255, 255, 255, 0.10);
}

#popup-horario-agendamento .agendamento-horario-item {
    color: rgba(255, 255, 255, 0.92);
    font-weight: 600;
}

#popup-horario-agendamento .agendamento-horario-item:hover {
    background: rgba(0, 123, 255, 0.22);
    color: #fff;
}

#popup-horario-agendamento .agendamento-horario-item.selecionado {
    background: var(--btn-filter-active-bg);
    color: #fff;
}

.agendamento-popup.hidden {
    display: none;
}

.agendamento-popup-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px 10px;
    border-bottom: 1px solid var(--border-color);
    background: var(--bg-primary);
    border-radius: 8px 8px 0 0;
    font-size: 14px;
    color: var(--text-primary);
}

.agendamento-nav-btn {
    border: none;
    background: transparent;
    color: var(--text-primary);
    cursor: pointer;
    padding: 2px 6px;
    border-radius: 4px;
}

.agendamento-nav-btn:hover {
    background: var(--bg-hover);
}

.agendamento-calendario-corpo {
    padding: 8px 10px 10px 10px;
}

.agendamento-calendario-semana {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    font-size: 11px;
    text-align: center;
    color: var(--text-secondary);
    margin-bottom: 4px;
}

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

.agendamento-dia {
    padding: 6px 0;
    text-align: center;
    font-size: 13px;
    border-radius: 6px;
    cursor: pointer;
    color: var(--text-primary);
}

.agendamento-dia.outro-mes {
    opacity: 0.3;
}

.agendamento-dia.hoje {
    border: 1px solid var(--btn-filter-active-bg);
}

.agendamento-dia.selecionado {
    background: var(--btn-filter-active-bg);
    color: #fff;
}

.agendamento-dia:hover {
    background: var(--bg-hover);
}

.agendamento-popup-horario {
    max-height: 220px;
    overflow-y: auto;
}

.agendamento-horarios-lista {
    max-height: 200px;
    overflow-y: auto;
    padding: 6px 0;
}

.agendamento-horario-item {
    padding: 6px 12px;
    font-size: 14px;
    cursor: pointer;
    color: var(--text-primary);
}

.agendamento-horario-item:hover,
.agendamento-horario-item.selecionado {
    background: var(--btn-filter-active-bg);
    color: #fff;
}

.pedido-descricao {
    color: var(--text-secondary);
    margin: 10px 0;
    font-size: 14px;
}

.pedido-localizacao {
    color: var(--text-secondary);
    font-size: 13px;
    margin: 10px 0;
    display: flex;
    align-items: center;
    gap: 5px;
}

.pedido-cliente {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 10px 0;
    font-size: 14px;
    color: var(--text-primary);
}

.pedido-cliente-header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 15px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--border-color);
    overflow: visible !important;
    overflow-x: visible !important;
    overflow-y: visible !important;
    max-height: none !important;
    height: auto !important;
}

/* Garantir que em telas menores não haja rolagem */
@media (max-width: 1023px) {
    .pedido-cliente-header,
    .pedido-info-atendimento,
    .tempo-restante {
        overflow: visible !important;
        overflow-x: visible !important;
        overflow-y: visible !important;
        max-height: none !important;
        height: auto !important;
    }
}

.avatar-pequeno-pedido {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid var(--border-color);
    flex-shrink: 0;
    display: block;
}

/* Garantir que o avatar fique redondo mesmo em diferentes contextos */
.pedido-cliente-header .avatar-pequeno-pedido,
.pedido-cliente-header .clickable-avatar {
    width: 40px !important;
    height: 40px !important;
    border-radius: 50% !important;
    object-fit: cover !important;
    overflow: hidden !important;
}

.nome-cliente-clickable {
    font-weight: 600;
    color: var(--primary-color);
    cursor: pointer;
    transition: color 0.2s;
}

.nome-cliente-clickable:hover {
    color: var(--primary-color-dark, #0056b3);
    text-decoration: underline;
}

.clickable-avatar {
    transition: transform 0.2s, opacity 0.2s;
}

.clickable-avatar:hover {
    transform: scale(1.05);
    opacity: 0.9;
}

.pedido-foto-servico {
    margin: 10px 0;
    overflow: visible !important;
    overflow-x: visible !important;
    overflow-y: visible !important;
}

.pedido-foto-servico img {
    width: 100%;
    max-height: 300px;
    object-fit: cover;
    border-radius: 8px;
    border: 1px solid var(--border-color);
}

/* Remover rolagem das fotos em telas menores */
@media (max-width: 1023px) {
    .pedido-foto-servico {
        overflow: visible !important;
        overflow-x: visible !important;
        overflow-y: visible !important;
        max-height: none !important;
        height: auto !important;
    }
    
    .pedido-foto-servico img {
        max-height: 200px;
    }
}

.btn-enviar-proposta {
    width: 100%;
    padding: 10px;
    background: #ffc107;
    color: #333;
    border: none;
    border-radius: 5px;
    font-weight: bold;
    cursor: pointer;
    transition: background 0.2s;
    margin-top: 10px;
}

.btn-enviar-proposta:hover {
    background: #e0a800;
}

/* ⚡ NOVO: Estilos para Vagas-Relâmpago */
.vaga-relampago-card {
    background: var(--bg-primary);
    padding: 15px;
    border-radius: 8px;
    border-left: 4px solid #ffc107;
    margin-bottom: 15px;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.vaga-relampago-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.1);
}

.vaga-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 10px;
}

.vaga-header strong {
    color: var(--text-primary);
    font-size: 18px;
}

.badge-cargo {
    background: #ffc107;
    color: #333;
    padding: 2px 8px;
    border-radius: 12px;
    font-size: 11px;
    margin-left: 8px;
    font-weight: bold;
}

.badge-status-aberta {
    background: #28a745;
    color: white;
    padding: 4px 10px;
    border-radius: 12px;
    font-size: 12px;
}

.badge-status-em_andamento {
    background: #007bff;
    color: white;
    padding: 4px 10px;
    border-radius: 12px;
    font-size: 12px;
}

.badge-status-concluida {
    background: #6c757d;
    color: white;
    padding: 4px 10px;
    border-radius: 12px;
    font-size: 12px;
}

.vaga-descricao {
    color: var(--text-secondary);
    margin: 10px 0;
    font-size: 14px;
    line-height: 1.5;
}

.vaga-info {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin: 15px 0;
}

.vaga-info-item {
    display: flex;
    align-items: center;
    gap: 8px;
    color: var(--text-secondary);
    font-size: 13px;
}

.vaga-empresa {
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 15px 0;
    padding: 10px;
    background: var(--bg-secondary);
    border-radius: 5px;
}

.btn-candidatar-vaga {
    width: 100%;
    padding: 12px;
    background: #ffc107;
    color: #333;
    border: none;
    border-radius: 5px;
    font-weight: bold;
    cursor: pointer;
    transition: background 0.2s;
    margin-top: 10px;
}

.btn-candidatar-vaga:hover {
    background: #e0a800;
}

.btn-candidatar-vaga:disabled {
    background: #6c757d;
    cursor: not-allowed;
}

.candidato-card {
    background: var(--bg-primary);
    padding: 15px;
    border-radius: 8px;
    border-left: 4px solid #007bff;
    margin-bottom: 15px;
}

.candidato-header {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 10px;
}

.candidato-info {
    flex: 1;
}

.candidato-info strong {
    display: block;
    color: var(--text-primary);
    margin-bottom: 5px;
}

.candidato-meta {
    display: flex;
    gap: 10px;
    font-size: 12px;
    color: var(--text-secondary);
    margin-bottom: 5px;
}

.candidato-acoes {
    display: flex;
    gap: 10px;
    margin-top: 10px;
}

.btn-aceitar-candidato,
.btn-rejeitar-candidato {
    flex: 1;
    padding: 8px;
    border: none;
    border-radius: 5px;
    font-weight: bold;
    cursor: pointer;
    transition: background 0.2s;
}

.btn-aceitar-candidato {
    background: #28a745;
    color: white;
}

.btn-aceitar-candidato:hover {
    background: #218838;
}

.btn-rejeitar-candidato {
    background: #dc3545;
    color: white;
}

.btn-rejeitar-candidato:hover {
    background: #c82333;
}


.badge-aceito {
    background: #28a745;
    color: white;
    padding: 2px 8px;
    border-radius: 12px;
    font-size: 11px;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    margin-left: 10px;
}

/* 💰 NOVO: Estilos para Pagamento Seguro */
.pagamento-card {
    background: var(--bg-primary);
    padding: 20px;
    border-radius: 8px;
    border-left: 4px solid #007bff;
    margin-bottom: 15px;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.pagamento-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.1);
}

.pagamento-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 15px;
    padding-bottom: 15px;
    border-bottom: 1px solid var(--border-color);
}

.pagamento-info {
    margin: 15px 0;
}

.btn-liberar-pagamento,
.btn-reembolsar-pagamento {
    transition: background 0.2s, transform 0.1s;
}

.btn-liberar-pagamento:hover {
    background: #218838 !important;
    transform: translateY(-1px);
}

.btn-reembolsar-pagamento:hover {
    background: #c82333 !important;
    transform: translateY(-1px);
}

/* 🔔 NOVO: Estilos para Notificações */
.notificacao-card {
    /* Tema claro/escuro via variáveis */
    background: var(--bg-comment);
    padding: 15px;
    border-radius: 8px;
    margin-bottom: 10px;
    cursor: pointer;
    transition: background 0.2s, opacity 0.2s;
    border-left: 3px solid transparent;
}

.notificacao-card.nao-lida {
    /* Um pouco mais “marcado” que o normal */
    background: var(--bg-action-hover);
    border-left-color: #007bff;
}

.notificacao-card.notificacao-recusada {
    background: rgba(220, 53, 69, 0.1) !important;
    border-left-color: #dc3545 !important;
}

.notificacao-card.notificacao-recusada.nao-lida {
    background: rgba(220, 53, 69, 0.15) !important;
    border-left-color: #dc3545 !important;
}

.notificacao-card:hover {
    background: var(--bg-action-hover);
}

.notificacao-card.notificacao-recusada:hover {
    background: rgba(220, 53, 69, 0.2) !important;
}

/* Destaque para serviço ativo vindo da notificação */
.servico-ativo-destacado {
    box-shadow: 0 0 0 2px var(--primary-color);
}

.btn-mapa-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    border-radius: 999px;
    background: var(--primary-color);
    color: #fff;
    text-decoration: none;
    font-size: 13px;
}

.btn-mapa-link:hover {
    opacity: 0.9;
}

/* ⚖️ NOVO: Estilos para Disputas */
.disputa-card {
    background: var(--bg-primary);
    padding: 20px;
    border-radius: 8px;
    border-left: 4px solid #ffc107;
    margin-bottom: 15px;
}

.disputa-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 15px;
    padding-bottom: 15px;
    border-bottom: 1px solid var(--border-color);
}

.disputa-info {
    margin: 15px 0;
}

.disputa-info p {
    margin: 8px 0;
}

.btn-abrir-disputa:hover {
    background: #e0a800 !important;
    transform: translateY(-1px);
}

/* 📈 NOVO: Estilos para Dashboard Administrativo */
.admin-stat-card {
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.admin-stat-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 16px rgba(0,0,0,0.2);
}

.admin-tab-btn {
    background: none;
    border: none;
    padding: 12px 20px;
    cursor: pointer;
    font-size: 16px;
    color: var(--text-secondary);
    border-bottom: 3px solid transparent;
    transition: all 0.2s;
}

.admin-tab-btn:hover {
    color: var(--primary-color);
}

.admin-tab-btn.active {
    color: var(--primary-color);
    border-bottom-color: var(--primary-color);
    font-weight: bold;
}

.admin-tab-content {
    display: none;
}

.admin-tab-content.active {
    display: block;
}

.admin-pagamento-card,
.admin-disputa-card {
    background: var(--bg-primary);
    padding: 15px;
    border-radius: 8px;
    margin-bottom: 10px;
    border-left: 4px solid var(--primary-color);
}

.btn-resolver-disputa:hover {
    background: #218838 !important;
    transform: translateY(-1px);
}

/* 🆕 NOVO: Estilos para detalhes de projeto */
.projeto-imagens-detalhes {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 10px;
    margin: 15px 0;
}

.projeto-imagem-detalhe {
    width: 100%;
    height: 150px;
    object-fit: cover;
    border-radius: 5px;
    cursor: pointer;
}

.validacoes-lista {
    margin-top: 15px;
}

.validacao-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px;
    background: var(--bg-primary);
    border-radius: 8px;
    margin-bottom: 10px;
}

.validacao-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    object-fit: cover;
}

.validacao-info {
    flex: 1;
}

.validacao-info strong {
    display: block;
    color: var(--text-primary);
}

.validacao-info p {
    margin: 5px 0;
    color: var(--text-secondary);
    font-size: 0.9em;
}

.validacao-info small {
    color: var(--text-secondary);
    font-size: 0.8em;
}

.validacao-badge {
    font-size: 1.5em;
}

.btn-validar-projeto.ja-validado {
    background: #28a745;
    opacity: 0.8;
    cursor: default;
}

.btn-validar-projeto.ja-validado:hover {
    background: #28a745;
}

/* 🆕 NOVO: Estilos para nível (separado de XP) */
.nivel-container {
    margin-top: 15px;
    padding: 10px;
    background: var(--bg-primary);
    border-radius: 10px;
    border: 1px solid var(--border-color);
    text-align: center;
}

.nivel-container .nivel-badge {
    margin-bottom: 0;
}

/* Seção de avaliações verificadas - reduzida */
#secao-avaliacoes-verificadas {
    max-height: 450px; /* Altura máxima reduzida */
    overflow: hidden; /* Previne que o conteúdo vaze fora da caixa */
    position: relative; /* Garante que o conteúdo não vaze */
    box-sizing: border-box; /* Inclui padding e border no cálculo da altura */
}

#lista-avaliacoes-verificadas {
    max-height: none; /* Remove altura máxima inicial para permitir crescimento */
    overflow: visible; /* Permite que o conteúdo seja visível inicialmente */
    transition: max-height 0.3s ease;
    position: relative; /* Garante posicionamento correto */
    box-sizing: border-box; /* Inclui padding e border no cálculo da altura */
}

/* Container do botão de expandir deve estar sempre visível */
.avaliacoes-expandir-container {
    position: relative;
    margin: 10px 0;
    text-align: center;
    padding: 5px 0;
    z-index: 10;
    width: 100%;
}

/* Quando expandido, ativa scrollbar customizada (mostra 4 avaliações com scroll) */
#lista-avaliacoes-verificadas.lista-avaliacoes-com-scroll {
    max-height: 400px; /* Altura máxima quando expandido (4 avaliações) */
    overflow-y: auto;
    overflow-x: hidden;
    position: relative; /* Garante posicionamento correto */
    box-sizing: border-box; /* Inclui padding e border no cálculo da altura */
}

/* Scrollbar customizada para lista de avaliações */
#lista-avaliacoes-verificadas.lista-avaliacoes-com-scroll::-webkit-scrollbar {
    width: 8px;
}

#lista-avaliacoes-verificadas.lista-avaliacoes-com-scroll::-webkit-scrollbar-track {
    background: var(--bg-secondary, #f5f5f5);
    border-radius: 10px;
}

#lista-avaliacoes-verificadas.lista-avaliacoes-com-scroll::-webkit-scrollbar-thumb {
    background: linear-gradient(180deg, #667eea 0%, #764ba2 100%);
    border-radius: 10px;
    border: 2px solid var(--bg-secondary, #f5f5f5);
}

#lista-avaliacoes-verificadas.lista-avaliacoes-com-scroll::-webkit-scrollbar-thumb:hover {
    background: linear-gradient(180deg, #5568d3 0%, #6a3f8f 100%);
}

/* Para Firefox */
#lista-avaliacoes-verificadas.lista-avaliacoes-com-scroll {
    scrollbar-width: thin;
    scrollbar-color: #667eea var(--bg-secondary, #f5f5f5);
}

/* Botão para expandir/colapsar avaliações verificadas */
.btn-expandir-avaliacoes {
    border: none;
    background: linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,0.35) 100%);
    color: #fff;
    font-size: 14px;
    cursor: pointer;
    border-radius: 8px;
    padding: 8px 16px;
    display: flex !important; /* Força display flex */
    align-items: center;
    justify-content: center;
    transition: opacity 0.12s ease;
    opacity: 0.7;
    margin: 5px auto;
    z-index: 10;
    min-width: 40px;
    min-height: 30px;
}

.btn-expandir-avaliacoes:hover {
    opacity: 1;
}

.btn-expandir-avaliacoes:focus {
    outline: none;
}

.avaliacao-oculta {
    display: none;
}

/* Container de fotos nas avaliações */
.avaliacao-fotos-container {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 10px;
    padding-top: 10px;
    border-top: 1px solid var(--border-color, #e5e7eb);
}

.avaliacao-foto-miniatura {
    width: 60px;
    height: 60px;
    object-fit: cover;
    border-radius: 6px;
    cursor: pointer;
    border: 2px solid var(--border-color, #e5e7eb);
    transition: transform 0.2s ease, border-color 0.2s ease;
}

.avaliacao-foto-miniatura:hover {
    transform: scale(1.05);
    border-color: var(--btn-primary-bg, #667eea);
}

/* Modal de imagem expandida */
.modal-imagem-avaliacao {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 10000;
    display: flex;
    align-items: center;
    justify-content: center;
    animation: fadeIn 0.2s ease;
}

@keyframes fadeIn {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}

.modal-imagem-avaliacao-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.9);
    cursor: pointer;
}

.modal-imagem-avaliacao-content {
    position: relative;
    z-index: 10001;
    max-width: 90%;
    max-height: 90%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.modal-imagem-avaliacao-container {
    position: relative;
    max-width: 100%;
    max-height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.modal-imagem-avaliacao-img {
    max-width: 100%;
    max-height: 90vh;
    object-fit: contain;
    border-radius: 8px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.5);
}

.modal-imagem-avaliacao-fechar {
    position: absolute;
    top: -40px;
    right: 0;
    background: rgba(255, 255, 255, 0.9);
    border: none;
    border-radius: 50%;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-size: 20px;
    color: #333;
    z-index: 10002;
    transition: background 0.2s ease, transform 0.2s ease;
}

.modal-imagem-avaliacao-fechar:hover {
    background: rgba(255, 255, 255, 1);
    transform: scale(1.1);
}

.modal-imagem-avaliacao-prev,
.modal-imagem-avaliacao-next {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: rgba(255, 255, 255, 0.9);
    border: none;
    border-radius: 50%;
    width: 50px;
    height: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-size: 20px;
    color: #333;
    z-index: 10002;
    transition: background 0.2s ease, transform 0.2s ease;
}

.modal-imagem-avaliacao-prev {
    left: -60px;
}

.modal-imagem-avaliacao-next {
    right: -60px;
}

.modal-imagem-avaliacao-prev:hover,
.modal-imagem-avaliacao-next:hover {
    background: rgba(255, 255, 255, 1);
    transform: translateY(-50%) scale(1.1);
}

.modal-imagem-avaliacao-indicador {
    position: absolute;
    bottom: -40px;
    left: 50%;
    transform: translateX(-50%);
    background: rgba(255, 255, 255, 0.9);
    padding: 8px 16px;
    border-radius: 20px;
    font-size: 14px;
    color: #333;
    z-index: 10002;
}

/* Mobile: ajustes para telas pequenas */
@media (max-width: 768px) {
    .modal-imagem-avaliacao-content {
        max-width: 95%;
        max-height: 95%;
    }

    .modal-imagem-avaliacao-img {
        max-height: 85vh;
    }

    .modal-imagem-avaliacao-fechar {
        top: 10px;
        right: 10px;
        width: 35px;
        height: 35px;
        font-size: 18px;
    }

    .modal-imagem-avaliacao-prev,
    .modal-imagem-avaliacao-next {
        width: 40px;
        height: 40px;
        font-size: 16px;
    }

    .modal-imagem-avaliacao-prev {
        left: 10px;
    }

    .modal-imagem-avaliacao-next {
        right: 10px;
    }

    .modal-imagem-avaliacao-indicador {
        bottom: 10px;
        font-size: 12px;
        padding: 6px 12px;
    }

    .avaliacao-foto-miniatura {
        width: 50px;
        height: 50px;
    }
}

/* 🆕 NOVO: Modal Proposta Aceita - Bottom Sheet (Mobile) / Side Panel (Desktop) */
.modal-proposta-aceita {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 10000;
    pointer-events: none;
    transition: opacity 0.3s ease;
}

.modal-proposta-aceita.hidden {
    opacity: 0;
    pointer-events: none;
}

.modal-proposta-aceita:not(.hidden) {
    opacity: 1;
    pointer-events: all;
}

.modal-proposta-aceita-backdrop {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    backdrop-filter: blur(4px);
}

.modal-proposta-aceita-content {
    position: absolute;
    background: var(--bg-primary);
    border-radius: 20px 20px 0 0;
    box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.3);
    display: flex;
    flex-direction: column;
    /* Mobile: Bottom Sheet */
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: 90vh; /* Aumentado para cobrir mais a tela */
    max-height: 90vh;
    overflow-y: auto;
    transform: translateY(100%);
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.modal-proposta-aceita:not(.hidden) .modal-proposta-aceita-content {
    transform: translateY(0);
}

.modal-proposta-aceita-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 15px 20px;
    border-bottom: 1px solid var(--border-color);
    flex-shrink: 0;
}

.proposta-aceita-perfil {
    display: flex;
    align-items: center;
    gap: 10px;
    text-decoration: none;
    color: var(--text-primary);
    transition: opacity 0.2s ease;
    flex: 1;
}

.proposta-aceita-perfil:hover {
    opacity: 0.8;
}

.proposta-aceita-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid var(--primary-color);
}

.proposta-aceita-nome {
    font-size: 14px;
    font-weight: 600;
    color: var(--text-primary);
}

.modal-proposta-aceita-close {
    background: none;
    border: none;
    font-size: 28px;
    color: var(--text-secondary);
    cursor: pointer;
    padding: 0;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    transition: all 0.2s ease;
}

.modal-proposta-aceita-close:hover {
    background: var(--bg-secondary);
    color: var(--text-primary);
}

.modal-proposta-aceita-body {
    padding: 25px 20px;
    flex: 1;
}

.proposta-aceita-status {
    text-align: center;
    margin-bottom: 30px;
}

.status-icon {
    font-size: 64px;
    margin-bottom: 10px;
    animation: scaleIn 0.3s ease;
}

@keyframes scaleIn {
    from {
        transform: scale(0);
    }
    to {
        transform: scale(1);
    }
}

.proposta-aceita-titulo {
    font-size: 24px;
    font-weight: 700;
    color: var(--text-primary);
    margin: 0;
}

.proposta-aceita-info {
    display: flex;
    flex-direction: column;
    gap: 20px;
    margin-bottom: 30px;
}

.info-item {
    display: flex;
    align-items: flex-start;
    gap: 15px;
    padding: 15px;
    background: var(--bg-secondary);
    border-radius: 12px;
    border-left: 4px solid var(--primary-color);
}

.info-item i {
    font-size: 20px;
    color: var(--primary-color);
    margin-top: 2px;
    flex-shrink: 0;
}

.info-item > div {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.info-label {
    font-size: 12px;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    font-weight: 600;
}

.info-value {
    font-size: 16px;
    color: var(--text-primary);
    font-weight: 600;
    word-break: break-word;
}

.info-value-link {
    color: var(--primary-color);
    text-decoration: none;
    transition: all 0.2s ease;
    display: inline-block;
}

.info-value-link:hover {
    color: var(--primary-color);
    text-decoration: underline;
    transform: translateX(2px);
}

.btn-whatsapp-proposta {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    width: 100%;
    padding: 16px 24px;
    background: #25D366;
    color: white;
    text-decoration: none;
    border-radius: 12px;
    font-size: 16px;
    font-weight: 600;
    transition: all 0.3s ease;
    box-shadow: 0 4px 12px rgba(37, 211, 102, 0.3);
    position: sticky;
    bottom: 0;
    margin-top: auto;
}

.btn-whatsapp-proposta:hover {
    background: #20BA5A;
    transform: translateY(-2px);
    box-shadow: 0 6px 16px rgba(37, 211, 102, 0.4);
}

.btn-whatsapp-proposta:active {
    transform: translateY(0);
}

.btn-whatsapp-proposta i {
    font-size: 20px;
}

/* 🆕 NOVO: Estilos para Popup Equipes Concluídas (Pequeno, próximo ao botão) */
.popup-equipes-concluidas {
    position: fixed;
    z-index: 10000;
    animation: popupFadeIn 0.2s ease;
    pointer-events: none;
}

.popup-equipes-concluidas-content {
    background: var(--bg-secondary);
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
    border: 1px solid var(--border-color);
    width: 320px;
    max-width: 90vw;
    max-height: 500px;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    box-sizing: border-box;
}

.popup-equipes-concluidas-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 15px;
    border-bottom: 1px solid var(--border-color);
    background: var(--bg-secondary);
    flex-shrink: 0;
}

.popup-equipes-concluidas-header h4 {
    margin: 0;
    font-size: 14px;
    font-weight: 600;
    color: var(--text-primary);
}

.popup-equipes-concluidas-header .btn-fechar-popup-equipes {
    background: none;
    border: none;
    font-size: 20px;
    color: var(--text-secondary);
    cursor: pointer;
    padding: 0;
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    transition: all 0.2s ease;
    line-height: 1;
}

.popup-equipes-concluidas-header .btn-fechar-popup-equipes:hover {
    background: var(--bg-hover);
    color: var(--text-primary);
}

.popup-equipes-concluidas-body {
    flex: 1;
    overflow-y: auto;
    padding: 12px;
    /* Mostra até 4 equipes em telas maiores (cada equipe ~150px + gap 10px) */
    max-height: calc(4 * 150px + 3 * 10px + 24px); /* 4 equipes + 3 gaps + padding */
    display: flex;
    flex-direction: column;
    gap: 10px;
}

/* Em telas menores, mostra até 2 equipes */
@media (max-width: 767px) {
    .popup-equipes-concluidas-body {
        max-height: calc(2 * 150px + 1 * 10px + 24px); /* 2 equipes + 1 gap + padding */
    }
}

.equipe-concluida-item {
    padding: 10px;
    background: var(--bg-primary);
    border-radius: 6px;
    border-left: 2px solid #28a745;
    transition: all 0.2s ease;
    margin-bottom: 0;
    position: relative;
    cursor: pointer;
    min-height: 120px;
}

.equipe-concluida-item:last-child {
    margin-bottom: 0;
}

.equipe-concluida-item:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
}

/* Modo de seleção */
.equipe-concluida-item.modo-selecao {
    padding-left: 40px;
    cursor: pointer;
}

.equipe-concluida-item.modo-selecao::before {
    content: '';
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    width: 20px;
    height: 20px;
    border: 2px solid var(--text-secondary);
    border-radius: 4px;
    background-color: var(--bg-secondary);
    transition: all 0.2s ease;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.equipe-concluida-item.modo-selecao:hover::before {
    border-color: #4CAF50;
    box-shadow: 0 2px 5px rgba(76, 175, 80, 0.2);
}

.equipe-concluida-item.modo-selecao.selecionada::before {
    background-color: #4CAF50;
    border-color: #4CAF50;
    box-shadow: 0 2px 5px rgba(76, 175, 80, 0.3);
}

.equipe-concluida-item.modo-selecao.selecionada::after {
    content: '✓';
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    color: white;
    font-size: 14px;
    font-weight: bold;
    width: 20px;
    height: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
}

/* Estilo para botão lixeira */
.btn-lixeira-equipes {
    transition: all 0.2s ease;
}

.btn-lixeira-equipes:hover {
    background: var(--bg-hover) !important;
    color: var(--text-primary) !important;
}

.btn-lixeira-equipes.modo-selecao {
    background: rgba(220, 53, 69, 0.1) !important;
    color: #dc3545 !important;
}

.btn-lixeira-equipes.modo-selecao:hover {
    background: rgba(220, 53, 69, 0.2) !important;
}

.equipe-concluida-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 10px;
}

.equipe-concluida-header h5 {
    margin: 0 0 8px 0;
    font-size: 13px;
    color: var(--text-primary);
    font-weight: 600;
}

.equipe-status {
    padding: 4px 12px;
    background: #28a745;
    color: white;
    border-radius: 12px;
    font-size: 12px;
    font-weight: 600;
}

.equipe-descricao {
    color: var(--text-secondary);
    margin: 10px 0;
    line-height: 1.5;
}

.equipe-localizacao {
    color: var(--text-secondary);
    font-size: 13px;
    margin: 8px 0;
    display: flex;
    align-items: center;
    gap: 6px;
    line-height: 1.4;
}

.popup-equipes-concluidas-body .equipe-localizacao {
    font-size: 11px;
    margin: 6px 0;
}

.equipe-profissionais-aceitos {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.equipe-profissionais-aceitos strong {
    display: block;
    margin-bottom: 12px;
    color: var(--text-primary);
    font-size: 14px;
}

.profissionais-aceitos-lista {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.profissional-aceito-item {
    padding: 8px;
    background: var(--bg-secondary);
    border-radius: 5px;
    border: 1px solid var(--border-color);
    transition: all 0.2s ease;
}

.profissional-aceito-item:hover {
    border-color: var(--primary-color);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
}

.profissional-aceito-link {
    display: flex;
    align-items: center;
    gap: 12px;
    text-decoration: none;
    color: var(--text-primary);
}

.profissional-aceito-foto {
    width: 35px;
    height: 35px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid var(--primary-color);
    flex-shrink: 0;
}

.profissional-aceito-info {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.profissional-aceito-nome {
    font-weight: 600;
    font-size: 12px;
    color: var(--text-primary);
}

.profissional-aceito-tipo {
    font-size: 10px;
    color: var(--text-secondary);
}

.profissional-aceito-valor {
    font-size: 11px;
    color: #28a745;
    font-weight: 600;
}

.mensagem-vazia-popup {
    text-align: center;
    color: var(--text-secondary);
    font-size: 12px;
    padding: 20px;
    margin: 0;
}

/* Responsivo para mobile */
@media (max-width: 767px) {
    .popup-equipes-concluidas-content {
        width: 100% !important;
        max-width: 90vw !important;
        max-height: 80vh !important;
    }

    .popup-equipes-concluidas-header {
        padding: 10px 12px;
    }

    .popup-equipes-concluidas-header h4 {
        font-size: 13px;
    }

    .popup-equipes-concluidas-body {
        padding: 10px;
        max-height: calc(80vh - 60px);
    }
    
    .equipe-concluida-item {
        padding: 8px;
    }
    
    .equipe-concluida-header h5 {
        font-size: 12px;
    }
    
    .profissional-aceito-foto {
        width: 30px;
        height: 30px;
    }
    
    .profissional-aceito-nome {
        font-size: 11px;
    }
    
    .profissional-aceito-tipo {
        font-size: 9px;
    }
    
    .profissional-aceito-valor {
        font-size: 10px;
    }
}

/* Desktop: Side Panel */
@media (min-width: 768px) {
    .modal-proposta-aceita-content {
        /* Side Panel da direita */
        bottom: auto;
        top: 0;
        right: 0;
        left: auto;
        width: 35%;
        min-width: 400px;
        max-width: 500px;
        height: 100%;
        max-height: 100vh;
        border-radius: 0;
        transform: translateX(100%);
        transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    }
    
    .proposta-aceita-avatar {
        width: 45px;
        height: 45px;
    }
    
    .proposta-aceita-nome {
        font-size: 15px;
    }

    .modal-proposta-aceita:not(.hidden) .modal-proposta-aceita-content {
        transform: translateX(0);
    }

    .modal-proposta-aceita-body {
        padding: 30px;
    }

    .proposta-aceita-titulo {
        font-size: 28px;
    }

    .info-item {
        padding: 20px;
    }

    .info-value {
        font-size: 18px;
    }

    .btn-whatsapp-proposta {
        padding: 18px 24px;
        font-size: 18px;
    }
}

/* Telas muito grandes: ajustar largura do side panel */
@media (min-width: 1440px) {
    .modal-proposta-aceita-content {
        width: 30%;
        min-width: 450px;
    }
}

/* =========================================================
   FIX FINAL: Notificações SEMPRE entre header e barra inferior
   (evita qualquer regra antiga sobrescrever)
   ========================================================= */
@media (max-width: 992px) {
    html.modal-notificacoes-open #modal-notificacoes.modal-overlay,
    #modal-notificacoes.modal-overlay:not(.hidden) {
        position: fixed !important;
        inset: 0 !important; /* ocupa a tela toda */
        margin: 0 !important;
        width: 100% !important;
        height: 100dvh !important;
        /* deixa o conteúdo SEMPRE entre os cabeçalhos */
        padding: calc(var(--header-height, 70px) + env(safe-area-inset-top, 0px))
                 0
                 calc(var(--bottom-nav-height, 56px) + env(safe-area-inset-bottom, 0px))
                 0 !important;
        box-sizing: border-box !important;
        overflow: hidden !important; /* sem scroll no overlay */
        justify-content: flex-start !important;
        align-items: stretch !important;
        z-index: 1700 !important; /* abaixo do header/barra inferior */
        background-color: rgba(0, 0, 0, 0.6) !important;
    }

    html.modal-notificacoes-open #modal-notificacoes .modal-content.modal-grande,
    #modal-notificacoes:not(.hidden) .modal-content.modal-grande {
        width: 100% !important;
        max-width: none !important;
        height: 100% !important;
        max-height: none !important;
        margin: 0 !important;
        border-radius: 0 !important;
        display: flex !important;
        flex-direction: column !important;
        box-sizing: border-box !important;
        overflow: hidden !important; /* sem scroll no modal-content */
    }

    html.modal-notificacoes-open #lista-notificacoes,
    #modal-notificacoes:not(.hidden) #lista-notificacoes {
        flex: 1 1 auto !important;
        min-height: 0 !important;
        overflow-y: scroll !important; /* barra sempre visível (onde suportado) */
        overflow-x: hidden !important;
        /* respiro visual (não influencia o recorte) */
        padding: 10px 10px 14px !important;
        scrollbar-gutter: stable;
    }
}




