/* PAINEL PHP - Design HD 4K | Tabler Style 2026 */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400&display=swap');

:root {
  --font-primary: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --icon-color: #206bc4;
  --sidebar-bg: #1a1c23;
  --sidebar-border: rgba(255,255,255,0.06);
  --sidebar-text: #959ca9;
  --sidebar-text-hover: #ffffff;
  --sidebar-active-bg: rgba(32,107,196,0.1);
  --sidebar-active-color: #206bc4;
  --header-bg: #1e2129;
  --main-bg: #1a1c23;
  --card-bg: #1e2129;
  --bg-tertiary: #242731;
  --border-subtle: rgba(255,255,255,0.06);
  --text-primary: #f6f8fb;
  --text-secondary: #959ca9;
  --text-muted: #656d77;
  --accent-blue: #206bc4;
  --accent-cyan: #17a2b8;
  --accent-green: #2fb344;
  --accent-pink: #d63384;
  --accent-orange: #f76707;
  --radius-md: 8px;
  --radius-lg: 12px;
  --transition-fast: 0.2s ease;
  --shadow-sm: 0 2px 8px rgba(0,0,0,0.15);
  --shadow-md: 0 4px 20px rgba(0,0,0,0.2);
}
* { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; scroll-behavior: smooth; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
body { margin: 0; font-family: var(--font-primary); background: var(--main-bg); color: var(--text-primary); line-height: 1.6; min-height: 100vh; font-size: 15px; font-weight: 400; letter-spacing: 0.01em; }

::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.1); border-radius: 9999px; }
::-webkit-scrollbar-thumb:hover { background: rgba(255,255,255,0.2); }
::selection { background: var(--accent-blue); color: white; }

/* ========== LOGIN (idêntico ao original) ========== */
.login-page { min-height: 100vh; display: flex; align-items: center; justify-content: center; background: #1a1c23; position: relative; overflow: hidden; }
.login-bg { position: absolute; inset: 0; z-index: 0; }
.bg-gradient { position: absolute; inset: 0; background: radial-gradient(ellipse at 50% 0%, rgba(32,107,196,0.15) 0%, transparent 60%); }
.bg-grid { position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,0.02) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,0.02) 1px, transparent 1px); background-size: 50px 50px; }
.bg-glow { position: absolute; border-radius: 50%; filter: blur(100px); opacity: 0.4; }
.glow-1 { width: 400px; height: 400px; background: #206bc4; top: -100px; left: -100px; }
.glow-2 { width: 300px; height: 300px; background: #2fb344; bottom: -50px; right: -50px; }
.glow-3 { width: 200px; height: 200px; background: #d63384; top: 50%; right: 20%; }
.login-theme-toggle { position: fixed; top: 20px; right: 20px; z-index: 100; padding: 12px; background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.1); border-radius: var(--radius-lg); color: var(--icon-color); cursor: pointer; transition: var(--transition-fast); display: flex; align-items: center; justify-content: center; }
.login-theme-toggle .ti { font-size: 1.35rem; color: inherit; }
.login-theme-toggle:hover { background: rgba(255,255,255,0.1); color: var(--accent-blue); }
.password-toggle .ti { color: var(--text-muted); font-size: 1.1rem; }
.password-toggle:hover .ti { color: var(--icon-color); }
.login-container { position: relative; z-index: 1; width: 100%; max-width: 400px; padding: 20px; }
.login-card { background: #1e2129; border: 1px solid rgba(255,255,255,0.06); border-radius: 12px; padding: 40px; box-shadow: 0 24px 64px rgba(0,0,0,0.4); }
.login-card-centered { text-align: center; }
.login-logo-section { margin-bottom: 32px; }
.login-logo-text { font-size: 24px; font-weight: 700; color: var(--accent-blue); margin: 0; }
.login-form { display: flex; flex-direction: column; gap: 20px; }
.form-group.login-group { text-align: left; }
.password-input { position: relative; }
.password-input input { padding-right: 44px; }
.password-toggle { position: absolute; right: 12px; top: 50%; transform: translateY(-50%); padding: 4px; color: var(--text-muted); cursor: pointer; border: none; background: none; color: inherit; }
.password-toggle:hover { color: var(--text-secondary); }
.login-error { padding: 12px 16px; background: rgba(214,51,132,0.1); border: 1px solid rgba(214,51,132,0.2); border-radius: 8px; color: var(--accent-pink); font-size: 13px; }
.login-btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; width: 100%; padding: 14px 20px; font-size: 14px; font-weight: 600; background: var(--accent-blue); color: #fff; border: none; border-radius: 8px; cursor: pointer; transition: var(--transition-fast); }
.login-btn:hover:not(:disabled) { background: #1a5bb0; }
.login-btn:disabled { opacity: 0.7; cursor: not-allowed; }
.login-btn .spinner-icon { display: none; width: 18px; height: 18px; border: 2px solid rgba(255,255,255,0.3); border-top-color: #fff; border-radius: 50%; animation: spin 0.8s linear infinite; }
.login-btn.loading .spinner-icon { display: inline-block; }
.spinner-icon { animation: spin 1s linear infinite; }
@keyframes spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
.animate-slide-down { animation: slideDown 0.3s ease forwards; }
@keyframes slideDown { from { opacity: 0; transform: translateY(-10px); } to { opacity: 1; transform: translateY(0); } }

/* ========== LAYOUT ========== */
.layout { display: flex; min-height: 100vh; }
.sidebar { width: 240px; background: var(--sidebar-bg); border-right: 1px solid var(--sidebar-border); display: flex; flex-direction: column; position: fixed; top: 0; left: 0; bottom: 0; z-index: 100; transition: transform 0.3s ease; }
.sidebar-header { display: flex; align-items: center; justify-content: space-between; padding: 0 16px; height: 64px; border-bottom: 1px solid var(--sidebar-border); }
.logo { text-decoration: none; color: inherit; display: flex; align-items: center; }
.logo-img { width: 240px; max-width: 100%; object-fit: contain; }
.logo-text { font-size: 18px; font-weight: 700; color: var(--accent-blue); }
.login-logo-img { max-width: 100%; height: auto; object-fit: contain; }
.sidebar-close { display: none; background: none; border: none; color: var(--sidebar-text); font-size: 24px; cursor: pointer; padding: 8px; }
.sidebar-nav { flex: 1; overflow-y: auto; padding: 16px 0; }
.nav-section { padding: 0 8px; margin-bottom: 16px; }
.nav-section-title { display: block; font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; color: var(--text-muted); padding: 8px 12px; margin-bottom: 4px; }
.nav-link { display: flex; align-items: center; gap: 12px; padding: 10px 14px; color: var(--sidebar-text); border-radius: var(--radius-md); font-size: 14px; font-weight: 500; text-decoration: none; margin-bottom: 2px; transition: all var(--transition-fast); }
.nav-link:hover { background: rgba(255,255,255,0.04); color: var(--sidebar-text-hover); }
.nav-link.active { background: var(--sidebar-active-bg); color: var(--sidebar-active-color); }
.nav-icon { color: var(--icon-color); font-size: 1.25rem; width: 1.25rem; flex-shrink: 0; transition: color var(--transition-fast); }
.nav-link:hover .nav-icon { color: var(--accent-blue); }
.nav-link.active .nav-icon { color: var(--sidebar-active-color); }
.sidebar-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.6); z-index: 99; }
.main { flex: 1; margin-left: 240px; display: flex; flex-direction: column; min-height: 100vh; }
.header { display: flex; align-items: center; justify-content: space-between; padding: 0 20px; height: 56px; background: var(--header-bg); border-bottom: 1px solid var(--border-subtle); position: sticky; top: 0; z-index: 50; }
.header-left { display: flex; align-items: center; gap: 12px; }
.menu-toggle { display: none; padding: 8px; background: none; border: none; color: var(--icon-color); cursor: pointer; font-size: 1.35rem; }
.menu-toggle .ti { color: var(--icon-color); }
.page-title { font-size: 14px; font-weight: 600; margin: 0; color: var(--text-primary); }
.header-right { display: flex; align-items: center; gap: 4px; }
.header-btn { padding: 10px; color: var(--text-secondary); background: transparent; border: none; border-radius: var(--radius-md); cursor: pointer; transition: var(--transition-fast); display: flex; align-items: center; justify-content: center; font-size: 1.2rem; }
.header-btn .ti { color: var(--icon-color); font-size: 1.25rem; }
.header-btn:hover { background: rgba(255,255,255,0.06); color: var(--text-primary); }
.header-btn:hover .ti { color: var(--accent-blue); }
.notification-wrap { position: relative; }
.notification-btn { position: relative; }
.notification-badge { position: absolute; top: 2px; right: 2px; min-width: 16px; height: 16px; padding: 0 4px; background: #d63384; color: white; border-radius: 50%; font-size: 10px; font-weight: 600; display: flex; align-items: center; justify-content: center; }
.notification-dropdown { position: absolute; top: calc(100% + 6px); right: 0; min-width: 280px; max-width: 360px; max-height: 400px; background: var(--card-bg); border: 1px solid var(--border-subtle); border-radius: 8px; box-shadow: 0 16px 48px rgba(0,0,0,0.4); z-index: 101; overflow: hidden; animation: dropdownFade 0.15s ease; display: flex; flex-direction: column; }
.notification-dropdown-header { padding: 12px 14px; font-size: 13px; font-weight: 600; color: var(--text-secondary); border-bottom: 1px solid var(--border-subtle); }
.notification-dropdown-list { overflow-y: auto; max-height: 320px; }
.notification-dropdown-item { display: block; width: 100%; padding: 12px 14px; text-align: left; background: none; border: none; border-bottom: 1px solid var(--border-subtle); color: var(--text-primary); font-size: 13px; cursor: pointer; transition: var(--transition-fast); text-decoration: none; }
.notification-dropdown-item:hover { background: rgba(255,255,255,0.04); }
.notification-dropdown-item:last-child { border-bottom: none; }
.notification-dropdown-item strong { display: block; margin-bottom: 2px; }
.notification-dropdown-item span { color: var(--text-muted); font-size: 12px; font-weight: 400; }
.notification-dropdown-empty { padding: 20px; text-align: center; color: var(--text-muted); font-size: 13px; }
.user-menu { position: relative; margin-left: 8px; }
.user-menu-trigger { display: flex; align-items: center; gap: 8px; padding: 4px 8px 4px 4px; background: transparent; border: 1px solid var(--border-subtle); border-radius: 6px; cursor: pointer; color: inherit; font-size: 13px; }
.user-avatar { width: 32px; height: 32px; border-radius: 50%; background: linear-gradient(135deg, var(--accent-blue), #17a2b8); display: flex; align-items: center; justify-content: center; color: #fff; font-weight: 600; font-size: 13px; overflow: hidden; }
.user-avatar img { width: 100%; height: 100%; object-fit: cover; object-position: center; border-radius: 50%; display: block; }
.user-info { text-align: left; }
.user-name { display: block; font-size: 13px; font-weight: 600; }
.user-role { display: block; font-size: 11px; color: var(--text-muted); }
.chevron { font-size: 10px; color: var(--text-muted); transition: transform 0.15s; }
.chevron.open { transform: rotate(180deg); }
.user-dropdown { position: absolute; top: calc(100% + 6px); right: 0; min-width: 180px; background: var(--card-bg); border: 1px solid var(--border-subtle); border-radius: 8px; box-shadow: 0 16px 48px rgba(0,0,0,0.4); z-index: 100; overflow: hidden; animation: dropdownFade 0.15s ease; }
@keyframes dropdownFade { from { opacity: 0; transform: translateY(-8px); } to { opacity: 1; transform: translateY(0); } }
.dropdown-item { display: flex; align-items: center; gap: 10px; padding: 10px 14px; color: var(--text-secondary); text-decoration: none; font-size: 13px; transition: var(--transition-fast); }
.dropdown-item .ti { color: var(--icon-color); font-size: 1.1rem; flex-shrink: 0; }
.dropdown-item:hover { background: rgba(255,255,255,0.04); color: var(--text-primary); }
.dropdown-item:hover .ti { color: var(--accent-blue); }
.dropdown-item.logout { color: var(--accent-pink); border-top: 1px solid var(--border-subtle); }
.dropdown-item.logout .ti { color: var(--accent-pink); }
.dropdown-item.logout:hover { background: rgba(214,51,132,0.08); }
.chevron { font-size: 1rem; color: var(--text-muted); transition: transform var(--transition-fast); }
.chevron.open { transform: rotate(180deg); }
.page-content { flex: 1; padding: 20px; overflow-x: hidden; }
.sidebar-footer { padding: 12px 8px; border-top: 1px solid var(--sidebar-border); }
.online-indicator { display: flex; align-items: center; gap: 8px; padding: 8px 12px; background: rgba(47,179,68,0.08); border: 1px solid rgba(47,179,68,0.15); border-radius: 6px; cursor: pointer; font-size: 12px; color: var(--accent-green); }
.online-indicator:hover { background: rgba(47,179,68,0.12); }
.online-list-sidebar { margin-top: 8px; padding: 6px; background: rgba(0,0,0,0.2); border-radius: 6px; max-height: 180px; overflow-y: auto; }
.online-user { display: flex; align-items: center; gap: 8px; padding: 6px 8px; border-radius: 4px; }
.online-user:hover { background: rgba(255,255,255,0.04); }
.online-avatar { width: 26px; height: 26px; border-radius: 50%; background: linear-gradient(135deg, var(--accent-blue), #17a2b8); display: flex; align-items: center; justify-content: center; color: white; font-size: 11px; font-weight: 600; }
.online-user-info { flex: 1; min-width: 0; }
.online-user-name { display: block; font-size: 12px; font-weight: 500; color: var(--text-primary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.online-user-ramal { display: block; font-size: 10px; color: var(--text-muted); }

/* ========== FORMULÁRIOS ========== */
.form-group { margin-bottom: 16px; }
.form-group label { display: block; font-size: 13px; font-weight: 500; color: var(--text-secondary); margin-bottom: 8px; }
.form-group input, .form-group select, .form-group textarea { width: 100%; padding: 10px 14px; font-size: 14px; background: #242731; border: 1px solid rgba(255,255,255,0.08); border-radius: 8px; color: var(--text-primary); }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color: var(--accent-blue); outline: none; }

/* ========== CARDS E BOTÕES ========== */
.card { background: var(--card-bg); border: 1px solid var(--border-subtle); border-radius: 12px; padding: 20px; }
.card-title { font-size: 14px; font-weight: 600; margin: 0 0 16px 0; }
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 10px 18px; font-size: 13px; font-weight: 600; border-radius: 8px; cursor: pointer; border: none; text-decoration: none; transition: all 0.15s; }
.btn-primary { background: var(--accent-blue); color: #fff; }
.btn-primary:hover { background: #1a5bb0; }
.btn-secondary { background: rgba(255,255,255,0.08); color: var(--text-primary); border: 1px solid var(--border-subtle); }
.btn-secondary:hover { background: rgba(255,255,255,0.12); }
.btn-success { background: var(--accent-green); color: #fff; }
.table-wrap { overflow-x: auto; }
table { width: 100%; border-collapse: collapse; font-size: 13px; }
table th, table td { padding: 10px 12px; text-align: left; border-bottom: 1px solid var(--border-subtle); }
table th { font-weight: 600; color: var(--text-secondary); }
.alert { padding: 12px 16px; border-radius: 8px; margin-bottom: 16px; font-size: 13px; }
.alert-success { background: rgba(47,179,68,0.1); border: 1px solid rgba(47,179,68,0.2); color: var(--accent-green); }
.alert-error { background: rgba(214,51,132,0.1); border: 1px solid rgba(214,51,132,0.2); color: var(--accent-pink); }
.loading { text-align: center; padding: 40px; color: var(--text-muted); }
.grid-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 16px; }

/* ========== CONSULTAS (Atendimentos) - Igual projeto original ========== */
.consultas-page { display: flex; flex-direction: column; gap: 20px; }
.consulta-card { background: var(--card-bg); border: 1px solid var(--border-subtle); border-radius: 8px; padding: 24px; }
.consulta-header { text-align: center; margin-bottom: 24px; }
.consulta-header h2 { font-size: 20px; font-weight: 600; margin: 0 0 8px; }
.consulta-header p { color: var(--text-muted); font-size: 13px; margin: 0; }
.consulta-tipos { display: flex; justify-content: center; gap: 12px; margin-bottom: 24px; flex-wrap: wrap; }
.tipo-btn { display: inline-flex; flex-direction: column; align-items: center; gap: 8px; padding: 16px 24px; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.08); border-radius: 8px; color: var(--text-secondary); cursor: pointer; transition: all 0.15s; min-width: 120px; font-size: 13px; }
.tipo-btn:hover { background: rgba(255,255,255,0.08); color: var(--text-primary); }
.tipo-btn.active { background: rgba(32,107,196,0.15); border-color: var(--accent-blue); color: var(--accent-blue); }
.consulta-form { display: flex; flex-direction: column; gap: 16px; }
.btn-lg { padding: 14px 20px; font-size: 14px; }
.resultado-card { background: var(--card-bg); border: 1px solid var(--border-subtle); border-radius: 8px; padding: 24px; margin-top: 20px; }
.resultado-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; padding-bottom: 16px; border-bottom: 1px solid var(--border-subtle); }
.resultado-header h3 { font-size: 18px; font-weight: 600; margin: 0; }
.resultado-section { margin-bottom: 20px; }
.resultado-section-title { font-size: 12px; font-weight: 600; color: var(--text-muted); margin: 0 0 12px; text-transform: uppercase; letter-spacing: 0.5px; }
.resultado-item-unico { padding: 24px; background: rgba(32,107,196,0.08); border: 1.5px solid rgba(32,107,196,0.3); border-left: 4px solid var(--accent-blue); border-radius: 12px; }
.resultado-item-unico .resultado-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; }
.resultado-dado-item { display: flex; flex-direction: column; gap: 8px; padding: 18px 16px; border-right: 1px solid rgba(255,255,255,0.1); border-bottom: 1px solid rgba(255,255,255,0.1); min-height: 85px; }
.resultado-dado-item:nth-child(3n) { border-right: none; }
.resultado-dado-item:nth-last-child(-n+3) { border-bottom: none; }
.resultado-label { font-size: 10px; font-weight: 700; color: var(--text-muted); text-transform: uppercase; letter-spacing: 1px; }
.resultado-value { font-size: 15px; font-weight: 600; word-break: break-word; }
.resultado-item:not(.resultado-item-unico) { display: flex; flex-direction: column; gap: 8px; padding: 20px 18px; border-right: 1px solid rgba(255,255,255,0.08); border-bottom: 1px solid rgba(255,255,255,0.08); }
.resultado-acoes { margin-top: 24px; padding-top: 20px; border-top: 1px solid var(--border-subtle); }
.resultado-acoes h4 { font-size: 14px; font-weight: 600; margin: 0 0 16px; }
.acoes-grid { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 16px; }
.acao-btn { display: inline-flex; align-items: center; gap: 8px; padding: 12px 20px; border-radius: 8px; border: 1px solid rgba(255,255,255,0.1); background: rgba(255,255,255,0.04); color: var(--text-primary); cursor: pointer; font-size: 13px; transition: all 0.15s; }
.acao-btn:hover { background: rgba(255,255,255,0.08); }
.acao-protocolo.active, .acao-boletim.active { background: rgba(32,107,196,0.15); border-color: var(--accent-blue); color: var(--accent-blue); }
.envio-form { background: rgba(0,0,0,0.0); border-radius: 8px; padding: 20px; margin-top: 16px; }
.envio-tipos { display: flex; gap: 8px; margin-bottom: 16px; }
.envio-tipo { padding: 10px 16px; border-radius: 6px; border: 1px solid rgba(255,255,255,0.1); background: transparent; color: var(--text-secondary); cursor: pointer; font-size: 13px; }
.envio-tipo.active { background: rgba(32,107,196,0.15); border-color: var(--accent-blue); color: var(--accent-blue); }
.form-hint { font-size: 12px; color: var(--text-muted); margin-top: 4px; }
.btn-ghost { background: transparent; color: var(--text-secondary); border: 1px solid var(--border-subtle); }
.btn-ghost:hover { background: rgba(255,255,255,0.04); color: var(--text-primary); }
.btn-sm { padding: 8px 14px; font-size: 12px; }
.resultado-header .success-icon { color: var(--accent-green); font-size: 1.25rem; margin-right: 8px; }
.animate-slide-up { animation: slideUp 0.3s ease forwards; }
@keyframes slideUp { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } }
.acoes-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 12px; }
.acao-btn { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 10px; padding: 16px 20px; min-height: 100px; border-radius: 8px; border: 1px solid rgba(255,255,255,0.08); background: rgba(255,255,255,0.04); color: var(--text-secondary); cursor: pointer; font-size: 13px; font-weight: 500; transition: all 0.2s; }
.acao-btn:hover:not(:disabled) { background: rgba(255,255,255,0.08); border-color: rgba(255,255,255,0.15); color: var(--text-primary); transform: translateY(-2px); box-shadow: 0 4px 12px rgba(0,0,0,0.15); }
.acao-btn:disabled { opacity: 0.5; cursor: not-allowed; }
.acao-btn .ti { font-size: 1.25rem; }
.acao-btn.acao-protocolo { border-color: rgba(255,152,0,0.3); color: #ff9800; background: rgba(255,152,0,0.05); }
.acao-btn.acao-protocolo:hover:not(:disabled) { background: rgba(255,152,0,0.15); border-color: #ff9800; color: #ff9800; }
.acao-btn.acao-boletim { border-color: rgba(244,67,54,0.3); color: #f44336; background: rgba(244,67,54,0.05); }
.acao-btn.acao-boletim:hover:not(:disabled) { background: rgba(244,67,54,0.15); border-color: #f44336; color: #f44336; }
.acao-btn.acao-pix { border-color: rgba(76,175,80,0.3); color: #4caf50; background: rgba(76,175,80,0.05); }
.acao-btn.acao-pix:hover:not(:disabled) { background: rgba(76,175,80,0.15); border-color: #4caf50; color: #4caf50; }
.envio-tipo { display: flex; align-items: center; gap: 8px; }
.envio-tipo .ti { font-size: 1.1rem; }
.pix-dados-container { display: flex; flex-direction: column; gap: 20px; }
.pix-secao { display: flex; flex-direction: column; gap: 12px; }
.pix-separador { text-align: center; color: rgba(255,255,255,0.2); font-size: 14px; letter-spacing: 2px; margin: 8px 0; padding: 12px 0; }
.pix-item { display: flex; align-items: center; gap: 12px; padding: 14px 18px; background: linear-gradient(135deg, rgba(255,255,255,0.04) 0%, rgba(255,255,255,0.02) 100%); border: 1px solid rgba(255,255,255,0.08); border-left: 3px solid rgba(76,175,80,0.5); border-radius: 8px; transition: all 0.3s; }
.pix-item:hover { border-left-color: #4caf50; }
.pix-emoji { font-size: 18px; width: 24px; text-align: center; flex-shrink: 0; }
.pix-label { font-size: 13px; font-weight: 600; color: var(--text-secondary); min-width: 100px; }
.pix-value { font-size: 15px; font-weight: 600; color: var(--text-primary); flex: 1; word-break: break-word; }
.resultado-pix-section { background: linear-gradient(135deg, rgba(76,175,80,0.08) 0%, rgba(76,175,80,0.03) 100%); border-color: rgba(76,175,80,0.2); }
.boletim-select-banco, .boletim-input-email, .boletim-input { width: 100%; padding: 10px 12px; border-radius: 6px; border: 1px solid var(--border-subtle); background: var(--bg-tertiary); color: var(--text-primary); font-size: 14px; }
.boletim-select-banco:focus, .boletim-input-email:focus, .boletim-input:focus { outline: none; border-color: var(--accent-blue); }
.envio-form-boletim .form-group { margin-bottom: 12px; }
.form-hint { font-size: 12px; color: var(--text-muted); margin-top: 6px; }
.alert-success { background: rgba(47,179,68,0.1); border: 1px solid rgba(47,179,68,0.2); color: var(--accent-green); }
.consultas-page .consulta-tipos .tipo-btn { display: flex; flex-direction: column; align-items: center; gap: 8px; }
.consultas-page .form-group input[type="file"] { cursor: pointer; }

.config-section-danger .config-section-header { border-bottom-color: rgba(214,51,132,0.2); }
.config-section-danger .config-section-icon { color: var(--accent-pink); }
.config-btn-zerar { display: inline-flex; align-items: center; gap: 8px; padding: 12px 24px; background: rgba(214,51,132,0.15); border: 1px solid rgba(214,51,132,0.4); border-radius: 8px; color: var(--accent-pink); font-size: 14px; font-weight: 600; cursor: pointer; transition: var(--transition-fast); }
.config-btn-zerar:hover:not(:disabled) { background: rgba(214,51,132,0.25); border-color: var(--accent-pink); }
.config-btn-zerar:disabled { opacity: 0.7; cursor: not-allowed; }
.config-btn-zerar.loading .ti { animation: spin 1s linear infinite; }

/* ========== DASHBOARD (idêntico ao original) ========== */
.dashboard { padding: 0; }
.breadcrumb { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--text-muted); margin-bottom: 20px; }
.breadcrumb .current { color: var(--text-primary); }
.breadcrumb-icon { color: var(--icon-color); font-size: 1rem; }
.page-icon { color: var(--icon-color); font-size: 1.5rem; flex-shrink: 0; }
.page-icon-inline { color: var(--icon-color); font-size: 1.1rem; margin-right: 8px; vertical-align: -0.15em; }
.empty-state-icon { color: var(--icon-color); font-size: 3rem; margin-bottom: 8px; }
.search-input-icon { color: var(--icon-color); font-size: 1.1rem; flex-shrink: 0; }
.logs-empty-icon { color: var(--text-muted); font-size: 2.5rem; margin-bottom: 8px; display: block; }
.logs-tab .ti { margin-right: 6px; font-size: 1rem; vertical-align: -0.1em; color: inherit; }
.logs-btn-icon .ti { font-size: 1.1rem; color: inherit; }
.radio-btn .ti { color: var(--icon-color); font-size: 1.1rem; margin-right: 6px; }
.stat-item-icon { color: var(--icon-color); font-size: 1.25rem; flex-shrink: 0; }
.avatar-edit .ti { font-size: 1rem; color: #fff; }
.btn .ti { font-size: 1rem; margin-right: 4px; }
.alert .ti { margin-right: 8px; flex-shrink: 0; font-size: 1.1rem; }
.form-group label .ti { margin-right: 6px; color: var(--icon-color); font-size: 0.95rem; vertical-align: -0.1em; }
.modal-close .ti { font-size: 1.25rem; color: inherit; }
.config-header { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 16px; margin-bottom: 24px; padding: 20px; background: var(--card-bg); border: 1px solid var(--border-subtle); border-radius: var(--radius-lg); }
.config-header-info { display: flex; align-items: center; }
.config-header .page-icon { margin-right: 12px; }
.config-header h1 { margin: 0 0 4px; font-size: 1.35rem; font-weight: 700; color: var(--text-primary); }
.config-header p { margin: 0; font-size: 13px; color: var(--text-muted); }
.sms-header .page-icon { margin-right: 12px; }
.sms-header-info { display: flex; align-items: center; }
.dash-hero { background: linear-gradient(135deg, #1e2129 0%, #252932 100%); border: 1px solid rgba(255,255,255,0.08); border-radius: 12px; padding: 28px 32px; margin-bottom: 24px; box-shadow: 0 4px 20px rgba(0,0,0,0.3); position: relative; overflow: hidden; }
.dash-hero::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: linear-gradient(90deg, #206bc4 0%, #4a90e2 50%, #206bc4 100%); background-size: 200% 100%; animation: shimmer 3s ease-in-out infinite; }
@keyframes shimmer { 0%, 100% { background-position: 0% 50%; } 50% { background-position: 100% 50%; } }
.hero-content { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 20px; position: relative; z-index: 1; }
.hero-text { display: flex; flex-direction: column; gap: 8px; flex: 1; }
.hero-greeting { font-size: 16px; color: #959ca9; font-weight: 500; }
.hero-name { font-size: 18px; font-weight: 800; background: linear-gradient(135deg, #f6f8fb 0%, #206bc4 100%); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; margin: 0; }
.hero-subtitle { font-size: 15px; color: #656d77; margin: 4px 0 0 0; font-weight: 500; }
.hero-ramal { font-size: 13px; color: #959ca9; padding: 4px 12px; background: rgba(32,107,196,0.1); border-radius: 6px; display: inline-block; width: fit-content; margin-top: 4px; }
.hero-motivacional { margin: 20px 0; position: relative; z-index: 1; }
.motivacional-content { display: flex; align-items: flex-start; gap: 16px; padding: 24px 28px; background: linear-gradient(135deg, rgba(32,107,196,0.12) 0%, rgba(32,107,196,0.06) 100%); border: 1px solid rgba(32,107,196,0.25); border-left: 4px solid #206bc4; border-radius: 12px; }
.motivacional-icon { width: 56px; height: 56px; background: linear-gradient(135deg, rgba(32,107,196,0.2) 0%, rgba(32,107,196,0.1) 100%); border-radius: 12px; color: #206bc4; flex-shrink: 0; display: flex; align-items: center; justify-content: center; }
.motivacional-text-wrapper { flex: 1; display: flex; flex-direction: column; gap: 8px; }
.motivacional-label { font-size: 11px; font-weight: 700; color: #206bc4; text-transform: uppercase; letter-spacing: 1px; }
.motivacional-text { font-size: 16px; font-weight: 600; color: #f6f8fb; margin: 0; line-height: 1.6; padding-left: 20px; position: relative; }
.motivacional-text::before { content: '"'; position: absolute; left: 0; top: -4px; color: #206bc4; font-size: 32px; font-weight: 700; opacity: 0.6; }
.hero-refresh { padding: 10px; background: rgba(32,107,196,0.1); border: 1px solid rgba(32,107,196,0.2); border-radius: 8px; color: #206bc4; cursor: pointer; transition: 0.2s; display: flex; align-items: center; justify-content: center; }
.hero-refresh:hover:not(:disabled) { background: rgba(32,107,196,0.2); }
.hero-stats { display: flex; gap: 24px; padding-top: 16px; border-top: 1px solid rgba(255,255,255,0.06); }
.hero-stat { display: flex; align-items: center; gap: 12px; }
.stat-icon-mini { font-size: 1.2rem; flex-shrink: 0; display: flex; align-items: center; justify-content: center; }
.stat-icon-mini .ti { color: var(--icon-color); }
.hero-stat.online .stat-icon-mini .ti { color: #2fb344; }
.hero-stat.envios .stat-icon-mini .ti { color: #4a90e2; }
.motivacional-icon .ti { color: var(--accent-blue); font-size: 1.75rem; }
.hero-refresh .ti.refresh-icon { font-size: 1.25rem; color: var(--accent-blue); transition: transform 0.3s; }
.hero-refresh:hover .ti.refresh-icon { color: #4a90e2; }
.hero-refresh.spinning .ti.refresh-icon { animation: spin 0.8s linear infinite; }
.card-head-icon { color: var(--icon-color); font-size: 1.25rem; }
.empty-icon { color: var(--text-muted); font-size: 2rem; margin-bottom: 4px; }
.filter-btn.years .ti { color: var(--text-muted); font-size: 0.95rem; margin-right: 2px; }
.stat-num { font-size: 24px; font-weight: 800; background: linear-gradient(135deg, #f6f8fb 0%, #206bc4 100%); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.stat-lbl { font-size: 13px; color: #959ca9; margin-top: 4px; font-weight: 500; }
.dash-grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: 20px; }
.card-chart { grid-column: 1 / -1; min-height: 400px; }
.card-atendentes-stats { grid-column: 1 / -1; }
.card-header { display: flex; align-items: center; justify-content: space-between; padding: 16px 20px; border-bottom: 1px solid rgba(255,255,255,0.06); }
.update-info { flex: 1; }
.update-badge { font-size: 10px; font-weight: 600; color: #656d77; letter-spacing: 0.5px; }
.chart-filters { display: flex; align-items: center; gap: 6px; }
.filter-btn .dot { width: 8px; height: 8px; border-radius: 50%; }
.filter-btn .dot.blue { background: #206bc4; }
.filter-btn .dot.pink { background: #d63384; }
.filter-btn.years { background: rgba(255,255,255,0.04); }
.chart-stat .change { font-size: 11px; font-weight: 500; }
.chart-stat .change.up { color: #2fb344; }
.chart-stat .change.down { color: #d63384; }
.card-head { display: flex; align-items: center; gap: 10px; padding: 16px 20px; border-bottom: 1px solid rgba(255,255,255,0.06); }
.card-head h3 { flex: 1; font-size: 15px; font-weight: 600; color: #f6f8fb; margin: 0; }
.card-head .badge { background: rgba(32,107,196,0.15); color: #206bc4; padding: 4px 10px; border-radius: 12px; font-size: 11px; font-weight: 600; }
.table-wrapper { overflow-x: auto; }
.atendentes-table { width: 100%; border-collapse: collapse; }
.atendentes-table thead { background: rgba(255,255,255,0.02); }
.atendentes-table th { padding: 12px 16px; text-align: left; font-size: 11px; font-weight: 600; color: #656d77; text-transform: uppercase; letter-spacing: 0.5px; border-bottom: 1px solid rgba(255,255,255,0.06); }
.atendentes-table td { padding: 14px 16px; font-size: 13px; color: #f6f8fb; border-bottom: 1px solid rgba(255,255,255,0.04); }
.atendentes-table tbody tr:hover { background: rgba(255,255,255,0.02); }
.atendentes-table tbody tr.highlight-atendente { background: rgba(32,107,196,0.12); outline: 1px solid rgba(32,107,196,0.35); }
.atendente-cell { display: flex; align-items: center; gap: 10px; }
.atendente-avatar { width: 32px; height: 32px; border-radius: 50%; background: linear-gradient(135deg, #206bc4, #4299e1); display: flex; align-items: center; justify-content: center; color: white; font-size: 12px; font-weight: 600; flex-shrink: 0; overflow: hidden; }
.atendente-avatar img { width: 100%; height: 100%; object-fit: cover; object-position: center; border-radius: 50%; display: block; }
.atendente-info { flex: 1; min-width: 0; }
.atendente-name { font-weight: 500; color: #f6f8fb; }
.ramal-badge { display: inline-block; padding: 4px 10px; background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.1); border-radius: 6px; font-size: 12px; font-weight: 600; color: #959ca9; }
.nivel-badge { display: inline-flex; align-items: center; gap: 6px; padding: 6px 12px; border-radius: 6px; font-size: 12px; font-weight: 500; }
.nivel-badge.admin { background: rgba(214,51,132,0.15); color: #d63384; }
.nivel-badge.atendente { background: rgba(32,107,196,0.15); color: #206bc4; }
.status-badge { display: inline-flex; align-items: center; gap: 6px; padding: 6px 12px; border-radius: 6px; font-size: 12px; font-weight: 500; }
.status-badge.online { background: rgba(47,179,68,0.15); color: #2fb344; }
.status-badge.offline { background: rgba(149,156,169,0.15); color: #959ca9; }
.online-list { padding: 12px 0; max-height: 400px; overflow-y: auto; }
.online-item { display: flex; align-items: center; gap: 12px; padding: 10px 20px; transition: background 0.15s; }
.online-item:hover { background: rgba(255,255,255,0.02); }
.online-info { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.online-name { font-size: 13px; font-weight: 500; color: #f6f8fb; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.online-ramal { font-size: 11px; color: #656d77; }
.online-dot { color: #2fb344; flex-shrink: 0; font-size: 0.5rem; animation: pulse 2s ease infinite; }
@keyframes pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.5; } }
.card-stat { grid-column: span 3; padding: 20px; display: flex; align-items: center; gap: 16px; min-height: 100px; }
.stat-icon { width: 48px; height: 48px; border-radius: 8px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.stat-icon.blue { background: rgba(32,107,196,0.15); color: #206bc4; }
.stat-icon.green { background: rgba(47,179,68,0.15); color: #2fb344; }
.stat-content { flex: 1; display: flex; flex-direction: column; gap: 4px; }
.stat-value { font-size: 24px; font-weight: 700; color: #f6f8fb; }
.stat-label { font-size: 12px; color: #656d77; }
.empty { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 12px; padding: 40px 20px; color: #656d77; text-align: center; }
.chart-container { padding: 0 10px 10px; }
.filter-btn { display: flex; align-items: center; gap: 6px; padding: 6px 12px; background: transparent; border: 1px solid rgba(255,255,255,0.1); border-radius: 20px; color: #959ca9; font-size: 12px; cursor: pointer; transition: 0.15s; }
.filter-btn.active { background: rgba(255,255,255,0.06); border-color: rgba(255,255,255,0.15); color: #f6f8fb; }
.chart-stats { display: flex; gap: 40px; padding: 16px 20px; }
.chart-stat .label { font-size: 12px; color: #656d77; }
.chart-stat .value { font-size: 28px; font-weight: 600; color: #f6f8fb; }

@media (max-width: 768px) {
  .sidebar { transform: translateX(-100%); }
  .sidebar.open { transform: translateX(0); }
  .sidebar-close { display: block; }
  .menu-toggle { display: block; }
  .main { margin-left: 0; }
  .user-info { display: none; }
  .resultado-item-unico .resultado-grid { grid-template-columns: 1fr; }
  .resultado-dado-item:nth-child(n) { border-right: none; }
}

/* ========== CONSULTA PAGE (idêntico ao React) ========== */
.consulta-page { display: flex; flex-direction: column; gap: 20px; }
.consulta-card { background: var(--card-bg); border: 1px solid var(--border-subtle); border-radius: var(--radius-lg); padding: 24px; }
.consulta-header { text-align: center; margin-bottom: 24px; }
.consulta-header h2 { font-size: 20px; font-weight: 600; color: var(--text-primary); margin: 0 0 8px; }
.consulta-header p { color: var(--text-muted); font-size: 13px; }
.consulta-form { display: flex; flex-direction: column; gap: 20px; }
.radio-group { display: flex; gap: 12px; flex-wrap: wrap; }
.radio-btn { display: flex; align-items: center; gap: 8px; padding: 12px 20px; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.08); border-radius: var(--radius-lg); color: var(--text-secondary); cursor: pointer; transition: 0.15s; font-size: 14px; font-weight: 500; }
.radio-btn:hover { background: rgba(255,255,255,0.08); border-color: rgba(255,255,255,0.12); color: var(--text-primary); }
.radio-btn input[type="radio"] { display: none; }
.radio-btn.active { background: rgba(32,107,196,0.15); border-color: var(--accent-blue); color: var(--accent-blue); }
.form-group input[type="text"].consulta-input { width: 100%; padding: 12px 16px; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.08); border-radius: var(--radius-lg); color: var(--text-primary); font-size: 14px; }
.form-group input[type="text"].consulta-input:focus { outline: none; border-color: var(--accent-blue); }
.alert-info { background: rgba(32,107,196,0.1); border: 1px solid rgba(32,107,196,0.2); color: var(--accent-blue); padding: 12px 16px; border-radius: var(--radius-lg); font-size: 13px; display: flex; align-items: center; gap: 12px; }
.resultado-card { background: var(--card-bg); border: 1px solid var(--border-subtle); border-radius: var(--radius-lg); padding: 24px; margin-top: 20px; }
.resultado-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 24px; padding-bottom: 16px; border-bottom: 1px solid var(--border-subtle); }
.resultado-header h3 { font-size: 18px; font-weight: 700; margin: 0; }
.titulo-serasa { color: #6f42c1 !important; }
.titulo-credilink { color: #007bff !important; }
.fonte-badge { padding: 6px 12px; border-radius: 6px; font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; }
.fonte-badge.serasa { background: rgba(111,66,193,0.15); color: #6f42c1; border: 1px solid rgba(111,66,193,0.3); }
.fonte-badge.credilink { background: rgba(0,123,255,0.15); color: #007bff; border: 1px solid rgba(0,123,255,0.3); }
.resultado-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 20px; }
.resultado-item { display: flex; flex-direction: column; gap: 10px; padding: 18px; background: linear-gradient(135deg, rgba(255,255,255,0.04) 0%, rgba(255,255,255,0.02) 100%); border: 1px solid rgba(255,255,255,0.08); border-top: 3px solid rgba(32,107,196,0.5); border-radius: 10px; min-height: 90px; }
.resultado-item:hover { border-top-color: var(--accent-blue); }
.resultado-label { font-size: 11px; font-weight: 700; color: var(--text-secondary); text-transform: uppercase; letter-spacing: 0.8px; }
.resultado-value { font-size: 15px; color: var(--text-primary); font-weight: 600; word-break: break-word; }
.resultado-section { margin-top: 32px; padding: 28px; background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.08); border-radius: 16px; }
.resultado-section-title { font-size: 18px; font-weight: 700; color: var(--text-primary); margin: 0 0 24px; padding-bottom: 16px; border-bottom: 2px solid rgba(32,107,196,0.2); }
@media (max-width: 1200px) { .resultado-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 768px) { .resultado-grid { grid-template-columns: repeat(2, 1fr); } .radio-group { flex-direction: column; } .radio-btn { width: 100%; } }
@media (max-width: 480px) { .resultado-grid { grid-template-columns: 1fr; } }

/* ========== LOGS PAGE (idêntico ao React) ========== */
.logs-page { display: flex; flex-direction: column; gap: 12px; padding: 0; }
.logs-header { display: flex; justify-content: space-between; align-items: center; padding: 12px 16px; background: var(--card-bg); border-radius: var(--radius-lg); border: 1px solid var(--border-subtle); margin-bottom: 12px; }
.logs-header h1 { font-size: 18px; font-weight: 600; color: var(--text-primary); margin: 0; }
.logs-header .header-actions { display: flex; align-items: center; gap: 8px; }
.logs-btn-icon { display: inline-flex; align-items: center; justify-content: center; width: 36px; height: 36px; background: var(--bg-tertiary); border: 1px solid var(--border-subtle); border-radius: 6px; color: var(--text-secondary); cursor: pointer; transition: 0.15s; }
.logs-btn-icon:hover:not(:disabled) { background: rgba(255,255,255,0.08); color: var(--text-primary); border-color: var(--accent-blue); }
.logs-btn-icon.active { background: var(--accent-blue); color: #fff; border-color: var(--accent-blue); }
.logs-btn-icon.btn-danger { color: var(--accent-pink); }
.logs-btn-icon.btn-danger:hover { background: rgba(214,51,132,0.15); border-color: var(--accent-pink); }
.logs-btn-filter { display: inline-flex; align-items: center; gap: 6px; padding: 8px 12px; background: var(--bg-tertiary); border: 1px solid var(--border-subtle); border-radius: 6px; color: var(--text-secondary); font-size: 13px; cursor: pointer; }
.logs-btn-filter.active { background: var(--accent-blue); color: #fff; border-color: var(--accent-blue); }
.logs-last-update { font-size: 11px; color: var(--text-muted); padding: 0 8px; }
.logs-tabs { display: flex; gap: 4px; padding: 4px; background: var(--card-bg); border-radius: var(--radius-lg); border: 1px solid var(--border-subtle); margin-bottom: 12px; }
.logs-tab { flex: 1; padding: 8px 12px; background: transparent; border: none; border-radius: 6px; color: var(--text-secondary); font-size: 13px; font-weight: 500; cursor: pointer; transition: 0.15s; }
.logs-tab:hover { background: rgba(255,255,255,0.06); color: var(--text-primary); }
.logs-tab.active { background: var(--accent-blue); color: #fff; }
/* ========== LOGS - Painel de Filtros ========== */
.filters-panel { background: var(--card-bg); border-radius: var(--radius-lg); border: 1px solid var(--border-subtle); margin-bottom: 16px; overflow: hidden; }
.filters-panel .filters-panel-head { display: flex; align-items: center; gap: 10px; padding: 14px 20px; background: rgba(255,255,255,0.02); border-bottom: 1px solid var(--border-subtle); }
.filters-panel .filters-panel-head i { color: var(--accent-blue); font-size: 1.2rem; }
.filters-panel .filters-panel-head span { font-size: 14px; font-weight: 600; color: var(--text-primary); }
.filters-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 16px; padding: 20px; }
.filters-grid .form-group { margin-bottom: 0; }
.filters-grid .form-group label { display: block; font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.04em; color: var(--text-muted); margin-bottom: 8px; }
.filters-grid .form-group select,
.filters-grid .form-group input[type="date"] { width: 100%; padding: 10px 12px; font-size: 13px; background: var(--bg-tertiary); border: 1px solid var(--border-subtle); border-radius: 8px; color: var(--text-primary); transition: border-color 0.15s; }
.filters-grid .form-group select:focus,
.filters-grid .form-group input[type="date"]:focus { border-color: var(--accent-blue); outline: none; }
.filters-grid .form-group select:hover,
.filters-grid .form-group input[type="date"]:hover { border-color: rgba(255,255,255,0.12); }
.filter-group-atendentes { grid-column: 1 / -1; margin-top: 4px; padding-top: 16px; border-top: 1px solid var(--border-subtle); }
.filter-atendentes-header { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px; margin-bottom: 12px; }
.filter-atendentes-header label { margin: 0; font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.04em; color: var(--text-muted); }
.btn-select-all { padding: 6px 12px; font-size: 12px; font-weight: 500; background: rgba(32,107,196,0.12); border: 1px solid rgba(32,107,196,0.25); border-radius: 6px; color: var(--accent-blue); cursor: pointer; transition: 0.15s; }
.btn-select-all:hover { background: rgba(32,107,196,0.2); border-color: var(--accent-blue); }
.atendentes-checkboxes { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 8px; max-height: 180px; overflow-y: auto; padding: 4px 0; }
.atendentes-checkboxes::-webkit-scrollbar { width: 6px; }
.atendentes-checkboxes::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.15); border-radius: 3px; }
.checkbox-label { display: flex; align-items: center; gap: 10px; padding: 10px 12px; background: rgba(255,255,255,0.02); border: 1px solid var(--border-subtle); border-radius: 8px; cursor: pointer; transition: background 0.15s, border-color 0.15s; }
.checkbox-label:hover { background: rgba(255,255,255,0.04); border-color: rgba(255,255,255,0.1); }
.checkbox-label input[type="checkbox"] { width: 18px; height: 18px; accent-color: var(--accent-blue); cursor: pointer; flex-shrink: 0; }
.checkbox-label input[type="checkbox"]:checked + .checkbox-text { color: var(--text-primary); }
.checkbox-text { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; font-size: 13px; color: var(--text-secondary); }
.checkbox-text .atendente-name { font-weight: 500; color: var(--text-primary); }
.atendente-badge { font-size: 10px; font-weight: 600; padding: 2px 6px; border-radius: 4px; background: rgba(111,66,193,0.2); color: #9f7aea; }
.atendentes-selected-info { font-size: 12px; color: var(--text-muted); margin-top: 10px; padding: 8px 12px; background: rgba(32,107,196,0.06); border-radius: 6px; }
.filters-actions { display: flex; gap: 10px; justify-content: flex-end; align-items: center; padding: 14px 20px; background: rgba(0,0,0,0.15); border-top: 1px solid var(--border-subtle); }
.filters-actions .btn { min-width: 100px; }
.logs-table-container { overflow-x: auto; background: var(--card-bg); border-radius: var(--radius-lg); border: 1px solid var(--border-subtle); }
.logs-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.logs-table th, .logs-table td { padding: 12px 16px; text-align: left; border-bottom: 1px solid var(--border-subtle); }
.logs-table th { font-weight: 600; color: var(--text-secondary); }
.logs-table tbody tr:hover { background: rgba(255,255,255,0.02); }
.log-user-avatar { width: 28px; height: 28px; border-radius: 50%; background: var(--accent-blue); color: #fff; display: inline-flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 600; margin-right: 8px; }
.action-badge { display: inline-flex; align-items: center; gap: 6px; padding: 4px 10px; border-radius: 6px; font-size: 12px; }
.action-consulta { background: rgba(32,107,196,0.15); color: #206bc4; }
.action-sms { background: rgba(47,179,68,0.15); color: #2fb344; }
.action-email { background: rgba(23,162,184,0.15); color: #17a2b8; }
.action-error { background: rgba(214,51,132,0.15); color: #d63384; }
.action-default { background: rgba(255,255,255,0.06); color: var(--text-secondary); }
.btn-view-details { padding: 6px 10px; background: var(--bg-tertiary); border: 1px solid var(--border-subtle); border-radius: 6px; color: var(--text-secondary); cursor: pointer; }
.btn-view-details:hover { color: var(--accent-blue); border-color: var(--accent-blue); }
.logs-empty { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 12px; padding: 40px 20px; color: var(--text-muted); text-align: center; }
.logs-pagination { display: flex; justify-content: space-between; align-items: center; padding: 12px 16px; background: var(--card-bg); border-radius: var(--radius-lg); border: 1px solid var(--border-subtle); margin-top: 12px; }
.pagination-controls { display: flex; gap: 4px; }
.pagination-btn { padding: 8px 12px; background: var(--bg-tertiary); border: 1px solid var(--border-subtle); border-radius: 6px; color: var(--text-primary); cursor: pointer; }
.pagination-btn:disabled { opacity: 0.5; cursor: not-allowed; }
.modal-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.6); display: flex; align-items: center; justify-content: center; z-index: 1000; padding: 20px; }
.modal-content { background: var(--card-bg); border: 1px solid var(--border-subtle); border-radius: var(--radius-lg); max-width: 560px; width: 100%; max-height: 90vh; overflow: hidden; display: flex; flex-direction: column; }
.modal-header { display: flex; align-items: center; justify-content: space-between; padding: 16px 20px; border-bottom: 1px solid var(--border-subtle); }
.modal-header h3 { margin: 0; font-size: 18px; font-weight: 600; }
.modal-close { background: none; border: none; color: var(--text-secondary); cursor: pointer; padding: 4px; }
.modal-body { padding: 20px; overflow-y: auto; flex: 1; }
.modal-footer { display: flex; justify-content: flex-end; gap: 8px; padding: 16px 20px; border-top: 1px solid var(--border-subtle); }
.detail-section { margin-bottom: 20px; }
.detail-section h4 { font-size: 14px; color: var(--text-secondary); margin: 0 0 12px; }
.detail-grid { display: grid; gap: 8px; }
.detail-item { display: flex; flex-direction: column; gap: 2px; }
.detail-label { font-size: 11px; color: var(--text-muted); }
.detail-value { font-size: 13px; color: var(--text-primary); }
.detail-field { margin-bottom: 8px; }
.field-label { font-size: 11px; color: var(--text-muted); display: block; }
.field-value { font-size: 13px; color: var(--text-primary); }
.detail-result { margin-top: 16px; }
.resultado-organizado { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 12px; margin-top: 12px; }
.detail-json { background: #242731; padding: 12px; border-radius: 8px; font-size: 11px; overflow: auto; max-height: 300px; white-space: pre-wrap; }
.json-details summary { cursor: pointer; margin-top: 12px; font-size: 12px; color: var(--text-muted); }
.loading-overlay { position: absolute; inset: 0; background: rgba(0,0,0,0.3); display: flex; align-items: center; justify-content: center; border-radius: var(--radius-lg); }
.logs-content { position: relative; }
.btn.btn-danger { background: var(--accent-pink); color: #fff; border-color: var(--accent-pink); }
.btn.btn-danger:hover { background: #b82a6f; }
.delete-modal .modal-header.delete-header { display: flex; align-items: center; gap: 8px; }
.delete-warning { display: flex; align-items: center; gap: 12px; padding: 12px; background: rgba(214,51,132,0.1); border-radius: 8px; margin-bottom: 16px; color: var(--accent-pink); }
.delete-form label { display: block; margin-bottom: 8px; font-size: 13px; }
.delete-options { display: flex; flex-direction: column; gap: 8px; }
.radio-option { display: flex; align-items: center; gap: 8px; cursor: pointer; }
.spinning { animation: spin 1s linear infinite; }

/* ========== BOLETINS / USUARIOS / PAGES ========== */
.boletins-page, .usuarios-page { display: flex; flex-direction: column; gap: 20px; }
.page-header { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 16px; }
.header-info h2 { font-size: 20px; font-weight: 600; color: var(--text-primary); margin: 0 0 4px; }
.header-info p { color: var(--text-muted); font-size: 13px; margin: 0; }
.header-actions { display: flex; gap: 8px; }
.header-actions .btn { display: inline-flex; align-items: center; gap: 8px; padding: 10px 16px; font-size: 13px; font-weight: 500; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.08); border-radius: 6px; color: var(--text-secondary); cursor: pointer; }
.header-actions .btn:hover { background: rgba(255,255,255,0.08); color: var(--text-primary); }
.header-actions .btn.active { background: var(--accent-blue); border-color: var(--accent-blue); color: #fff; }
.filters-card { background: var(--card-bg); border: 1px solid var(--border-subtle); border-radius: var(--radius-lg); padding: 20px; }
.table-wrapper { overflow-x: auto; }
.boletins-table table, .usuarios-table table { width: 100%; border-collapse: collapse; font-size: 13px; }
.boletins-table th, .boletins-table td, .usuarios-table th, .usuarios-table td { padding: 12px 16px; text-align: left; border-bottom: 1px solid var(--border-subtle); }
.empty-state { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 12px; padding: 40px 20px; color: var(--text-muted); text-align: center; }
.empty-state h3 { margin: 0; font-size: 18px; color: var(--text-primary); }
.protocolo-badge { font-weight: 600; color: var(--accent-blue); }
.vitima-nome { display: block; font-weight: 500; }
.vitima-cpf { font-size: 12px; color: var(--text-muted); }
.tipo-badge { padding: 4px 8px; background: rgba(255,255,255,0.06); border-radius: 4px; font-size: 12px; }
.status-badges { display: flex; gap: 6px; flex-wrap: wrap; }
.badge { display: inline-flex; align-items: center; gap: 4px; padding: 2px 8px; border-radius: 4px; font-size: 11px; }
.badge-success { background: rgba(47,179,68,0.15); color: #2fb344; }
.badge-warning { background: rgba(247,103,7,0.15); color: #f76707; }
.table-actions { display: flex; gap: 6px; }
.action-icon { padding: 8px; background: var(--bg-tertiary); border: 1px solid var(--border-subtle); border-radius: 6px; color: var(--text-secondary); cursor: pointer; }
.action-icon:hover { color: var(--accent-blue); border-color: var(--accent-blue); }
.action-icon.danger:hover { color: var(--accent-pink); border-color: var(--accent-pink); }
.table-pagination { display: flex; justify-content: space-between; align-items: center; padding: 12px 16px; border-top: 1px solid var(--border-subtle); }
.pagination-current { font-size: 13px; color: var(--text-secondary); margin: 0 12px; }
.modal-content.modal-sm { max-width: 400px; }
.modal-content.modal-lg { max-width: 640px; }
.btn-ghost { background: transparent; color: var(--text-secondary); }
.modal-section { margin-bottom: 20px; }
.modal-section h4 { font-size: 14px; color: var(--text-secondary); margin: 0 0 12px; }
.modal-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 12px; }
.modal-item { display: flex; flex-direction: column; gap: 2px; }
.modal-label { font-size: 11px; color: var(--text-muted); text-transform: uppercase; }
.modal-value { font-size: 13px; color: var(--text-primary); }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.form-error { padding: 12px; background: rgba(214,51,132,0.1); border-radius: 8px; color: var(--accent-pink); margin-bottom: 16px; }
.search-bar { display: flex; gap: 12px; margin-bottom: 16px; }
.search-input { display: flex; align-items: center; gap: 8px; flex: 1; padding: 10px 14px; background: var(--bg-tertiary); border: 1px solid var(--border-subtle); border-radius: 6px; }
.search-input input { flex: 1; background: none; border: none; color: var(--text-primary); font-size: 14px; outline: none; }
.user-cell { display: flex; align-items: center; gap: 12px; }
.user-avatar { width: 40px; height: 40px; border-radius: 50%; background: var(--accent-blue); color: #fff; display: flex; align-items: center; justify-content: center; font-weight: 600; flex-shrink: 0; }
.user-name { display: block; font-weight: 500; }
.user-username { font-size: 12px; color: var(--text-muted); }
.role-badge { display: inline-flex; align-items: center; gap: 4px; padding: 4px 10px; border-radius: 6px; font-size: 12px; }
.role-badge.admin { background: rgba(111,66,193,0.15); color: #6f42c1; }
.role-badge.user { background: rgba(255,255,255,0.06); color: var(--text-secondary); }
.status-badge.active { color: #2fb344; }
.status-badge.inactive { color: var(--text-muted); }
.config-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 20px; }
.config-section { background: var(--card-bg); border: 1px solid var(--border-subtle); border-radius: var(--radius-lg); overflow: hidden; }
.config-section-header { display: flex; align-items: center; gap: 12px; padding: 16px 20px; border-bottom: 1px solid var(--border-subtle); background: rgba(255,255,255,0.02); flex-wrap: wrap; }
.config-section-header h2 { margin: 0; font-size: 15px; font-weight: 600; color: var(--text-primary); flex: 1; }
.config-section-icon { color: var(--icon-color); font-size: 1.25rem; flex-shrink: 0; }
.config-toggle { position: relative; width: 48px; height: 24px; cursor: pointer; flex-shrink: 0; margin-left: auto; }
.config-toggle input { opacity: 0; width: 0; height: 0; }
.toggle-slider { position: absolute; inset: 0; background: rgba(255,255,255,0.1); border-radius: 24px; transition: 0.3s; }
.toggle-slider::before { content: ''; position: absolute; width: 18px; height: 18px; left: 3px; top: 3px; background: #fff; border-radius: 50%; transition: 0.3s; }
.config-toggle input:checked + .toggle-slider { background: var(--accent-blue); }
.config-toggle input:checked + .toggle-slider::before { transform: translateX(24px); }
.config-password-field { position: relative; display: flex; align-items: center; }
.password-toggle-btn { position: absolute; right: 10px; top: 50%; transform: translateY(-50%); padding: 6px; background: none; border: none; color: var(--text-muted); cursor: pointer; border-radius: 4px; }
.password-toggle-btn:hover { color: var(--icon-color); }
.config-test-btn { display: inline-flex; align-items: center; gap: 8px; padding: 10px 16px; margin-top: 8px; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.08); border-radius: var(--radius-md); color: var(--text-secondary); font-size: 13px; font-weight: 500; cursor: pointer; transition: var(--transition-fast); }
.config-test-btn:hover:not(:disabled) { background: rgba(255,255,255,0.08); border-color: rgba(255,255,255,0.12); color: var(--text-primary); }
.config-test-btn:disabled { opacity: 0.6; cursor: not-allowed; }
.config-test-btn.loading .ti { animation: spin 1s linear infinite; }

.config-api-card { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px; padding: 14px 16px; background: rgba(255,255,255,0.03); border: 1px solid var(--border-subtle, rgba(255,255,255,0.08)); border-radius: 8px; }
.config-api-card-header { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.config-api-title { font-weight: 600; font-size: 14px; color: var(--text-primary); }
.config-api-type { font-size: 11px; font-weight: 600; padding: 4px 8px; border-radius: 6px; }
.config-api-type-sms { background: rgba(32,107,196,0.2); color: #4299e1; }
.config-api-type-email { background: rgba(47,179,68,0.2); color: #2fb344; }
.config-api-default-badge { font-size: 10px; padding: 2px 6px; border-radius: 4px; background: var(--accent-blue); color: #fff; }
.config-api-card-actions { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.config-api-btn { padding: 6px 12px; font-size: 12px; border-radius: 6px; border: 1px solid var(--border-subtle); background: rgba(255,255,255,0.04); color: var(--text-secondary); cursor: pointer; transition: var(--transition-fast); }
.config-api-btn:hover { background: rgba(255,255,255,0.08); color: var(--text-primary); }
.config-api-btn-test { color: var(--accent-blue); }
.config-api-btn-delete { color: var(--accent-pink, #d63384); }
.config-api-toggle { margin-right: 4px; }
.config-hint { margin-top: 8px; font-size: 12px; color: var(--text-muted); }
.config-file-input { width: 100%; padding: 10px 12px; border: 1px solid var(--border-subtle); border-radius: var(--radius-md); background: var(--bg-tertiary); color: var(--text-primary); font-size: 13px; cursor: pointer; }
.config-configured-badge { display: inline-flex; align-items: center; gap: 4px; font-size: 12px; color: #2fb344; margin-left: auto; }
.config-upload-status { display: block; margin-top: 8px; font-size: 12px; color: var(--accent-blue); }
.config-preview-box { margin-top: 10px; padding: 12px; background: var(--bg-tertiary); border: 1px solid var(--border-subtle); border-radius: var(--radius-md); }
.config-preview-box .config-preview-label { font-size: 11px; font-weight: 600; color: var(--accent-green); text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: 8px; display: block; }
.config-preview-box img { max-width: 200px; max-height: 120px; width: auto; height: auto; display: block; border-radius: 4px; border: 1px solid var(--border-subtle); }
.config-preview-box.config-preview-empty .config-preview-label { color: var(--text-muted); }
.config-boletim-global-hint { font-size: 12px; color: var(--text-muted); margin-bottom: 16px; padding: 10px 12px; background: rgba(32,107,196,0.08); border-radius: var(--radius-md); border-left: 3px solid var(--accent-blue); }
.config-save-success { font-size: 13px; color: var(--accent-green); padding: 10px 12px; background: rgba(47,179,68,0.1); border-radius: var(--radius-md); margin-bottom: 16px; display: none; }
.config-save-success.show { display: block; }
.config-field-hint { font-weight: normal; color: var(--text-muted); font-size: 11px; }
.badge .ti { font-size: 0.9rem; }
.action-icon .ti { font-size: 1rem; color: inherit; }
.config-section-body { padding: 16px; }
.config-field { margin-bottom: 12px; }
.config-field label { display: block; font-size: 12px; font-weight: 500; color: var(--text-secondary); margin-bottom: 4px; }
.config-field input,
.config-field select,
.config-password-field input {
  width: 100%;
  height: 40px;
  padding: 10px 12px;
  background: var(--bg-tertiary);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  color: var(--text-primary);
  font-size: 13px;
  font-family: var(--font-primary);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}
.config-field input::placeholder,
.config-password-field input::placeholder {
  color: var(--text-muted);
}
.config-field input:hover:not(:disabled):not(:focus),
.config-field select:hover:not(:disabled):not(:focus),
.config-password-field input:hover:not(:disabled):not(:focus) {
  border-color: rgba(255,255,255,0.12);
}
.config-field input:focus,
.config-field select:focus,
.config-password-field input:focus {
  outline: none;
  border-color: var(--accent-blue);
  box-shadow: 0 0 0 3px rgba(32,107,196,0.2);
}
.config-field input:disabled,
.config-field select:disabled,
.config-password-field input:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}
.config-field select {
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23959ca9' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  padding-right: 36px;
}
.config-password-field input { padding-right: 44px; flex: 1; min-width: 0; }
.config-save-btn { display: inline-flex; align-items: center; gap: 8px; padding: 10px 20px; background: var(--accent-blue); color: #fff; border: none; border-radius: 8px; font-weight: 600; cursor: pointer; }
.config-save-btn:disabled { opacity: 0.7; cursor: not-allowed; }
.sms-massa { display: flex; flex-direction: column; gap: 20px; }
.sms-header { display: flex; align-items: center; gap: 16px; padding: 16px; background: var(--card-bg); border-radius: var(--radius-lg); border: 1px solid var(--border-subtle); }
.sms-header h1 { margin: 0 0 4px; font-size: 20px; }
.sms-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: 20px; }
.sms-card { background: var(--card-bg); border: 1px solid var(--border-subtle); border-radius: var(--radius-lg); overflow: hidden; }
.sms-card-head { display: flex; align-items: center; gap: 8px; padding: 14px 16px; border-bottom: 1px solid var(--border-subtle); font-weight: 600; }
.sms-badge { background: var(--accent-blue); color: #fff; padding: 2px 8px; border-radius: 10px; font-size: 12px; }
.sms-card-body { padding: 16px; }
.sms-textarea { width: 100%; min-height: 120px; padding: 12px; background: var(--bg-tertiary); border: 1px solid var(--border-subtle); border-radius: 6px; color: var(--text-primary); font-size: 14px; resize: vertical; }
.sms-actions { display: flex; gap: 8px; margin-top: 12px; flex-wrap: wrap; }
.sms-btn { display: inline-flex; align-items: center; gap: 6px; padding: 10px 16px; border-radius: 6px; font-size: 13px; cursor: pointer; border: 1px solid var(--border-subtle); background: var(--bg-tertiary); color: var(--text-primary); }
.sms-btn.primary { background: var(--accent-blue); border-color: var(--accent-blue); color: #fff; }
.sms-btn.primary:disabled { opacity: 0.6; cursor: not-allowed; }
.historico-list { display: flex; flex-direction: column; gap: 8px; }
.historico-item { display: flex; justify-content: space-between; align-items: center; padding: 12px; background: var(--bg-tertiary); border-radius: 6px; }
.historico-info { display: flex; flex-wrap: wrap; gap: 12px; font-size: 13px; }
.historico-data { color: var(--text-muted); }
.historico-status .status { padding: 4px 8px; border-radius: 4px; font-size: 12px; }
.historico-status .status.concluido { background: rgba(47,179,68,0.15); color: #2fb344; }
.sms-progresso { margin-top: 12px; }
.progresso-bar { height: 8px; background: var(--bg-tertiary); border-radius: 4px; overflow: hidden; }
.progresso-fill { height: 100%; background: var(--accent-green); transition: width 0.3s; }
.progresso-info { display: flex; gap: 16px; margin-top: 8px; font-size: 12px; }
.perfil-page { display: flex; flex-direction: column; gap: 20px; }
.perfil-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 24px; }
.profile-card { background: var(--card-bg); border: 1px solid var(--border-subtle); border-radius: var(--radius-lg); padding: 24px; text-align: center; }
.profile-header { position: relative; }
.profile-avatar { width: 100px; height: 100px; border-radius: 50%; margin: 0 auto 16px; background: var(--accent-blue); color: #fff; display: flex; align-items: center; justify-content: center; font-size: 36px; font-weight: 700; position: relative; overflow: hidden; }
.profile-avatar img { width: 100%; height: 100%; object-fit: cover; }
.avatar-edit { position: absolute; bottom: 0; right: 0; width: 32px; height: 32px; border-radius: 50%; background: var(--accent-blue); color: #fff; border: 2px solid var(--card-bg); cursor: pointer; display: flex; align-items: center; justify-content: center; }
.edit-card { background: var(--card-bg); border: 1px solid var(--border-subtle); border-radius: var(--radius-lg); padding: 24px; }
.edit-card h3 { margin: 0 0 20px; font-size: 18px; }
.form-divider { margin: 20px 0 12px; padding-top: 16px; border-top: 1px solid var(--border-subtle); font-size: 13px; color: var(--text-secondary); }
.profile-stats { display: flex; flex-direction: column; gap: 12px; margin-top: 20px; text-align: left; }
.stat-item { display: flex; align-items: center; gap: 12px; font-size: 13px; }
.stat-label { display: block; font-size: 11px; color: var(--text-muted); }
.stat-value { color: var(--text-primary); font-weight: 500; }

/* ========== TEMA CLARO – variáveis e todos os componentes ========== */
html[data-theme="light"] {
  --sidebar-bg: #ffffff;
  --sidebar-border: #e6e8eb;
  --sidebar-text: #495057;
  --sidebar-text-hover: #1d273b;
  --header-bg: #ffffff;
  --main-bg: #f4f6fa;
  --card-bg: #ffffff;
  --bg-tertiary: #f0f2f5;
  --border-subtle: #e6e8eb;
  --border-color: #e6e8eb;
  --input-bg: #ffffff;
  --text-primary: #1d273b;
  --text-secondary: #495057;
  --text-muted: #656d77;
  --icon-color: #206bc4;
  --shadow-sm: 0 2px 8px rgba(0,0,0,0.06);
  --shadow-md: 0 4px 20px rgba(0,0,0,0.08);
}

[data-theme="light"] .login-page { background: #f4f6fa; }
[data-theme="light"] .login-card { background: #fff; border-color: #e6e8eb; box-shadow: 0 24px 64px rgba(0,0,0,0.08); }
[data-theme="light"] .login-theme-toggle { background: rgba(0,0,0,0.04); border-color: rgba(0,0,0,0.08); color: #495057; }
[data-theme="light"] .login-theme-toggle:hover { background: rgba(0,0,0,0.08); color: #1d273b; }
[data-theme="light"] .form-group label { color: #495057; }
[data-theme="light"] .form-group input,
[data-theme="light"] .form-group select,
[data-theme="light"] .form-group textarea { background: #f8f9fa; border-color: #e6e8eb; color: #1d273b; }
[data-theme="light"] .sidebar { background: #fff; border-color: #e6e8eb; }
[data-theme="light"] .header { background: #fff; border-color: #e6e8eb; box-shadow: 0 1px 4px rgba(0,0,0,0.06); }
[data-theme="light"] .main { background: #f4f6fa; }
[data-theme="light"] .page-title { color: #1d273b; }
[data-theme="light"] .user-dropdown { background: #fff; border-color: #e6e8eb; box-shadow: 0 16px 48px rgba(0,0,0,0.12); }
[data-theme="light"] .card { background: #fff; border-color: #e6e8eb; }
[data-theme="light"] body { color: #1d273b; }
[data-theme="light"] .nav-link { color: #495057; }
[data-theme="light"] .nav-link:hover { color: #1d273b; background: rgba(0,0,0,0.04); }
[data-theme="light"] .nav-section-title { color: #656d77; }
[data-theme="light"] .header-btn { color: #495057; }
[data-theme="light"] .header-btn:hover { color: #1d273b; background: rgba(0,0,0,0.05); }
[data-theme="light"] .user-menu-trigger { border-color: #e6e8eb; color: #1d273b; }
[data-theme="light"] .user-role { color: #656d77; }
[data-theme="light"] .dropdown-item { color: #495057; }
[data-theme="light"] .dropdown-item:hover { color: #1d273b; background: #f8f9fa; }
[data-theme="light"] .logo-text { color: #206bc4; }

/* Dashboard tema claro */
[data-theme="light"] .breadcrumb { color: #656d77; }
[data-theme="light"] .breadcrumb .current { color: #1d273b; }
[data-theme="light"] .dash-hero { background: linear-gradient(135deg, #fff 0%, #f8f9fa 100%); border-color: #e6e8eb; box-shadow: var(--shadow-sm); }
[data-theme="light"] .dash-hero::before { background: linear-gradient(90deg, #206bc4 0%, #4a90e2 50%, #206bc4 100%); }
[data-theme="light"] .hero-greeting { color: #495057; }
[data-theme="light"] .hero-name { background: linear-gradient(135deg, #1d273b 0%, #206bc4 100%); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
[data-theme="light"] .hero-subtitle { color: #656d77; }
[data-theme="light"] .hero-ramal { color: #495057; background: rgba(32,107,196,0.08); }
[data-theme="light"] .hero-motivacional .motivacional-content { background: linear-gradient(135deg, rgba(32,107,196,0.08) 0%, rgba(32,107,196,0.04) 100%); border-color: rgba(32,107,196,0.2); }
[data-theme="light"] .motivacional-label { color: #206bc4; }
[data-theme="light"] .motivacional-text { color: #1d273b; }
[data-theme="light"] .hero-stats { border-top-color: #e6e8eb; }
[data-theme="light"] .stat-num { background: linear-gradient(135deg, #1d273b 0%, #206bc4 100%); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
[data-theme="light"] .stat-lbl { color: #656d77; }
[data-theme="light"] .card-chart,
[data-theme="light"] .card-online,
[data-theme="light"] .card-atividades,
[data-theme="light"] .card-atendentes-stats { background: #fff; border-color: #e6e8eb; }
[data-theme="light"] .card-header,
[data-theme="light"] .card-head { border-bottom-color: #e6e8eb; }
[data-theme="light"] .card-head h3 { color: #1d273b; }
[data-theme="light"] .update-badge { color: #656d77; }
[data-theme="light"] .chart-filters .filter-btn { border-color: #e6e8eb; color: #495057; }
[data-theme="light"] .chart-filters .filter-btn:hover { border-color: #dee2e6; color: #1d273b; }
[data-theme="light"] .chart-filters .filter-btn.active { background: rgba(32,107,196,0.08); border-color: #206bc4; color: #1d273b; }
[data-theme="light"] .chart-stat .label { color: #656d77; }
[data-theme="light"] .chart-stat .value { color: #1d273b; }
[data-theme="light"] .online-name { color: #1d273b; }
[data-theme="light"] .online-ramal { color: #656d77; }
[data-theme="light"] .atendentes-table th { color: #656d77; }
[data-theme="light"] .atendentes-table td { color: #1d273b; border-bottom-color: #e6e8eb; }
[data-theme="light"] .atendentes-table thead { background: #f8f9fa; }
[data-theme="light"] .atendentes-table tbody tr:hover { background: #f8f9fa; }
[data-theme="light"] .empty { color: #656d77; }
[data-theme="light"] .empty span { color: #656d77; }

/* Formulários, inputs e grids tema claro */
[data-theme="light"] .form-group input,
[data-theme="light"] .form-group select,
[data-theme="light"] .form-group textarea { background: #f8f9fa; }
[data-theme="light"] .search-input { background: #f8f9fa; border-color: #e6e8eb; }
[data-theme="light"] .search-input input { color: #1d273b; }
[data-theme="light"] table th { color: #495057; }
[data-theme="light"] table td { color: #1d273b; border-bottom-color: #e6e8eb; }
[data-theme="light"] .consulta-card,
[data-theme="light"] .resultado-card { background: #fff; border-color: #e6e8eb; }
[data-theme="light"] .consulta-header h2 { color: #1d273b; }
[data-theme="light"] .consulta-header p { color: #656d77; }
[data-theme="light"] .radio-btn { background: #f8f9fa; border-color: #e6e8eb; color: #495057; }
[data-theme="light"] .radio-btn:hover { background: #f0f2f5; color: #1d273b; }
[data-theme="light"] .radio-btn.active { background: rgba(32,107,196,0.1); color: #206bc4; border-color: #206bc4; }
[data-theme="light"] .consulta-input { background: #f8f9fa !important; color: #1d273b !important; border-color: #e6e8eb !important; }
[data-theme="light"] .resultado-header { border-bottom-color: #e6e8eb; }
[data-theme="light"] .resultado-header h3 { color: #1d273b; }
[data-theme="light"] .resultado-item { background: linear-gradient(135deg, #f8f9fa 0%, #f0f2f5 100%); border-color: #e6e8eb; }
[data-theme="light"] .resultado-label { color: #495057; }
[data-theme="light"] .resultado-value { color: #1d273b; }
[data-theme="light"] .resultado-section { background: #f8f9fa; border-color: #e6e8eb; }
[data-theme="light"] .resultado-section-title { color: #1d273b; border-bottom-color: rgba(32,107,196,0.2); }

/* Logs tema claro */
[data-theme="light"] .logs-header,
[data-theme="light"] .logs-tabs,
[data-theme="light"] .filters-panel,
[data-theme="light"] .logs-table-container,
[data-theme="light"] .logs-pagination { background: #fff; border-color: #e6e8eb; }
[data-theme="light"] .filters-panel .filters-panel-head { background: #f8f9fa; border-bottom-color: #e6e8eb; }
[data-theme="light"] .filters-panel .filters-panel-head span { color: #1d273b; }
[data-theme="light"] .filters-grid .form-group select,
[data-theme="light"] .filters-grid .form-group input[type="date"] { background: #f8f9fa; border-color: #e6e8eb; color: #1d273b; }
[data-theme="light"] .filters-grid .form-group select:hover,
[data-theme="light"] .filters-grid .form-group input[type="date"]:hover { border-color: #dee2e6; }
[data-theme="light"] .filter-group-atendentes { border-top-color: #e6e8eb; }
[data-theme="light"] .checkbox-label { background: #f8f9fa; border-color: #e6e8eb; }
[data-theme="light"] .checkbox-label:hover { background: #f0f2f5; border-color: #dee2e6; }
[data-theme="light"] .checkbox-text .atendente-name { color: #1d273b; }
[data-theme="light"] .filters-actions { background: #f8f9fa; border-top-color: #e6e8eb; }
[data-theme="light"] .logs-header h1 { color: #1d273b; }
[data-theme="light"] .logs-btn-icon { background: #f8f9fa; border-color: #e6e8eb; color: #495057; }
[data-theme="light"] .logs-btn-icon:hover { color: #1d273b; background: #f0f2f5; }
[data-theme="light"] .logs-btn-filter { background: #f8f9fa; border-color: #e6e8eb; color: #495057; }
[data-theme="light"] .logs-tab { color: #495057; }
[data-theme="light"] .logs-tab:hover { color: #1d273b; background: #f8f9fa; }
[data-theme="light"] .logs-table th { color: #495057; }
[data-theme="light"] .logs-table td { color: #1d273b; border-bottom-color: #e6e8eb; }
[data-theme="light"] .logs-table tbody tr:hover { background: #f8f9fa; }
[data-theme="light"] .modal-content,
[data-theme="light"] .modal-header,
[data-theme="light"] .modal-body,
[data-theme="light"] .modal-footer { background: #fff; border-color: #e6e8eb; }
[data-theme="light"] .modal-header h3 { color: #1d273b; }
[data-theme="light"] .modal-close { color: #495057; }
[data-theme="light"] .modal-content .form-group label { color: #1d273b; }
[data-theme="light"] .modal-content .form-group input,
[data-theme="light"] .modal-content .form-group select,
[data-theme="light"] .modal-content .form-group textarea { background: #fff; border-color: #dee2e6; color: #1d273b; }
[data-theme="light"] .modal-content .form-error { background: rgba(214,51,132,0.08); color: #c7156b; }
/* Modal Editar HTML (config): tema claro – fundo branco e texto preto */
[data-theme="light"] .config-modal-box,
[data-theme="light"] .config-modal-header,
[data-theme="light"] .config-modal-body,
[data-theme="light"] .config-modal-footer { background: #fff !important; border-color: #e6e8eb !important; }
[data-theme="light"] .config-modal-box h3,
[data-theme="light"] .config-modal-box label,
[data-theme="light"] .config-modal-box p { color: #1d273b !important; }
[data-theme="light"] .config-modal-box input,
[data-theme="light"] .config-modal-box textarea { background: #fff !important; border-color: #dee2e6 !important; color: #1d273b !important; }
[data-theme="light"] .config-modal-box #config-protocolo-modal-close { color: #495057; }
/* Botão primary no tema claro: fundo #206bc4 e texto branco */
[data-theme="light"] .btn-primary { background: #206bc4 !important; }
[data-theme="light"] .btn-primary:hover { background: #1a5bb0 !important; }
[data-theme="light"] .btn-primary,
[data-theme="light"] .btn-primary span,
[data-theme="light"] .btn-primary i { color: #fff !important; }
[data-theme="light"] .header-actions .btn.btn-primary { background: #206bc4 !important; color: #fff !important; }
[data-theme="light"] .header-actions .btn.btn-primary:hover { background: #1a5bb0 !important; color: #fff !important; }
/* Botão Salvar Tudo (config): tema claro – letras brancas */
[data-theme="light"] .config-save-btn,
[data-theme="light"] .config-save-btn .btn-text,
[data-theme="light"] .config-save-btn .btn-loading { color: #fff !important; }
[data-theme="light"] .config-save-btn { background: #206bc4 !important; }
[data-theme="light"] .config-save-btn:hover { background: #1a5bb0 !important; }
[data-theme="light"] .detail-section h4 { color: #495057; }
[data-theme="light"] .detail-label { color: #656d77; }
[data-theme="light"] .detail-value,
[data-theme="light"] .field-value { color: #1d273b; }
[data-theme="light"] .detail-json { background: #f0f2f5; color: #1d273b; }
[data-theme="light"] .pagination-btn { background: #f8f9fa; border-color: #e6e8eb; color: #1d273b; }
[data-theme="light"] .btn-view-details { background: #f8f9fa; border-color: #e6e8eb; color: #495057; }

/* Boletins, Usuários, Config, Perfil, SMS Massa tema claro */
[data-theme="light"] .header-info h2 { color: #1d273b; }
[data-theme="light"] .header-info p { color: #656d77; }
[data-theme="light"] .header-actions .btn { background: #f8f9fa; border-color: #e6e8eb; color: #495057; }
[data-theme="light"] .header-actions .btn:hover { background: #f0f2f5; color: #1d273b; }
[data-theme="light"] .filters-card { background: #fff; border-color: #e6e8eb; }
[data-theme="light"] .boletins-table th,
[data-theme="light"] .boletins-table td,
[data-theme="light"] .usuarios-table th,
[data-theme="light"] .usuarios-table td { border-bottom-color: #e6e8eb; color: #1d273b; }
[data-theme="light"] .boletins-table th,
[data-theme="light"] .usuarios-table th { color: #495057; }
[data-theme="light"] .empty-state h3 { color: #1d273b; }
[data-theme="light"] .config-section { background: #fff; border-color: #e6e8eb; }
[data-theme="light"] .config-section-header { border-bottom-color: #e6e8eb; }
[data-theme="light"] .config-section-header h2 { color: #1d273b; }
[data-theme="light"] .config-field label { color: #495057; }
[data-theme="light"] .config-field input,
[data-theme="light"] .config-field select,
[data-theme="light"] .config-password-field input {
  background: #f8f9fa;
  border-color: #e6e8eb;
  color: #1d273b;
}
[data-theme="light"] .config-field input::placeholder,
[data-theme="light"] .config-password-field input::placeholder { color: #868e96; }
[data-theme="light"] .config-field input:focus,
[data-theme="light"] .config-field select:focus,
[data-theme="light"] .config-password-field input:focus {
  border-color: #206bc4;
  box-shadow: 0 0 0 3px rgba(32,107,196,0.15);
}
[data-theme="light"] .config-header { background: #fff; border-color: #e6e8eb; }
[data-theme="light"] .config-header h1 { color: #1d273b; }
[data-theme="light"] .sms-header,
[data-theme="light"] .sms-card { background: #fff; border-color: #e6e8eb; }
[data-theme="light"] .sms-card-head { border-bottom-color: #e6e8eb; color: #1d273b; }
[data-theme="light"] .sms-textarea { background: #f8f9fa; border-color: #e6e8eb; color: #1d273b; }
[data-theme="light"] .sms-btn { background: #f8f9fa; border-color: #e6e8eb; color: #1d273b; }
[data-theme="light"] .historico-item { background: #f8f9fa; }
[data-theme="light"] .progresso-bar { background: #e6e8eb; }
[data-theme="light"] .profile-card,
[data-theme="light"] .edit-card { background: #fff; border-color: #e6e8eb; }
[data-theme="light"] .edit-card h3 { color: #1d273b; }
[data-theme="light"] .form-divider { border-top-color: #e6e8eb; color: #495057; }
[data-theme="light"] .online-indicator { background: rgba(47,179,68,0.1); border-color: rgba(47,179,68,0.2); }
[data-theme="light"] .online-list-sidebar { background: #f8f9fa; }
[data-theme="light"] .online-user-name { color: #1d273b; }
[data-theme="light"] .table-pagination { border-top-color: #e6e8eb; }
[data-theme="light"] .pagination-current { color: #495057; }
[data-theme="light"] .action-icon { background: #f8f9fa; border-color: #e6e8eb; color: #495057; }
[data-theme="light"] .sidebar-close { color: #495057; }
[data-theme="light"] .card-title { color: #1d273b; }
[data-theme="light"] .stat-value { color: #1d273b; }
[data-theme="light"] .stat-label { color: #656d77; }
[data-theme="light"] .empty-icon { color: #959ca9; }
[data-theme="light"] ::-webkit-scrollbar-thumb { background: rgba(0,0,0,0.15); }
[data-theme="light"] ::-webkit-scrollbar-thumb:hover { background: rgba(0,0,0,0.25); }
/* Tema claro: garantir que todas as letras sejam pretas/visíveis */
[data-theme="light"], [data-theme="light"] body, [data-theme="light"] .main, [data-theme="light"] .page-content,
[data-theme="light"] h1, [data-theme="light"] h2, [data-theme="light"] h3, [data-theme="light"] h4,
[data-theme="light"] p, [data-theme="light"] span, [data-theme="light"] label, [data-theme="light"] a,
[data-theme="light"] .resultado-label, [data-theme="light"] .resultado-value, [data-theme="light"] .resultado-section-title,
[data-theme="light"] .form-hint, [data-theme="light"] .config-hint, [data-theme="light"] .config-preview-label,
[data-theme="light"] .modal-label, [data-theme="light"] .modal-value, [data-theme="light"] .vitima-nome, [data-theme="light"] .vitima-cpf {
  color: #000 !important;
}
[data-theme="light"] .text-muted, [data-theme="light"] .breadcrumb span:not(.current) { color: #333 !important; }

/* ========== RESPONSIVO - PAINEL PHP (qualquer dispositivo) ========== */
@media (max-width: 992px) {
  .page-content { padding: 16px; }
  .page-header { flex-direction: column; align-items: flex-start; gap: 12px; }
  .header-actions { width: 100%; justify-content: flex-start; flex-wrap: wrap; }
  .stats-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .dashboard .card { padding: 16px; }
  .acoes-grid { flex-wrap: wrap; gap: 8px; }
  .acao-btn { min-width: 140px; }
  .envio-tipos { flex-wrap: wrap; }
  .envio-tipo { flex: 1; min-width: 120px; }
  .filters-grid { grid-template-columns: 1fr 1fr; }
  .resultado-acoes .envio-form { padding: 16px; }
  .form-row { grid-template-columns: 1fr; }
  .search-bar { flex-direction: column; }
  .search-input { min-width: 0; }
  .table-wrap, .table-wrapper { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  table { font-size: 12px; }
  table th, table td { padding: 8px 10px; }
  .modal-content { max-width: 96%; margin: 10px; }
  .modal-content.modal-lg { max-width: 96%; }
  .config-section-body { padding: 14px; }
}
@media (max-width: 768px) {
  .sidebar { transform: translateX(-100%); width: 280px; }
  .sidebar.open { transform: translateX(0); }
  .sidebar-close { display: block; }
  .menu-toggle { display: block; }
  .main { margin-left: 0; }
  .user-info { display: none; }
  .page-title { font-size: 13px; max-width: 120px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
  .header-right { gap: 2px; }
  .header-btn { padding: 8px; }
  .page-content { padding: 12px; }
  .stats-grid { grid-template-columns: 1fr; }
  .card-stats .stat-value { font-size: 1.5rem; }
  .consultas-page .consulta-card { padding: 16px; }
  .consultas-page .consulta-tipos { gap: 8px; }
  .consultas-page .tipo-btn { min-width: 100px; padding: 12px 16px; font-size: 12px; }
  .resultado-acoes h4 { font-size: 14px; }
  .acoes-grid { flex-direction: column; }
  .acao-btn { width: 100%; justify-content: center; }
  .envio-form { padding: 16px; }
  .envio-form .form-group { margin-bottom: 12px; }
  .envio-form .btn { width: 100%; }
  .filters-grid { grid-template-columns: 1fr; }
  .filters-actions { flex-direction: column; }
  .filters-actions .btn { width: 100%; min-width: 0; }
  .logs-header { flex-wrap: wrap; gap: 10px; }
  .logs-header .header-actions { flex-wrap: wrap; }
  .logs-tabs { flex-direction: column; }
  .logs-tab { width: 100%; }
  .atendentes-table th, .atendentes-table td { padding: 10px 12px; font-size: 12px; }
  .atendente-cell { flex-wrap: wrap; }
  .user-menu-trigger { padding: 4px 6px; }
  .notification-dropdown { min-width: 260px; max-width: 100vw; }
  .breadcrumb { flex-wrap: wrap; font-size: 12px; }
}
@media (max-width: 480px) {
  .page-content { padding: 10px; }
  .consultas-page .tipo-btn { min-width: 0; flex: 1; }
  .consultas-page .consulta-form .btn-lg { width: 100%; }
  .resultado-header { flex-direction: column; align-items: flex-start; gap: 10px; }
  .resultado-header .btn { width: 100%; }
  .resultado-item-unico .resultado-grid { grid-template-columns: 1fr; }
  .resultado-dado-item { border-right: none; }
  .envio-tipos { flex-direction: column; }
  .envio-tipo { width: 100%; }
  .boletim-select-banco, .boletim-input, .boletim-input-email { font-size: 16px; }
  input[type="email"], input[type="tel"], input[type="text"] { font-size: 16px; }
  .modal-content { max-width: 100%; margin: 8px; border-radius: 12px; }
  .modal-header, .modal-footer { padding: 12px 16px; }
  .modal-body { padding: 16px; }
  .logs-btn-filter { padding: 8px 10px; font-size: 12px; }
  .pagination-controls { flex-wrap: wrap; }
  .table-pagination { flex-direction: column; gap: 10px; align-items: stretch; }
  .user-menu-trigger .user-avatar { width: 28px; height: 28px; font-size: 12px; }
  .user-menu-trigger .user-avatar img { width: 100%; height: 100%; object-fit: cover; }
}
@media (min-width: 769px) {
  .sidebar.open { transform: translateX(0); }
}
