/* ============================================================
   PONTUS - Estilo Executivo Sobrio
   Creme + Marinho + Dourado, serifa nas manchetes, sans no corpo.
   ============================================================ */

:root{
    --bg:#F2ECDB;
    --surface:#FBF7EB;
    --surface-soft:#F7F1DC;
    --ink:#0F1E3B;
    --ink-soft:#1F3052;
    --ink-mute:#39456B;
    --muted:#5A4A1F;
    --gold:#A07F1F;
    --gold-soft:#D8C079;
    --gold-dark:#6E5410;
    --danger:#7A1F1F;
    --danger-soft:#C16363;
    --ok:#2C5208;
    --ok-soft:#7BAA42;
    --line:#D5CAA8;
    --line-soft:#E5DCC0;
    --row-alt:#EDE5CC;
    --edit-bg:#FFF6D9;
    --edit-bg-strong:#FFEFB8;
    --edit-border:#A07F1F;

    --font-display:'Cormorant Garamond', Georgia, serif;
    --font-body:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

*{box-sizing:border-box}

html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:var(--font-body);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}

a{color:var(--ink);text-decoration:none}
a:hover{color:var(--gold-dark)}

h1,h2,h3,h4{font-family:var(--font-display);font-weight:500;color:var(--ink);margin:0 0 8px;letter-spacing:0.2px;line-height:1.15}
h1{font-size:26px}
h2{font-size:22px}
h3{font-size:18px}
h4{font-size:16px;font-family:var(--font-body);font-weight:600;letter-spacing:0.5px;text-transform:uppercase;color:var(--muted);font-size:11px}

/* ============================================================
   LAYOUT: sidebar + conteudo
   ============================================================ */

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

.sidebar{
    width:240px;flex-shrink:0;background:#FBF7EB;border-right:1px solid var(--line);
    display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto;
}

.sidebar-head{padding:18px 18px 10px;border-bottom:1px solid var(--line-soft)}
.brand{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.brand-mark{width:38px;height:38px;display:flex;align-items:center;justify-content:center;color:var(--gold-dark);border:1px solid var(--gold);border-radius:50%}
.brand-text .brand-name{font-family:var(--font-display);font-size:22px;font-weight:600;color:var(--ink);line-height:1}
.brand-text .brand-meta{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin-top:2px}

.stats-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-top:6px}
.stat{background:var(--surface-soft);border:0.5px solid var(--line);padding:8px 6px;text-align:center}
.stat-num{font-family:var(--font-display);font-size:18px;font-weight:500;color:var(--ink);line-height:1.1}
.stat-lbl{font-size:9.5px;letter-spacing:1.2px;text-transform:uppercase;color:var(--muted);margin-top:2px;font-weight:700}
.stat.stat-warn .stat-num{color:var(--danger)}

.menu{padding:10px 0;flex:1}
.menu-grupo{display:flex;align-items:center;gap:6px;padding:14px 18px 6px;font-size:13px;letter-spacing:2px;text-transform:uppercase;color:var(--ink);font-weight:700}
.grupo-dot{width:5px;height:5px;background:var(--gold);border-radius:50%;flex-shrink:0}
.grupo-line{flex:1;border-bottom:1px dotted var(--line)}
.grupo-txt{white-space:nowrap}

.menu-item{
    display:flex;align-items:center;gap:10px;padding:10px 18px;color:var(--ink);
    font-size:13px;font-weight:500;border-left:2px solid transparent;transition:background .15s, color .15s, border-color .15s;
}
.menu-item:hover{background:var(--surface-soft);color:var(--ink)}
.menu-item.active{background:var(--surface-soft);color:var(--ink);border-left-color:var(--gold);font-weight:500}
.mi-icon{width:18px;text-align:center;color:var(--muted);font-size:15px}
.menu-item.active .mi-icon{color:var(--gold-dark)}
.mi-label{flex:1}
.mi-arrow{color:var(--line);font-size:14px}
.menu-item.active .mi-arrow{color:var(--gold)}
.mi-badge{background:var(--danger);color:#FFF;border-radius:10px;padding:1px 7px;font-size:11px;font-weight:500}

.sidebar-foot{padding:12px 18px;border-top:1px solid var(--line-soft);font-size:11px;color:var(--muted)}
.foot-rule{height:2px;background:linear-gradient(90deg,var(--gold) 0%,var(--gold) 30%,transparent 30%,transparent 100%);margin-bottom:8px}
.foot-text{display:flex;justify-content:space-between;letter-spacing:0.5px}

.sidebar-overlay{display:none}

/* ============================================================
   CONTEUDO
   ============================================================ */

.conteudo{flex:1;display:flex;flex-direction:column;min-width:0}

.topbar{
    background:var(--surface);border-bottom:1px solid var(--line);
    padding:14px 28px;display:flex;align-items:center;gap:18px;position:sticky;top:0;z-index:10;
}
.topbar h1{font-family:var(--font-display);font-size:22px;font-weight:500;margin:0;flex:1}
.menu-toggle{display:none;background:none;border:none;flex-direction:column;gap:3px;cursor:pointer;padding:6px}
.menu-toggle span{display:block;width:22px;height:2px;background:var(--ink)}

.user-info{display:flex;align-items:center;gap:14px;font-size:12px;color:var(--ink-soft)}
.user-name{font-weight:500;color:var(--ink)}
.user-perfil{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);border-left:2px solid var(--gold);padding-left:8px}
.btn-sair{background:var(--ink);color:var(--surface);padding:7px 16px;font-size:12px;letter-spacing:0.5px;border:none}
.btn-sair:hover{background:var(--ink-soft);color:var(--surface)}

.conteudo-inner{padding:24px 28px 60px;flex:1}

/* ============================================================
   ALERTAS / FLASH
   ============================================================ */
.alerta{padding:12px 18px;margin-bottom:18px;border-left:3px solid;font-size:13px}
.alerta.sucesso{background:#EEF6E2;border-color:var(--ok);color:#2C5208}
.alerta.erro{background:#FBEAEA;border-color:var(--danger);color:#5A1818}
.alerta.aviso{background:#FBEEDB;border-color:var(--gold);color:#5C5239}

/* ============================================================
   BOTOES
   ============================================================ */
.btn{
    display:inline-block;padding:9px 18px;font-size:13px;font-family:var(--font-body);
    background:var(--surface);color:var(--ink);border:1px solid var(--line);cursor:pointer;
    text-decoration:none;letter-spacing:0.3px;transition:all .15s;border-radius:0;
}
.btn:hover{background:var(--surface-soft);border-color:var(--gold)}
.btn-primary{background:var(--ink);color:var(--surface);border-color:var(--ink)}
.btn-primary:hover{background:var(--ink-soft);color:var(--surface);border-color:var(--ink-soft)}
.btn-gold{background:var(--gold);color:#FFF;border-color:var(--gold-dark)}
.btn-gold:hover{background:var(--gold-dark);color:#FFF}
.btn-novo{background:var(--gold);color:#FFF;border-color:var(--gold-dark)}
.btn-novo:hover{background:var(--gold-dark);color:#FFF}
.btn-editar{background:var(--surface);color:var(--ink);font-size:12px;padding:5px 10px}
.btn-excluir{background:#FFF;color:var(--danger);border-color:var(--danger-soft);font-size:12px;padding:5px 10px}
.btn-excluir:hover{background:var(--danger);color:#FFF;border-color:var(--danger)}
.btn-voltar{background:transparent;color:var(--ink-soft);border-color:var(--line)}
.btn-disabled{background:#EEE;color:#999;border-color:#DDD;cursor:not-allowed}
.btn-block{width:100%}

/* ============================================================
   FORMULARIOS
   ============================================================ */
.form-box{background:var(--surface);border:1px solid var(--line);border-top:3px solid var(--gold);padding:24px 28px;margin-bottom:24px}
.form-box h2{margin-top:0;padding-bottom:10px;border-bottom:1px solid var(--line-soft);margin-bottom:18px}
.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px 18px}
.campo{display:flex;flex-direction:column}
.campo label{font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin-bottom:6px;font-weight:700}
.campo input, .campo select, .campo textarea{
    padding:9px 12px;border:1.5px solid var(--edit-border);background:var(--edit-bg);color:var(--ink);
    font-size:14px;font-family:var(--font-body);border-radius:0;font-weight:500;
}
.campo input:focus, .campo select:focus, .campo textarea:focus{outline:none;border-color:var(--gold-dark);background:#FFF;box-shadow:0 0 0 3px rgba(160,127,31,.28)}
.campo input[readonly]{background:var(--surface-soft);color:var(--ink-soft);border-color:var(--line);font-weight:400}
.campo input[disabled], .campo select[disabled]{background:#EFE9D3;color:#6B6452;border-color:var(--line);font-weight:400}
.form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:22px;padding-top:14px;border-top:1px solid var(--line-soft)}

/* ============================================================
   ACAO BAR (busca + novo)
   ============================================================ */
.acao-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;gap:14px;flex-wrap:wrap}
.busca-bar{flex:1;max-width:380px}
.busca-bar input{width:100%;padding:9px 12px;border:1px solid var(--line);background:#FFF;font-size:13px;border-radius:0;font-family:var(--font-body)}
.busca-bar input:focus{outline:none;border-color:var(--gold)}

/* ============================================================
   TABELAS
   ============================================================ */
.tabela-box{background:var(--surface);border:1px solid var(--line);overflow-x:auto}
.tabela{width:100%;border-collapse:collapse;font-size:13px}
.tabela thead th{
    background:var(--surface-soft);border-bottom:1.5px solid var(--gold);
    padding:10px 14px;text-align:left;font-weight:700;font-size:11.5px;
    letter-spacing:1.2px;text-transform:uppercase;color:var(--ink);
}
.tabela tbody td{padding:9px 14px;border-bottom:0.5px solid var(--line-soft);vertical-align:middle;color:var(--ink)}

/* Valor monetario: R$ a esquerda, numero a direita, com gap garantido.
   Usa inline-flex + min-width para que o gap se mantenha mesmo quando o
   conteudo da celula equivale a largura maxima da coluna (caso do tfoot). */
.brl{
    display:inline-flex;align-items:baseline;justify-content:space-between;
    gap:1.2em;min-width:9.5ch;font-variant-numeric:tabular-nums
}
.brl-sym{color:var(--gold-dark);font-weight:600;font-variant-numeric:normal}
.tabela tbody tr:nth-child(even){background:var(--surface-soft)}
.tabela tbody tr:hover{background:#F0E7C8}
.tabela .acoes{display:flex;gap:6px;justify-content:flex-end}
.tabela tfoot td{padding:9px 14px;font-weight:500;background:var(--row-alt);border-top:2px solid var(--gold);vertical-align:middle}

.badge{display:inline-block;padding:2px 8px;font-size:11px;letter-spacing:0.5px;background:var(--surface-soft);border:0.5px solid var(--line);color:var(--ink-soft)}
.badge.protegido{background:var(--ink);color:var(--gold-soft);border-color:var(--ink)}
.badge.ativo{background:#E7F0DA;color:var(--ok);border-color:var(--ok-soft)}
.badge.inativo{background:#EEE;color:#777;border-color:#CCC}
.badge.corretiva{background:#FBEAEA;color:var(--danger);border-color:var(--danger-soft)}
.badge.preventiva{background:#FBEEDB;color:var(--gold-dark);border-color:var(--gold)}

/* ============================================================
   DASHBOARD
   ============================================================ */
.dash-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:18px;flex-wrap:wrap;gap:14px}
.dash-head .dash-title{font-family:var(--font-display);font-size:30px;font-weight:500;color:var(--ink);line-height:1}
.dash-head .dash-sub{font-size:11px;color:var(--muted);letter-spacing:0.4px;margin-top:4px}
.dash-meta{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:1.5px;border-left:2px solid var(--gold);padding:2px 0 2px 10px}
.dash-meta b{color:var(--ink);display:block;font-weight:500}
.dash-nav{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.dash-nav .btn{padding:6px 12px;font-size:12px}
.dash-nav-form{display:flex;gap:6px;margin:0}
.dash-nav-form select{background:var(--surface);border:0.5px solid var(--line);color:var(--ink);padding:5px 10px;font-size:12px;font-family:inherit;cursor:pointer}
.dash-nav-form select:focus{outline:none;border-color:var(--gold)}

.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin-bottom:22px}
.kpi{background:var(--surface);border:0.5px solid var(--line);border-top:2px solid var(--gold);padding:14px 18px}
.kpi.kpi-danger{border-top-color:var(--danger)}
.kpi-lbl{font-size:11.5px;letter-spacing:1.2px;text-transform:uppercase;color:var(--muted);font-weight:700}
.kpi-num{font-family:var(--font-display);font-size:34px;font-weight:500;color:var(--ink);line-height:1.05;margin-top:4px}
.kpi.kpi-danger .kpi-num{color:var(--danger)}
.kpi-foot{font-size:11px;color:var(--ink-mute);margin-top:2px}

.dash-section{background:var(--surface);border:0.5px solid var(--line);padding:18px 22px;margin-bottom:18px}
.dash-section h3{font-family:var(--font-display);font-size:20px;border-bottom:1px solid var(--line-soft);padding-bottom:8px;margin-bottom:12px}

.bar-chart{display:flex;align-items:flex-end;gap:3px;height:140px;padding:8px 0;border-bottom:1px solid var(--line-soft)}
.bar-chart .bar{flex:1;background:var(--ink-soft);position:relative;min-height:2px;transition:background .2s}
.bar-chart .bar.weekend{background:var(--line)}
.bar-chart .bar.holiday{background:var(--gold-soft)}
.bar-chart .bar.today{background:var(--gold);border-bottom:2px solid var(--gold-dark)}
.bar-chart .bar:hover{background:var(--ink)}
.bar-chart .bar:hover::after{
    content:attr(data-label);position:absolute;bottom:100%;left:50%;transform:translateX(-50%);
    background:var(--ink);color:var(--surface);padding:4px 8px;font-size:11px;white-space:nowrap;
}
.bar-axis{display:flex;justify-content:space-between;font-size:10px;color:var(--muted);letter-spacing:1px;margin-top:4px}

/* ============================================================
   LOGIN (auth-body)
   ============================================================ */
body.auth-body{background:var(--bg);min-height:100vh;display:flex;align-items:center;justify-content:center;padding:30px 20px}

.auth-wrap{
    display:grid;grid-template-columns:1.2fr 1fr;gap:0;width:100%;max-width:980px;
    background:var(--surface);border:1px solid var(--line);box-shadow:0 14px 40px rgba(26,42,71,.10);
}

.auth-brand{
    background:var(--ink);color:var(--surface);padding:48px 44px;
    display:flex;flex-direction:column;justify-content:flex-start;position:relative;
}
.auth-brand-eyebrow{font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--gold-soft);margin-bottom:24px}
.auth-brand-mark{color:var(--gold-soft);margin-bottom:14px}
.auth-bigname{font-family:var(--font-display);font-size:68px;font-weight:500;margin:0 0 4px;color:var(--surface);letter-spacing:0.5px;line-height:1}
.auth-gold-rule{width:48px;height:3px;background:var(--gold);margin:14px 0 18px}
.auth-tagline{font-size:14px;line-height:1.7;color:#D2D7E0;max-width:330px;margin:0 0 36px}

.auth-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:auto 0 0;border-top:1px solid #2F3F5C;padding-top:18px}
.auth-meta dt{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--gold-soft);margin-bottom:6px}
.auth-meta dd{font-family:var(--font-display);font-size:28px;font-weight:500;margin:0;color:var(--surface)}

.auth-card{padding:48px 44px;display:flex;flex-direction:column;background:var(--surface)}
.auth-card-eyebrow{display:flex;justify-content:space-between;font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:18px}
.auth-card-title{font-family:var(--font-display);font-size:34px;font-weight:500;margin:0;color:var(--ink)}
.auth-card-sub{font-size:13px;color:var(--ink-mute);margin:4px 0 26px}

.auth-error{
    background:#FBEAEA;border-left:3px solid var(--danger);color:#5A1818;
    padding:10px 14px;font-size:13px;margin-bottom:18px;
}

.auth-form .auth-field{margin-bottom:18px}
.auth-form label{display:block;font-size:11px;letter-spacing:1.2px;text-transform:uppercase;color:var(--muted);margin-bottom:6px;font-weight:500}
.auth-form input{
    width:100%;padding:11px 14px;border:1px solid var(--line);background:#FFF;color:var(--ink);
    font-size:15px;font-family:var(--font-body);border-radius:0;letter-spacing:0.5px;box-sizing:border-box;
}
.auth-form input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 2px rgba(184,155,64,.2)}

.auth-leds{display:flex;gap:6px;margin-top:8px}
.auth-led{width:24px;height:6px;background:var(--line);transition:background .15s}
.auth-led.on{background:var(--gold)}

.auth-submit{
    width:100%;margin-top:8px;background:var(--ink);color:var(--surface);
    padding:13px 0;border:none;font-family:var(--font-body);font-size:14px;letter-spacing:1.5px;
    text-transform:uppercase;cursor:pointer;transition:background .15s;
}
.auth-submit:hover{background:var(--ink-soft)}

.auth-foot{display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;margin-top:auto;padding-top:24px;font-size:11px;color:var(--muted);letter-spacing:0.5px;border-top:1px solid var(--line-soft)}

/* ============================================================
   MOVIMENTO - Grid estilo planilha
   ============================================================ */
.mov-filtros{background:var(--surface);border:1px solid var(--line);border-top:3px solid var(--gold);padding:18px 22px;margin-bottom:18px}
.mov-filtros-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;align-items:end}

.mov-header{background:var(--surface);border:0.5px solid var(--line);border-bottom:none;padding:12px 18px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;font-size:12px;color:var(--ink-soft)}
.mov-header .mov-fn{font-family:var(--font-display);font-size:18px;color:var(--ink);font-weight:500}
.mov-header .mov-help{font-size:11px;color:var(--muted);letter-spacing:0.5px}

.mov-grid-wrap{background:var(--surface);border:0.5px solid var(--line);overflow-x:auto}
.mov-grid{width:100%;border-collapse:collapse;font-size:13px;font-variant-numeric:tabular-nums}
.mov-grid thead th{
    background:var(--surface-soft);border-bottom:1.5px solid var(--gold);
    padding:8px 10px;text-align:center;font-size:11.5px;letter-spacing:1.2px;text-transform:uppercase;
    color:var(--ink);font-weight:700;position:sticky;top:0;
}
.mov-grid tbody td{padding:0;border-bottom:0.5px solid var(--line-soft);text-align:center}
.mov-grid tbody tr:nth-child(even) td{background:var(--surface-soft)}
.mov-grid tbody tr.weekend td{background:#EEE5C5;color:var(--danger)}
.mov-grid tbody tr.holiday td{background:#F2E3B0;color:var(--danger)}
.mov-grid tbody tr.dirty td{background:#FFF5E0}
.mov-grid tbody tr.saved td{background:#EEF6E2}
.mov-grid tbody tr.error td{background:#FBEAEA}

.mov-grid td.dia{font-weight:500;color:var(--ink);padding:6px 8px}
.mov-grid td.sem{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:1px}
.mov-grid td.calc{font-weight:500;color:var(--ink-soft);padding:6px 8px}

.mov-grid input, .mov-grid select{
    width:100%;border:none;background:transparent;padding:8px 8px;font-size:13px;
    font-family:var(--font-body);font-variant-numeric:tabular-nums;text-align:center;
    color:var(--ink);border-radius:0;
}
.mov-grid input:focus, .mov-grid select:focus{outline:2px solid var(--gold);background:#FFF}
/* DSR/FOLGA/FERIADO: classificacao em vermelho */
.mov-grid tbody tr.weekend select,
.mov-grid tbody tr.holiday select{color:var(--danger);font-weight:500}

/* Entrada/Saida estilo badge:
   - amarelo quando vazio (placeholder visivel)
   - verde quando preenchido
   - neutro/oculto quando o dia esta desabilitado (DSR/FOLGA/FERIADO/FALTA) */
.mov-grid input[data-campo="hora_entrada"],
.mov-grid input[data-campo="hora_saida"]{
    width:auto;display:inline-block;min-width:62px;
    padding:3px 10px;margin:3px auto;
    border-radius:4px;border:0.5px solid var(--gold);
    background:#FBEEDB;color:var(--gold-dark);font-weight:500;letter-spacing:0.5px
}
.mov-grid input[data-campo="hora_entrada"]:not(:placeholder-shown),
.mov-grid input[data-campo="hora_saida"]:not(:placeholder-shown){
    background:#E7F0DA;color:var(--ok);border-color:var(--ok-soft)
}
.mov-grid input[data-campo="hora_entrada"]:disabled,
.mov-grid input[data-campo="hora_saida"]:disabled{
    background:transparent;color:var(--muted);border-color:transparent;font-weight:normal
}
.mov-grid input[data-campo="hora_entrada"]::placeholder,
.mov-grid input[data-campo="hora_saida"]::placeholder{
    color:var(--gold-dark);opacity:0.75
}
/* Saida apos meia-noite (HH>=24): destaque azulado + asterisco depois,
   para o conferente bater o olho e ver que aquele turno "virou o dia". */
.mov-grid input[data-campo="hora_saida"].saida-proxdia{
    background:#DEE9F0;color:#2A4D6E;border-color:#7A9EBF
}
.mov-grid td:has(input.saida-proxdia)::after{
    content:"+1d";display:inline-block;margin-left:4px;
    font-size:9px;color:#2A4D6E;font-weight:500;letter-spacing:0.5px;
    vertical-align:middle
}
.mov-grid input[type="time"]::-webkit-calendar-picker-indicator{display:none}
.mov-grid input.obs{text-align:left;padding-left:10px}

.mov-bar{background:var(--surface-soft);border:0.5px solid var(--line);border-top:none;padding:12px 18px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;font-size:12px}
.mov-totais{display:flex;gap:18px;font-family:var(--font-body)}
.mov-totais b{font-family:var(--font-display);font-size:18px;color:var(--ink);font-weight:500;margin-left:6px}

/* ============================================================
   DBCFG (config conexao)
   ============================================================ */
.dbcfg-wrap{display:grid;grid-template-columns:2fr 1fr;gap:18px}
.dbcfg-card{background:var(--surface);border:0.5px solid var(--line);border-top:3px solid var(--gold);padding:18px 22px;margin-bottom:14px}
.dbcfg-card-head{display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--line-soft);padding-bottom:10px;margin-bottom:12px}
.dbcfg-card-head h3{margin:0;flex:1;font-family:var(--font-display);font-size:18px}
.dbcfg-card-head .code{font-size:10px;letter-spacing:1.5px;color:var(--muted)}
.led-dot{width:8px;height:8px;border-radius:50%;display:inline-block}
.dbcfg-warn{background:#FBEEDB;border-left:3px solid var(--gold);padding:10px 14px;font-size:12px;margin-bottom:14px;display:flex;gap:8px}
.dbcfg-passwrap{display:flex;gap:6px}
.dbcfg-passwrap input{flex:1}
.dbcfg-eye{padding:0 12px;background:var(--surface-soft);border:1px solid var(--line);cursor:pointer}
.dbcfg-table{width:100%;font-size:12px;border-collapse:collapse}
.dbcfg-table th{text-align:left;padding:6px 0;color:var(--muted);font-size:10px;letter-spacing:1.2px;text-transform:uppercase;font-weight:500}
.dbcfg-table td{padding:6px 0;color:var(--ink);font-family:'Courier New',monospace}
.dbcfg-presets-list{display:flex;flex-direction:column;gap:8px}
.dbcfg-preset{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--surface-soft);border:0.5px solid var(--line);text-align:left;cursor:pointer;width:100%;font-family:var(--font-body)}
.dbcfg-preset:hover{background:var(--row-alt);border-color:var(--gold)}
.dbcfg-preset-ico{font-size:18px}
.dbcfg-preset b{display:block;font-size:13px}
.dbcfg-preset span{display:block;font-size:11px;color:var(--muted);font-family:'Courier New',monospace}

/* ============================================================
   IMPRESSAO
   ============================================================ */
@media print {
    .sidebar, .topbar, .acao-bar, .form-actions, .btn { display:none !important; }
    body, .conteudo, .conteudo-inner { background:#FFF; color:#000; padding:0 !important; }
    .tabela tbody tr:nth-child(even), .tabela tbody tr:hover { background:transparent !important; }
    .form-box, .dash-section, .tabela-box { border:1px solid #000; box-shadow:none; }
}

/* ============================================================
   RESPONSIVO
   ============================================================ */
@media (max-width: 900px) {
    .auth-wrap{grid-template-columns:1fr;max-width:480px}
    .auth-brand{padding:28px}
    .auth-bigname{font-size:48px}
    .auth-meta{margin-top:24px}
    .dbcfg-wrap{grid-template-columns:1fr}
}

@media (max-width: 768px) {
    .sidebar{
        position:fixed;left:-260px;top:0;height:100vh;z-index:200;
        transition:left .2s ease;box-shadow:4px 0 16px rgba(0,0,0,.1);
    }
    .sidebar.open{left:0}
    .sidebar-overlay{display:block;position:fixed;inset:0;background:rgba(26,42,71,.4);z-index:150;opacity:0;pointer-events:none;transition:opacity .2s}
    .sidebar-overlay.on{opacity:1;pointer-events:auto}
    .menu-toggle{display:flex}
    .topbar{padding:12px 18px}
    .topbar h1{font-size:18px}
    .user-info .user-name, .user-info .user-perfil{display:none}
    .conteudo-inner{padding:18px 14px 40px}
    .form-grid{grid-template-columns:1fr}
    .kpi-grid{grid-template-columns:1fr 1fr}
    .mov-filtros-grid{grid-template-columns:1fr}
}
