/* ================= VARIÁVEIS GERAIS ================= */
:root {
    --font-family: 'Inter', sans-serif;
    --bg-body: #ffffff;
    --bg-sidebar: #f8f9fa;
    --bg-card: #f3f4f6;
    --text-main: #111827;
    --text-secondary: #6b7280;
    --text-tertiary: #9ca3af;
    --border-color: #e5e7eb;
    --brand-green: #5cc639;
    --brand-green-light: #ecfccb;
    --brand-orange: #ea580c;
    --brand-orange-light: #ffedd5;
    --brand-blue: #3b82f6;
    --radius-md: 8px;
}

/* ================= DARK MODE ================= */
body.dark-theme {
    --bg-body: #111827;
    --bg-sidebar: #1f2937;
    --bg-card: #374151;
    --text-main: #f9fafb;
    --text-secondary: #d1d5db;
    --text-tertiary: #9ca3af;
    --border-color: #4b5563;
}
body.dark-theme .page-modal { background-color: var(--bg-body); }
body.dark-theme .input-gray { background-color: var(--bg-card); color: var(--text-main); border: 1px solid var(--border-color); }
body.dark-theme .btn-select { background-color: var(--bg-body); color: var(--text-main); border-color: var(--border-color); }
body.dark-theme .btn-select.active { background-color: var(--brand-green); color: #fff; border-color: var(--brand-green); }
body.dark-theme .action-block, body.dark-theme .select-cliente { background-color: var(--bg-card); }
body.dark-theme .action-block:hover, body.dark-theme .select-cliente:hover { background-color: #4b5563; }
body.dark-theme .resumo-box { background-color: var(--bg-sidebar); border-color: var(--border-color); }
body.dark-theme .prod-item { background-color: var(--bg-sidebar); border-color: var(--border-color); box-shadow: none; }
body.dark-theme .prod-item:hover { border-color: var(--brand-blue); background-color: var(--bg-card); }
body.dark-theme .prod-icon { background-color: transparent; color: var(--brand-blue); border: none; }
body.dark-theme .modal-container { background-color: var(--bg-body); border: 1px solid var(--border-color); }
body.dark-theme .taxa-row { background-color: var(--bg-sidebar); border-color: var(--border-color); }
body.dark-theme .user-item { background-color: var(--bg-sidebar); border-color: transparent; }
body.dark-theme .user-item:hover, body.dark-theme .user-item.active { background-color: var(--bg-card); border-color: var(--border-color); }
body.dark-theme .brand-badge { background-color: var(--bg-body); border-color: var(--border-color); color: var(--text-main); }
body.dark-theme .history-card { background-color: var(--bg-sidebar); border-color: var(--border-color); }
body.dark-theme .input-outline { background-color: var(--bg-body); color: var(--text-main); border-color: var(--border-color); }
body.dark-theme .u-avatar { background-color: var(--bg-card); color: var(--text-main); border-color: var(--border-color); }
body.dark-theme .photo-upload-box { background-color: var(--bg-card); }

/* CORES DAS TAGS */
.cli-tag { background: #ffffff; color: #111827; border: 1px solid var(--border-color); }
body.dark-theme .cli-tag { background-color: var(--bg-sidebar); color: var(--text-main); border-color: var(--border-color); }
body.dark-theme .cli-tag:hover { background-color: var(--bg-card); }

.cli-tag.active { background: var(--brand-green) !important; color: #ffffff !important; border-color: var(--brand-green) !important; }
.cli-tag-black { background: #111827 !important; color: #ffffff !important; border-color: #111827 !important; }

body.dark-theme .doc-upload-box { background-color: var(--bg-sidebar); border-color: var(--border-color); }
body.dark-theme .report-card { background-color: var(--bg-sidebar); border-color: var(--border-color); }
body.dark-theme .report-card:hover { background-color: var(--bg-card); }
body.dark-theme .acc-header { color: var(--text-main); }
body.dark-theme .report-user-row { background-color: var(--bg-sidebar); }
body.dark-theme .date-badge { background-color: var(--bg-body); border-color: var(--border-color); color: var(--text-main); }
body.dark-theme .btn-circle-back { background-color: var(--bg-card); color: var(--text-main); }
body.dark-theme .btn-circle-back:hover { background-color: var(--border-color); }
body.dark-theme .btn-cancelar { background-color: var(--bg-card); color: var(--text-main); border-color: var(--border-color); }
body.dark-theme .btn-concluir { background-color: #ffffff; color: #000000; }
body.dark-theme .btn-concluir[style*="var(--brand-green)"] { background-color: var(--brand-green) !important; color: #ffffff !important; }
body.dark-theme .cli-search { background-color: var(--bg-sidebar); color: var(--text-main); border: 1px solid var(--border-color); }
body.dark-theme .bottom-panel { background-color: #1f2937; border-top: 1px solid var(--border-color); }
body.dark-theme .input-login { background-color: #374151; border-color: #4b5563; }
body.dark-theme .cartao-block { background-color: var(--bg-sidebar); border-color: var(--border-color); }
body.dark-theme .chat-message.received { background-color: var(--bg-card); color: var(--text-main); }
body.dark-theme .calendar-day { background-color: var(--bg-card); border-color: var(--border-color); color: var(--text-main); }
body.dark-theme .calendar-day:hover { background-color: var(--bg-sidebar); }
body.dark-theme .chat-notif { background: var(--bg-sidebar); border-color: var(--border-color); }

body.dark-theme .bucket-card { background-color: var(--bg-sidebar); border-color: var(--border-color); }
body.dark-theme .bucket-glass { background-color: var(--bg-card); border-color: var(--border-color); }

.user-badge-container { position: absolute; top: 24px; right: 40px; display: flex; flex-direction: column; align-items: flex-end; gap: 6px; z-index: 10; }
.current-user-badge { display: flex; align-items: center; gap: 12px; background: var(--bg-card); padding: 8px 16px; border-radius: 999px; font-size: 13px; font-weight: 500; color: var(--text-main); }
.current-user-badge .circle { width: 24px; height: 24px; background: var(--text-main); color: var(--bg-body); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 10px; font-weight: bold; overflow: hidden;}

body.dark-theme .current-user-badge { background-color: var(--bg-sidebar); color: var(--text-main); }
body.dark-theme .current-user-badge .circle { background-color: var(--text-main); color: var(--bg-body); }

body.dark-theme .detail-tab { background-color: var(--bg-sidebar); color: var(--text-main); }
body.dark-theme .detail-tab.active { background-color: var(--text-main); color: var(--bg-body); }
body.dark-theme .pill-btn { background-color: var(--bg-sidebar); color: var(--text-main); }
body.dark-theme .pill-btn.active { background-color: var(--text-main); color: var(--bg-body); }
body.dark-theme .btn-config-bandeiras { background-color: var(--bg-card); color: var(--text-main); }
body.dark-theme .btn-config-bandeiras i { color: var(--text-main); }
body.dark-theme .taxa-input-box { background-color: var(--bg-card); }
body.dark-theme .rk-card { background-color: var(--bg-sidebar); border-color: var(--border-color); }
body.dark-theme .modal-header { border-bottom-color: var(--border-color); color: var(--text-main); }
body.dark-theme .modal-footer { border-top-color: var(--border-color); }
body.dark-theme .btn-modal-action { background: var(--bg-sidebar); border-color: var(--border-color); }
body.dark-theme .btn-modal-action:hover { background: var(--bg-card); }

* { margin: 0; padding: 0; box-sizing: border-box; font-family: var(--font-family); transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease; }
body, html { height: 100vh; overflow: hidden; background-color: var(--bg-body); color: var(--text-main); }

/* ================= OVERLAY PARA OPACIDADE ================= */
#app-opacity-overlay { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: #000; opacity: 0; pointer-events: none; z-index: 9998; transition: opacity 0.2s; }

/* ================= NOTIFICAÇÕES (TOAST E CHAT) ================= */
#toast-container { position: fixed; bottom: 24px; right: 24px; display: flex; flex-direction: column; gap: 10px; z-index: 9999; }
.toast { background-color: #111827; color: #ffffff; padding: 12px 20px; border-radius: var(--radius-md); font-size: 14px; font-weight: 500; box-shadow: 0 4px 12px rgba(0,0,0,0.15); display: flex; align-items: center; gap: 8px; opacity: 0; transform: translateY(20px); animation: slideIn 0.3s forwards, fadeOut 0.3s forwards 3.7s; }
body.dark-theme .toast { background-color: #f9fafb; color: #111827; }
.toast i { color: var(--brand-green); font-size: 18px; }

#chat-notif-container { position: fixed; top: 24px; right: 24px; z-index: 10000; display: flex; flex-direction: column; gap: 10px; }
.chat-notif { background: var(--bg-body); border-left: 4px solid var(--brand-green); box-shadow: 0 4px 12px rgba(0,0,0,0.15); padding: 12px 16px; border-radius: 8px; width: 300px; cursor: pointer; opacity: 0; animation: slideInRight 0.4s forwards, fadeOutRight 0.4s forwards 5s; display: flex; align-items: flex-start; gap: 12px;}

@keyframes slideIn { to { opacity: 1; transform: translateY(0); } }
@keyframes fadeOut { to { opacity: 0; transform: translateY(-10px); } }
@keyframes slideInRight { from { opacity: 0; transform: translateX(50px); } to { opacity: 1; transform: translateX(0); } }
@keyframes fadeOutRight { to { opacity: 0; transform: translateX(50px); } }
@keyframes spin { 0% { transform: rotate(0deg); } 100% { transform: rotate(360deg); } }

/* ANIMAÇÃO DA CHAMADA / CUTUCO */
@keyframes shake {
    0% { transform: translate(1px, 1px) rotate(0deg); }
    10% { transform: translate(-1px, -2px) rotate(-1deg); }
    20% { transform: translate(-3px, 0px) rotate(1deg); }
    30% { transform: translate(3px, 2px) rotate(0deg); }
    40% { transform: translate(1px, -1px) rotate(1deg); }
    50% { transform: translate(-1px, 2px) rotate(-1deg); }
    60% { transform: translate(-3px, 1px) rotate(0deg); }
    70% { transform: translate(3px, 1px) rotate(-1deg); }
    80% { transform: translate(-1px, -1px) rotate(1deg); }
    90% { transform: translate(1px, 2px) rotate(0deg); }
    100% { transform: translate(1px, -2px) rotate(-1deg); }
}
.shake-animation { animation: shake 0.5s cubic-bezier(.36,.07,.19,.97) both; transform: translate3d(0, 0, 0); backface-visibility: hidden; perspective: 1000px; }

/* ================= TELAS BASE ================= */
.tela-app { display: none; height: 100%; width: 100%; position: relative; }
.tela-ativa { display: flex !important; }

/* ================= COMPONENTES FIXOS (STICKY) ================= */
.sticky-footer { position: sticky; bottom: 0; background: var(--bg-body); padding: 16px 0; border-top: 1px solid var(--border-color); z-index: 50; display: flex; justify-content: flex-end; gap: 12px; margin-top: auto; }

/* ================= TELA 1: LOGIN (Limpa) ================= */
#tela-login { flex-direction: column; position: relative; background-color: var(--bg-body); }
.logo-container { position: absolute; top: 30%; left: 50%; transform: translate(-50%, -50%); width: 100%; text-align: center; font-size: 44px; font-weight: 700; color: var(--text-main); letter-spacing: -1.5px; }
.bottom-panel { position: absolute; bottom: 0; left: 0; width: 100%; background-color: #000000; padding: 32px 24px 40px 24px; border-top-left-radius: 20px; border-top-right-radius: 20px; display: flex; flex-direction: column; gap: 12px; z-index: 20; }
.input-login { width: 100%; padding: 14px 16px; border-radius: 8px; border: 1px solid #333; background-color: #1a1a1a; color: #fff; font-size: 15px; outline: none; margin-bottom: 4px; transition: border-color 0.2s;}
.input-login:focus { border-color: var(--brand-green); }
.input-login::placeholder { color: #888; }
.btn-login { width: 100%; padding: 14px; border: none; border-radius: 8px; font-size: 15px; font-weight: 600; cursor: pointer; transition: opacity 0.2s; }
.btn-login:hover { opacity: 0.85; }
.btn-primary { background-color: var(--brand-green); color: #ffffff; }

/* ================= TELA 2: DASHBOARD ================= */
.sidebar { width: 80px; background-color: var(--bg-sidebar); border-right: 1px solid var(--border-color); display: flex; flex-direction: column; align-items: center; padding: 24px 0; flex-shrink: 0; position: relative; transition: all 0.3s; z-index: 100;}
.config-btn { background-color: #000; color: #fff; width: 40px; height: 40px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 20px; margin-bottom: 40px; cursor: pointer; border: none; }
.nav-item { display: flex; flex-direction: column; align-items: center; text-decoration: none; color: var(--text-main); margin-bottom: 32px; font-size: 11px; font-weight: 500; gap: 6px; cursor: pointer; width: 100%; padding: 8px 0; border-right: 3px solid transparent;}
.nav-item i { font-size: 24px; color: var(--text-secondary); }
.nav-item.active { border-right-color: var(--brand-green); }
.nav-item.active, .nav-item.active i { color: var(--brand-green); }
.nav-settings { position: absolute; bottom: 24px; left: 0; width: 100%; display: flex; flex-direction: column; align-items: center; cursor: pointer; color: var(--text-main); font-size: 11px; font-weight: 500; gap: 6px; }
.nav-settings i { font-size: 24px; color: var(--text-secondary); }
.nav-settings:hover i { color: var(--text-main); }

.main-wrapper { flex: 1; display: flex; overflow: hidden; position: relative; background-color: var(--bg-body); }
.col-right { flex: 1; padding: 32px 40px; overflow-y: auto; }
h2 { font-size: 18px; font-weight: 600; margin-bottom: 16px; color: var(--text-main); }
.tools-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 12px; margin-bottom: 40px; }
.tool-card { background-color: var(--bg-card); border-radius: var(--radius-md); padding: 16px; height: 110px; display: flex; flex-direction: column; justify-content: space-between; cursor: pointer; transition: background 0.2s ease, transform 0.1s ease; border: 1px solid transparent; }
.tool-card:hover { background-color: var(--bg-sidebar); transform: translateY(-2px); border-color: var(--border-color); }
.tool-card i { font-size: 24px; color: var(--text-main); }
.tool-card span { font-size: 13px; font-weight: 500; line-height: 1.2; color: var(--text-main); }

/* ================= TELAS: MODAIS GERAIS ================= */
.page-modal { background-color: var(--bg-body); flex-direction: column; padding: 32px 10%; overflow-y: auto; }
.header-modal { display: flex; justify-content: space-between; align-items: center; margin-bottom: 32px; width: 100%; }
.btn-circle-back { width: 40px; height: 40px; border-radius: 50%; background-color: var(--bg-card); color: var(--text-main); border: none; display: flex; align-items: center; justify-content: center; font-size: 18px; cursor: pointer; transition: 0.2s; }
.btn-circle-back:hover { background-color: var(--border-color); }
.btn-concluir { background-color: var(--text-main); color: var(--bg-body); border: none; padding: 10px 24px; border-radius: 999px; font-weight: 600; font-size: 14px; cursor: pointer; transition: 0.2s;}
.btn-concluir:hover { opacity: 0.85; }
.page-title { font-size: 24px; font-weight: 600; margin-bottom: 8px; color: var(--text-main); }
.page-subtitle { font-size: 14px; color: var(--text-secondary); margin-bottom: 32px; }

.action-block { background-color: var(--bg-card); padding: 24px; border-radius: var(--radius-md); display: flex; align-items: center; gap: 16px; margin-bottom: 16px; cursor: pointer; transition: 0.2s; border: 1px solid transparent; }
.action-block:hover { background-color: var(--bg-sidebar); border-color: var(--border-color); }
.action-block i { font-size: 28px; color: var(--text-main); }
.action-block-text strong { display: block; font-size: 16px; margin-bottom: 4px; font-weight: 600; color: var(--text-main); }
.action-block-text span { font-size: 14px; color: var(--text-secondary); }

.form-section { margin-bottom: 24px; }
.form-label { display: block; font-size: 14px; font-weight: 500; margin-bottom: 12px; color: var(--text-main); }
.options-grid { display: flex; flex-wrap: wrap; gap: 10px; }
.btn-select { background-color: var(--bg-body); border: 1px solid var(--border-color); color: var(--text-main); padding: 10px 16px; border-radius: 4px; font-size: 13px; font-weight: 500; cursor: pointer; transition: 0.2s; }
.btn-select:hover { border-color: var(--text-tertiary); }
.btn-select.active { background-color: var(--brand-green); color: #ffffff; border-color: var(--brand-green); }

.btn-status-cli[data-status="nao_concretizado"].active { background-color: #ef4444 !important; border-color: #ef4444 !important; color: #ffffff !important; }

.input-gray { width: 100%; background-color: var(--bg-card); border: 1px solid transparent; padding: 16px; border-radius: var(--radius-md); font-size: 15px; color: var(--text-main); outline: none; }
.input-gray:focus { border-color: var(--text-tertiary); }

.select-cliente { width: 100%; background-color: var(--bg-card); padding: 16px; border-radius: var(--radius-md); display: flex; justify-content: space-between; align-items: center; cursor: pointer; margin-top: 16px; border: 1px solid transparent; }
.select-cliente:hover { border-color: var(--border-color); }
.select-cliente-left { display: flex; align-items: center; gap: 12px; font-size: 15px; color: var(--text-secondary); }
.select-cliente-left i { font-size: 20px; color: var(--text-main); }
.select-cliente-left span { color: var(--text-main); }

.btn-modal-action { background: var(--bg-card); border: 1px solid transparent; width: 100%; display: flex; align-items: center; gap: 12px; padding: 14px 16px; border-radius: 8px; cursor: pointer; color: var(--text-main); transition: 0.2s; font-size: 14px; font-weight: 500; margin-bottom: 8px; } 
.btn-modal-action:hover { background: var(--border-color); }

/* ================= TELA: PRODUTOS E HISTÓRICO ================= */
.prod-item { background: #ffffff; border-radius: 12px; padding: 16px; display: flex; align-items: center; gap: 16px; margin-bottom: 12px; cursor: pointer; border: 1px solid #e5e7eb; transition: all 0.2s ease; box-shadow: 0 2px 4px rgba(0,0,0,0.02); }
.prod-item:hover { border-color: var(--brand-blue); box-shadow: 0 4px 12px rgba(0,0,0,0.08); transform: translateY(-2px); }
.prod-icon { width: 48px; height: 48px; background: #f8f9fa; border-radius: 12px; display: flex; align-items: center; justify-content: center; color: var(--brand-blue); font-size: 24px; border: none; }
.prod-name { font-size: 15px; font-weight: 500; color: var(--text-main); margin-bottom: 0; }

/* ================= TELA: CONFIGURAÇÃO DE TAXAS ================= */
.tabs-container { display: flex; gap: 8px; margin-bottom: 32px; }
.tab-btn { padding: 10px 20px; border-radius: 4px; font-size: 14px; font-weight: 500; border: none; cursor: pointer; background-color: var(--bg-card); color: var(--text-main); }
.tab-btn.active { background-color: var(--text-main); color: var(--bg-body); }
.section-title { font-size: 16px; font-weight: 500; margin-bottom: 16px; color: var(--text-main); }
.pill-container { display: flex; gap: 12px; margin-bottom: 32px; flex-wrap: wrap; }
.pill-btn { display: flex; align-items: center; gap: 8px; padding: 10px 16px; border-radius: 4px; font-size: 12px; font-weight: 600; border: none; cursor: pointer; background-color: var(--bg-sidebar); color: var(--text-main); }
.pill-btn.active { background-color: var(--text-main); color: var(--bg-body); }
.taxa-row { display: flex; justify-content: space-between; align-items: center; background-color: var(--bg-sidebar); padding: 14px 16px; border-radius: 4px; margin-bottom: 8px; border: 1px solid transparent; transition: 0.2s;}
.taxa-row:hover { border-color: var(--border-color); }
.taxa-info { display: flex; flex-direction: column; gap: 6px; }
.taxa-name { font-size: 14px; font-weight: 500; color: var(--text-main); }
.taxa-brands { display: flex; gap: 6px; flex-wrap: wrap; }
.brand-badge { font-size: 10px; background-color: var(--bg-body); border: 1px solid var(--border-color); padding: 2px 6px; border-radius: 4px; color: var(--text-main); font-weight: 500; }
.btn-config-bandeiras { width: 42px; height: 42px; border-radius: 50%; background-color: var(--bg-card); border: none; display: flex; align-items: center; justify-content: center; cursor: pointer; transition: 0.2s; position: relative; }
.btn-config-bandeiras:hover { background-color: var(--border-color); }

.modal-overlay { display: none; position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: rgba(0,0,0,0.5); z-index: 10000; align-items: center; justify-content: center; }
.modal-overlay.active { display: flex; }
.modal-container { background: var(--bg-body); width: 450px; max-width: 90%; border-radius: 12px; display: flex; flex-direction: column; max-height: 85vh; box-shadow: 0 10px 25px rgba(0,0,0,0.2); border: 1px solid var(--border-color); }
.modal-header { padding: 24px; border-bottom: 1px solid var(--border-color); color: var(--text-main); }
.modal-header h3 { font-size: 16px; font-weight: 500; color: var(--text-main); }
.modal-body { padding: 16px 24px; overflow-y: auto; flex: 1; }
.brand-row { display: flex; justify-content: space-between; align-items: center; margin-bottom: 12px; }
.brand-row span { font-size: 14px; font-weight: 400; color: var(--text-main); }
.taxa-input-box { display: flex; align-items: center; background-color: var(--bg-card); border-radius: 4px; padding: 8px 12px; width: 110px; }
.taxa-input-box input { border: none; outline: none; background: transparent; width: 100%; text-align: left; font-size: 14px; font-weight: 400; color: var(--text-main); }
.modal-footer { padding: 24px; border-top: 1px solid var(--border-color); display: flex; gap: 12px; }
.btn-cancelar { flex: 1; padding: 14px; background: var(--bg-card); border: 1px solid var(--border-color); border-radius: 8px; font-weight: 500; cursor: pointer; transition: 0.2s; color: var(--text-main); }
.btn-cancelar:hover { opacity: 0.8; }
.btn-salvar { flex: 1; padding: 14px; background: #000; color: #fff; border: none; border-radius: 8px; font-weight: 500; cursor: pointer; transition: 0.2s; }

/* ================= TELA: USUÁRIOS E PERMISSÕES ================= */
.users-layout { display: flex; height: calc(100vh - 160px); width: 100%; margin-top: 16px; }
.users-list-col { width: 400px; border-right: 1px solid var(--border-color); padding-right: 32px; overflow-y: auto; }
.users-detail-col { flex: 1; padding-left: 32px; display: flex; flex-direction: column; overflow-y: auto; }

.u-tab-container { display: flex; gap: 8px; margin-bottom: 24px; }
.u-tab { padding: 10px 16px; font-size: 13px; font-weight: 500; background: var(--bg-card); border: none; border-radius: 4px; cursor: pointer; color: var(--text-main); }
.u-tab.active { background: var(--text-main); color: var(--bg-body); }

.letter-group { font-size: 14px; color: var(--text-tertiary); margin-bottom: 8px; margin-top: 24px; font-weight: 600; }
.user-item { background: var(--bg-sidebar); padding: 12px 16px; border-radius: 8px; display: flex; align-items: center; gap: 16px; margin-bottom: 8px; cursor: pointer; border: 1px solid transparent; transition: 0.2s; }
.user-item:hover, .user-item.active { border-color: var(--border-color); background: var(--bg-card); }
.u-avatar { width: 36px; height: 36px; background: var(--bg-body); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 13px; font-weight: 600; color: var(--text-main); border: 1px solid var(--border-color); flex-shrink: 0; overflow: hidden; }
.u-name { font-size: 14px; font-weight: 500; flex: 1; color: var(--text-main);}
.u-role-badge { font-size: 10px; background: var(--bg-card); padding: 2px 6px; border-radius: 4px; color: var(--text-secondary); font-weight: 600; }

.empty-user-detail { flex: 1; display: flex; align-items: center; justify-content: center; }
.empty-pill { border: 1px solid var(--border-color); background: var(--bg-sidebar); padding: 12px 24px; border-radius: 999px; font-size: 14px; color: var(--text-secondary); }

.user-profile-card { display: none; flex-direction: column; width: 100%; max-width: 600px; padding-bottom: 40px;}
.user-profile-card.active { display: flex; }

.detail-tabs { display: flex; gap: 8px; margin-bottom: 32px; border-bottom: 1px solid var(--border-color); padding-bottom: 16px;}
.detail-tab { padding: 8px 16px; font-size: 13px; font-weight: 500; background: var(--bg-card); border: none; border-radius: 4px; cursor: pointer; color: var(--text-main); }
.detail-tab.active { background: var(--text-main); color: var(--bg-body); }

.tab-content { display: none; flex-direction: column; }
.tab-content.active { display: flex; }

.photo-upload-box { width: 120px; height: 120px; background: var(--bg-card); border-radius: 8px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; color: var(--brand-blue); font-size: 13px; font-weight: 500; cursor: pointer; margin-bottom: 32px; overflow: hidden;}
.photo-upload-box:hover { opacity: 0.8; }

.input-outline { width: 100%; padding: 14px 16px; border: 1px solid var(--border-color); border-radius: 8px; font-size: 14px; outline: none; color: var(--text-main); transition: border-color 0.2s; background-color: var(--bg-body); }
.input-outline:focus { border-color: var(--text-tertiary); }
.mb-2 { margin-bottom: 12px; }

.password-wrapper { position: relative; display: flex; align-items: center; }
.password-wrapper .input-outline { padding-right: 48px; }
.btn-eye { position: absolute; right: 12px; background: transparent; border: none; font-size: 20px; cursor: pointer; color: var(--text-secondary); display: flex; align-items: center; justify-content: center; }

.poderes-header p { font-size: 13px; color: var(--text-secondary); margin-bottom: 24px; line-height: 1.5; }
.group-title { font-size: 16px; font-weight: 500; mt: 16px; mb: 16px; color: var(--text-main); }
.perm-list-item { display: flex; justify-content: space-between; align-items: center; padding: 14px 0; border-bottom: 1px solid var(--border-color); }
.perm-title { display: flex; align-items: center; gap: 12px; font-size: 15px; font-weight: 500; color: var(--text-main); }
.perm-title i { font-size: 20px; }

.btn-test-user { mt: 40px; width: 100%; padding: 14px; background: var(--bg-card); border: 1px solid var(--border-color); border-radius: 8px; font-weight: 600; cursor: pointer; transition: 0.2s; color: var(--text-main); }
.btn-test-user:hover { opacity: 0.8; }

/* Switches Globais */
.switch { position: relative; display: inline-block; width: 46px; height: 26px; }
.switch input { opacity: 0; width: 0; height: 0; }
.slider { position: absolute; cursor: pointer; top: 0; left: 0; right: 0; bottom: 0; background-color: #e5e7eb; transition: .3s; border-radius: 6px; border: 1px solid #d1d5db;}
.slider:before { position: absolute; content: ""; height: 18px; width: 18px; left: 3px; bottom: 3px; background-color: white; transition: .3s; border-radius: 4px; box-shadow: 0 1px 3px rgba(0,0,0,0.2);}
input:checked + .slider { background-color: var(--brand-green); border-color: var(--brand-green); }
input:checked + .slider:before { transform: translateX(20px); }

body.dark-theme .slider { background-color: var(--bg-sidebar); border-color: var(--border-color); }
body.dark-theme .slider:before { background-color: var(--text-secondary); }
body.dark-theme input:checked + .slider { background-color: var(--brand-green); border-color: var(--brand-green); }
body.dark-theme input:checked + .slider:before { background-color: #fff; }

::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: #d1d5db; border-radius: 10px; }

/* ================= TELA: CLIENTES E DARK MODE (VERDE) ================= */
#tela-clientes, #tela-clientes .users-list-col, #tela-clientes .users-detail-col, #tela-clientes .input-gray, #tela-clientes .cli-search, #tela-clientes .user-item, #tela-clientes .doc-upload-box, #tela-clientes .detail-tab, #tela-clientes .page-modal, #tela-clientes .letter-group, #tela-clientes .form-label, #tela-clientes .u-name, #tela-clientes .page-title, #tela-clientes .btn-circle-back { transition: background-color 0.4s ease, color 0.4s ease, border-color 0.4s ease; }

#tela-clientes.add-mode-green { background-color: #064e3b; color: #ffffff; }
#tela-clientes.add-mode-green .page-title, #tela-clientes.add-mode-green .form-label, #tela-clientes.add-mode-green .u-name, #tela-clientes.add-mode-green .detail-tab, #tela-clientes.add-mode-green .photo-upload-box, #tela-clientes.add-mode-green .doc-upload-box, #tela-clientes.add-mode-green .input-gray { color: #ffffff; }
#tela-clientes.add-mode-green .input-gray::placeholder { color: #a7f3d0; }
#tela-clientes.add-mode-green .users-list-col > div[style*="background: var(--bg-sidebar)"] { background-color: #065f46 !important; border: 1px solid #047857 !important; }
#tela-clientes.add-mode-green .cli-search, #tela-clientes.add-mode-green .input-gray, #tela-clientes.add-mode-green .photo-upload-box, #tela-clientes.add-mode-green .doc-upload-box, #tela-clientes.add-mode-green .detail-tab { background-color: #065f46 !important; border: 1px solid #047857; }
#tela-clientes.add-mode-green .detail-tab.active { background-color: var(--brand-green) !important; border-color: var(--brand-green) !important; }
#tela-clientes.add-mode-green .user-item, #tela-clientes.add-mode-green .cli-tag { background-color: #065f46; color: #ffffff; border-color: transparent; }
#tela-clientes.add-mode-green .user-item:hover, #tela-clientes.add-mode-green .cli-tag:hover { background-color: #047857; }
#tela-clientes.add-mode-green .user-item.active, #tela-clientes.add-mode-green .cli-tag.active { background-color: #ffffff !important; border-color: #ffffff !important; color: #000000 !important; }
#tela-clientes.add-mode-green .cli-tag-black { background-color: #ffffff; color: #000000; }
#tela-clientes.add-mode-green #cli-form-tags { background-color: #065f46 !important; border: 1px solid #047857 !important; }
#tela-clientes.add-mode-green .letter-group, #tela-clientes.add-mode-green span[id="cli-count"] { color: #a7f3d0; }
#tela-clientes.add-mode-green .btn-circle-back { background-color: #065f46; color: #ffffff; }
#tela-clientes.add-mode-green .btn-circle-back:hover { background-color: #047857; }
#tela-clientes.add-mode-green .btn-cancelar { color: #ffffff !important; background: transparent !important; border: 1px solid #34d399 !important; }
#tela-clientes.add-mode-green .history-card { background-color: #065f46; border-color: #047857; }
#tela-clientes.add-mode-green .empty-pill { background: #065f46; border-color: #047857; color: #a7f3d0; }
#tela-clientes.add-mode-green .sticky-footer { background-color: #064e3b; border-color: #047857; }

.cli-filter-container { display: flex; flex-wrap: wrap; gap: 8px; margin: 16px 0; }
.cli-tag { display: inline-flex; align-items: center; gap: 6px; padding: 6px 12px; border-radius: 999px; font-size: 13px; font-weight: 500; cursor: pointer; transition: 0.2s; }
.dot { width: 10px; height: 10px; border-radius: 50%; display: inline-block; flex-shrink: 0; margin-right: 4px;}

.cli-search-box { position: relative; mt: 16px; }
.cli-search { width: 100%; padding: 12px 16px; background: var(--bg-card); border: none; border-radius: 8px; outline: none; font-size: 14px; color: var(--text-main); }
.cli-search-box i { position: absolute; right: 16px; top: 50%; transform: translateY(-50%); color: var(--text-secondary); font-size: 18px; }

.doc-upload-container { display: flex; gap: 12px; mt: 12px; }
.doc-upload-box { position: relative; flex: 1; border: 2px dashed var(--border-color); background: var(--bg-sidebar); border-radius: 8px; padding: 24px; text-align: center; color: var(--text-secondary); transition: 0.2s; font-size: 14px; font-weight: 500; display: flex; flex-direction: column; align-items: center; justify-content: center; }
.doc-upload-box:hover { border-color: var(--brand-green); color: var(--brand-green); }
.doc-upload-box i { display: block; font-size: 24px; mt: 8px; }

.doc-action-overlay { display: none; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0,0,0,0.7); border-radius: 6px; flex-direction: column; justify-content: center; align-items: center; gap: 8px; z-index: 10;}
.doc-upload-box.has-file .doc-action-overlay { display: flex; }
.btn-doc-action { background: #fff; color: #000; border: none; padding: 6px 12px; border-radius: 4px; font-size: 12px; font-weight: 600; cursor: pointer; width: 80%; display: flex; align-items: center; justify-content: center; gap: 6px; }
.btn-doc-action:hover { background: var(--brand-green); color: #fff; }

.slide-in-right { animation: slideInRight 0.4s ease-out forwards; }

/* ================= TELA: RELATÓRIOS E COMPONENTES ================= */
.resumo-box { background-color: var(--bg-sidebar); border: 1px solid var(--border-color); border-radius: var(--radius-md); padding: 20px; mt: 16px; display: flex; flex-direction: column; gap: 12px; }
.resumo-row { display: flex; justify-content: space-between; font-size: 14px; color: var(--text-secondary); }
.resumo-row span:last-child { font-weight: 500; color: var(--text-main); }
.resumo-row.highlight { mt: 8px; padding-top: 16px; border-top: 1px dashed var(--border-color); font-weight: 600; color: var(--text-main); font-size: 16px; }
.resumo-row.highlight span:last-child { font-size: 18px; }

.report-card { background: var(--bg-sidebar); border-radius: 8px; padding: 20px; display: flex; justify-content: space-between; align-items: center; cursor: pointer; mt: 16px; transition: 0.2s; border: 1px solid transparent; }
.report-card:hover { border-color: var(--border-color); background: var(--bg-card); }
.btn-report-green { background: var(--brand-green); color: #fff; padding: 8px 16px; border-radius: 6px; border: none; font-weight: 600; font-size: 13px; cursor: pointer; }

.acc-item { border-bottom: 1px solid var(--border-color); }
.acc-header { padding: 16px 0; display: flex; justify-content: space-between; align-items: center; cursor: pointer; font-size: 16px; font-weight: 500; color: var(--text-main); }
.acc-header span.count { font-size: 13px; color: var(--text-tertiary); font-weight: 400; ml: 4px; }
.btn-acc-toggle { width: 28px; height: 28px; border-radius: 50%; background: var(--border-color); border: none; color: var(--text-main); display: flex; align-items: center; justify-content: center; cursor: pointer; font-size: 14px; transition: 0.2s;}
.acc-header.active .btn-acc-toggle { transform: rotate(45deg); }

.acc-body { display: none; padding: 12px 0 24px 0; }
.acc-body.active { display: block; }

.report-user-row { background: var(--bg-sidebar); padding: 12px 16px; border-radius: 8px; display: flex; align-items: center; justify-content: space-between; mt: 8px;}
.report-user-left { display: flex; align-items: center; gap: 12px; }
.btn-whatsapp { background: var(--brand-green); color: #fff; width: 40px; height: 40px; border-radius: 8px; border: none; display: flex; align-items: center; justify-content: center; font-size: 22px; cursor: pointer; transition: 0.2s;}
.btn-whatsapp:hover { opacity: 0.85; }
.date-badge { background: var(--bg-body); border: 1px solid var(--border-color); padding: 8px 12px; border-radius: 6px; font-size: 13px; font-weight: 500; color: var(--text-main); }

.history-card { background: var(--bg-sidebar); border: 1px solid var(--border-color); padding: 16px; border-radius: 8px; mt: 12px; display: flex; justify-content: space-between; align-items: center; }

/* ================= TELA DE CONFIGURAÇÕES GERAIS ================= */
#tela-configuracoes-gerais .page-title { color: #3b82f6; font-size: 28px; }
#tela-configuracoes-gerais .settings-banner { border: 1px solid #d97706; padding: 16px; border-radius: 8px; mt: 32px; background: transparent; color: var(--text-main); }
#tela-configuracoes-gerais .settings-banner strong { font-weight: 700; color: #d97706; }
#tela-configuracoes-gerais .settings-group { mt: 32px; }
#tela-configuracoes-gerais .settings-group-title { font-size: 18px; font-weight: 600; mt: 16px; color: var(--text-main); }
#tela-configuracoes-gerais .setting-row { display: flex; align-items: center; gap: 12px; mt: 12px; color: var(--text-main); font-weight: 500; }

.theme-switch { position: relative; display: inline-block; width: 46px; height: 26px; }
.theme-switch input { opacity: 0; width: 0; height: 0; }
.theme-slider { position: absolute; cursor: pointer; top: 0; left: 0; right: 0; bottom: 0; background: var(--bg-sidebar); border: 1px solid var(--border-color); transition: .3s; border-radius: 999px;}
.theme-slider:before { position: absolute; content: ""; height: 18px; width: 18px; left: 3px; bottom: 3px; background-color: var(--text-secondary); transition: .3s; border-radius: 50%; }
.theme-switch input:checked + .theme-slider { background-color: #3b82f6; border-color: #3b82f6; }
.theme-switch input:checked + .theme-slider:before { transform: translateX(20px); background-color: #fff; }

/* ================= TELA: RANKING E DESEMPENHO ================= */
.rk-header-top { display: flex; justify-content: space-between; align-items: center; mt: 24px; padding-bottom: 16px; border-bottom: 1px solid var(--border-color); }
.rk-update-badge { font-size: 13px; color: var(--text-secondary); background: var(--bg-sidebar); padding: 6px 12px; border-radius: 4px; border: 1px solid var(--border-color); }

.rk-container { display: flex; gap: 32px; align-items: flex-end; mt: 40px; height: 350px; padding-bottom: 20px;}
.rk-podium-area { display: flex; align-items: flex-end; justify-content: center; gap: 8px; flex: 1; height: 100%; }
.rk-list-area { flex: 1; display: flex; flex-direction: column; gap: 12px; overflow-y: auto; max-height: 100%; padding-right: 12px;}

.podium-col { display: flex; flex-direction: column; align-items: center; width: 100px; }
.podium-medal { width: 36px; height: 36px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-weight: bold; font-size: 16px; mt: 12px; box-shadow: 0 4px 6px rgba(0,0,0,0.1); color: #fff;}
.podium-medal.gold { background: linear-gradient(135deg, #fbbf24, #d97706); }
.podium-medal.silver { background: linear-gradient(135deg, #e5e7eb, #9ca3af); color: #111;}
.podium-medal.bronze { background: linear-gradient(135deg, #fca5a5, #dc2626); }

.podium-bar { width: 100%; border-top-left-radius: 8px; border-top-right-radius: 8px; display: flex; flex-direction: column; align-items: center; justify-content: flex-end; padding-bottom: 16px; color: #fff; font-weight: bold; font-size: 40px; text-shadow: 1px 1px 2px rgba(0,0,0,0.2); transition: height 0.5s ease; }
.bar-1 { height: 260px; background: linear-gradient(180deg, #f59e0b, #b45309); }
.bar-2 { height: 180px; background: linear-gradient(180deg, #818cf8, #4f46e5); }
.bar-3 { height: 120px; background: linear-gradient(180deg, #38bdf8, #0284c7); }
.podium-name { font-size: 13px; font-weight: 600; color: var(--text-main); mt: 8px; text-align: center; }
.podium-props { font-size: 11px; font-weight: 400; text-align: center; mt: 8px; color: rgba(255,255,255,0.8); font-size: 12px; text-shadow: none; line-height: 1.3;}

.rk-card { position: relative; background: var(--bg-card); border-radius: 8px; padding: 16px; display: flex; justify-content: space-between; align-items: center; border: 1px solid transparent; }
.rk-card-left { display: flex; align-items: center; gap: 16px; }
.rk-circle { width: 32px; height: 32px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-weight: 600; font-size: 14px; color: #fff;}
.rk-card-title { font-weight: 600; font-size: 15px; color: var(--text-main); mt: 4px; }
.rk-card-sub { font-size: 11px; color: var(--text-secondary); }
.rk-card-right { text-align: right; }
.rk-card-props { font-size: 12px; color: var(--text-secondary); mt: 4px; }
.rk-card-val { font-size: 18px; font-weight: 700; color: var(--text-main); }

.rk-total-bar { display: flex; justify-content: flex-end; align-items: center; padding-top: 16px; mt: 16px; border-top: 1px solid var(--border-color); font-size: 16px; color: var(--text-main); }

/* CUSTOM TOOLTIP RANKING */
.rk-tooltip { 
    display: none; position: absolute; bottom: 100%; left: 50%; transform: translateX(-50%); 
    background: #111827; color: #fff; padding: 10px; border-radius: 6px; font-size: 12px; 
    white-space: pre-wrap; z-index: 9999; min-width: 200px; text-align: left; line-height: 1.4;
    box-shadow: 0 4px 12px rgba(0,0,0,0.2); pointer-events: none; mt: 8px; border: 1px solid #374151;
}
.rk-tooltip::after { content: ''; position: absolute; top: 100%; left: 50%; margin-left: -5px; border-width: 5px; border-style: solid; border-color: #111827 transparent transparent transparent; }
.rk-card:hover .rk-tooltip { display: block; }
body.dark-theme .rk-tooltip { background: #f9fafb; color: #111827; border-color: #d1d5db; }
body.dark-theme .rk-tooltip::after { border-color: #f9fafb transparent transparent transparent; }

/* ================= TELA: CAIXA ESPÉCIE E DIÁRIO ================= */
.ledger-container { width: 100%; background: transparent; mt: 16px; }
.ledger-header { display: grid; grid-template-columns: 1.5fr 3fr 1fr 1fr 1fr; padding: 12px; border-bottom: 2px solid var(--border-color); font-weight: 600; color: var(--text-secondary); font-size: 13px; }
.ledger-row { display: grid; grid-template-columns: 1.5fr 3fr 1fr 1fr 1fr; padding: 16px 12px; border-bottom: 1px solid var(--border-color); align-items: center; font-size: 14px; color: var(--text-main); transition: 0.2s; cursor: pointer; }
.ledger-row:hover { background-color: var(--bg-card); }
.ledger-val-in { color: var(--brand-green); font-weight: 600; }
.ledger-val-out { color: var(--brand-orange); font-weight: 600; }
.ledger-meta { font-size: 11px; color: var(--text-tertiary); display: block; mt: 4px; font-style: italic; }

body.dark-theme .ledger-row:hover { background-color: var(--bg-sidebar); }

.ledger-row-diario { display: grid; grid-template-columns: 0.9fr 0.6fr 1.5fr 1fr 1fr 0.7fr 1.2fr 1.2fr 1fr 1fr 0.5fr; padding: 12px 16px; border-bottom: 1px solid var(--border-color); align-items: center; font-size: 12px; color: var(--text-main); }
.ledger-row-diario:nth-child(even) { background-color: var(--bg-sidebar); }

.input-mensal { width: 100%; border: 1px solid var(--border-color); background: transparent; color: var(--text-main); padding: 6px; border-radius: 4px; font-size: 12px; outline: none; }
.input-mensal:focus { border-color: var(--brand-green); }

/* TELA DE DESPESAS */
.despesa-row { display: flex; justify-content: space-between; align-items: center; padding: 16px; background: var(--bg-sidebar); border: 1px solid var(--border-color); border-radius: 8px; mt: 8px; }
.despesa-row .desc { font-weight: 500; color: var(--text-main); font-size: 15px;}
.despesa-row .meta { font-size: 12px; color: var(--text-secondary); mt: 4px;}
.despesa-row .val { font-weight: 600; font-size: 16px; color: var(--brand-orange); }

/* CARTAO MULTIPLO */
.cartao-block { background: var(--bg-sidebar); border: 1px solid var(--border-color); padding: 16px; border-radius: 8px; mt: 16px; position: relative;}
.cartao-block-title { font-weight: 600; font-size: 14px; mt: 12px; color: var(--text-main); display: flex; justify-content: space-between; align-items: center;}
.btn-remove-cartao { background: transparent; border: none; color: #ef4444; cursor: pointer; font-size: 18px; display: flex; align-items: center; justify-content: center;}

/* CHAT E CALENDARIO */
.chat-sidebar-users { width: 250px; border-right: 1px solid var(--border-color); overflow-y: auto; background: var(--bg-sidebar); }
.chat-main { flex: 1; display: flex; flex-direction: column; background: var(--bg-body); }
.chat-messages { flex: 1; padding: 24px; overflow-y: auto; display: flex; flex-direction: column; gap: 12px; }
.chat-input-area { padding: 16px 24px; border-top: 1px solid var(--border-color); display: flex; gap: 12px; align-items: center; background: var(--bg-sidebar); }
.chat-message { max-width: 70%; padding: 12px 16px; border-radius: 8px; font-size: 14px; line-height: 1.4; position: relative; }
.chat-message.sent { background: var(--brand-green); color: #fff; align-self: flex-end; border-bottom-right-radius: 0; }
.chat-message.received { background: var(--bg-card); color: var(--text-main); align-self: flex-start; border-bottom-left-radius: 0; }
.chat-meta { font-size: 10px; mt: 4px; opacity: 0.8; text-align: right; }

.chat-msg-actions { display: none; position: absolute; top: -12px; right: 10px; background: var(--bg-card); border: 1px solid var(--border-color); border-radius: 4px; padding: 2px 4px; gap: 6px; box-shadow: 0 2px 4px rgba(0,0,0,0.1); }
.chat-message:hover .chat-msg-actions { display: flex; }
.chat-msg-actions button { background: transparent; border: none; cursor: pointer; color: var(--text-secondary); font-size: 14px; display:flex; align-items:center; justify-content:center;}
.chat-msg-actions button:hover { color: var(--brand-blue); }
.msg-rascunho { font-style: italic; color: #fbbf24; font-size: 11px; margin-top: 4px; }

.chat-user-item { padding: 12px 16px; border-bottom: 1px solid var(--border-color); cursor: pointer; display: flex; align-items: center; gap: 12px; }
.chat-user-item:hover { background: var(--bg-card); }
.chat-user-item.active { background: var(--bg-card); border-left: 4px solid var(--brand-green); }

.calendar-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; mt: 16px; }
.calendar-day-header { text-align: center; font-size: 12px; font-weight: 600; color: var(--text-secondary); padding: 8px 0; }
.calendar-day { background: var(--bg-sidebar); border: 1px solid var(--border-color); min-height: 80px; padding: 8px; border-radius: 6px; display: flex; flex-direction: column; cursor: pointer; }
.calendar-day.empty { background: transparent; border-color: transparent; cursor: default; }
.calendar-day:hover:not(.empty) { border-color: var(--brand-blue); }
.calendar-day .day-num { font-size: 14px; font-weight: 600; color: var(--text-main); mt: 4px; }
.calendar-event { font-size: 10px; background: var(--brand-blue); color: #fff; padding: 2px 4px; border-radius: 2px; mt: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* Estilos para a ferramenta de Serviços (Passo 4) */
.service-editable-card { transition: box-shadow 0.2s; mt: 12px; padding: 20px; }
.service-editable-card:hover { box-shadow: 0 4px 12px rgba(0,0,0,0.08); }
.service-editable-icon { font-size: 28px; color: var(--brand-blue); mt: 4px;}
.service-text-group { flex: 1; display: flex; flex-direction: column; gap: 6px; }
.input-plain-h { border: none; outline: none; background: transparent; font-size: 16px; font-weight: 600; color: var(--text-main); width: 100%; padding: 4px 0;}
.input-plain-h:focus { border-bottom: 2px solid var(--brand-blue); }
.input-plain { border: none; outline: none; background: transparent; font-size: 14px; color: var(--text-secondary); width: 100%; resize: none; min-height: 50px; padding: 4px 0;}
.input-plain:focus { border-bottom: 1px solid var(--border-color); }
.service-action-group { display: flex; flex-direction: column; gap: 8px; align-items: center; }
.btn-circle-action { width: 32px; height: 32px; border-radius: 50%; border: none; background: var(--bg-body); color: var(--text-secondary); display: flex; align-items: center; justify-content: center; font-size: 16px; cursor: pointer; transition: 0.2s; }
.btn-circle-action:hover { background: var(--bg-card); color: var(--text-main); }
.save-service-btn:hover { color: var(--brand-green); }
.delete-service-btn:hover { color: var(--brand-orange); }

/* Estilos para os Baldes (Metas) ATUALIZADO P/ LISTA LATERAL */
.bucket-card { background: var(--bg-card); border-radius: 12px; padding: 20px; text-align: left; border: 1px solid var(--border-color); display: flex; flex-direction: row; align-items: stretch; transition: 0.3s; gap: 20px;}
.bucket-card:hover { transform: translateY(-4px); box-shadow: 0 10px 15px -3px rgba(0,0,0,0.1); }
.bucket-left { display: flex; flex-direction: column; align-items: center; width: 150px; flex-shrink: 0; text-align: center; position: relative;}
.bucket-right { flex: 1; border-left: 1px dashed var(--border-color); padding-left: 20px; display: flex; flex-direction: column; }
.bucket-right-title { font-size: 12px; font-weight: 700; color: var(--text-secondary); text-transform: uppercase; margin-bottom: 12px; letter-spacing: 0.5px;}
.bucket-right-item { font-size: 13px; font-weight: 500; color: var(--text-main); display: flex; justify-content: space-between; align-items: center; border-bottom: 1px dashed var(--border-color); padding-bottom: 6px; margin-bottom: 6px;}
.bucket-title { font-size: 16px; font-weight: 600; color: var(--text-main); margin-bottom: 4px; width: 100%; word-break: break-word;}
.bucket-glass { width: 100px; height: 120px; border: 4px solid var(--border-color); border-top: none; border-radius: 0 0 16px 16px; position: relative; overflow: visible; margin: 12px 0; background: var(--bg-body); }
.bucket-fill { position: absolute; bottom: 0; left: 0; width: 100%; background: var(--brand-blue); transition: height 1s cubic-bezier(0.4, 0, 0.2, 1); border-radius: 0 0 12px 12px; }
.bucket-fill.success { background: var(--brand-green); }

/* Botão CSV Individual */
.btn-export-small { background: transparent; border: 1px solid var(--border-color); color: var(--text-secondary); padding: 6px 12px; border-radius: 6px; font-size: 12px; font-weight: 500; cursor: pointer; transition: 0.2s; display: flex; align-items: center; gap: 6px; margin-top: 16px; justify-content: center; width: 100%; }
.btn-export-small:hover { background: var(--bg-card); color: var(--text-main); }

/* Tiers for bucket */
.bucket-tier-line { position: absolute; width: 100%; border-bottom: 2px dashed rgba(255,255,255,0.6); left: 0; z-index: 5; }
.bucket-tier-label { position: absolute; right: 4px; bottom: 2px; font-size: 9px; font-weight: 800; color: rgba(255,255,255,0.9); text-shadow: 0 1px 2px rgba(0,0,0,0.5); }
/* ================= EFEITO PIX NUDGE ================= */
@keyframes shake-pix {
    0% { transform: translate(1px, 1px) rotate(0deg); }
    10% { transform: translate(-1px, -2px) rotate(-1deg); }
    20% { transform: translate(-3px, 0px) rotate(1deg); }
    30% { transform: translate(3px, 2px) rotate(0deg); }
    40% { transform: translate(1px, -1px) rotate(1deg); }
    50% { transform: translate(-1px, 2px) rotate(-1deg); }
    60% { transform: translate(-3px, 1px) rotate(0deg); }
    70% { transform: translate(3px, 1px) rotate(-1deg); }
    80% { transform: translate(-1px, -1px) rotate(1deg); }
    90% { transform: translate(1px, 2px) rotate(0deg); }
    100% { transform: translate(1px, -2px) rotate(-1deg); }
}

.efeito-pix-ativo {
    animation: shake-pix 0.5s cubic-bezier(.36,.07,.19,.97) both;
    animation-iteration-count: 3; /* Treme 3 vezes */
    background-color: rgba(234, 179, 8, 0.4) !important; /* Fundo amarelado */
    transition: background-color 0.2s ease-in-out;
}

.efeito-pix-ativo * {
    pointer-events: none; /* Evita cliques durante o tremor */
}
/* ================= NOTIFICAÇÕES DO CHAT ================= */
.chat-contact-item {
    position: relative;
    /* Garante que possamos posicionar os itens dentro do contato livremente */
}

.chat-time-stamp {
    position: absolute;
    top: 12px;
    right: 16px;
    font-size: 11px;
    color: var(--brand-green); /* Pode mudar para a cor que preferir */
    font-weight: 600;
}

.chat-unread-badge {
    position: absolute;
    bottom: 12px;
    right: 16px;
    background-color: #ef4444; /* Vermelho vivo */
    color: white;
    font-size: 11px;
    font-weight: bold;
    min-width: 20px;
    height: 20px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 6px;
    box-shadow: 0 2px 4px rgba(239, 68, 68, 0.3);
}
/* Bloqueia o cursor de texto e a seleção acidental em elementos da interface */
.podium-col, .tool-card, .action-block, .rk-card, .sidebar, button, .detail-tab, .bucket-card, .calendar-day, .nav-item, .report-card {
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}
