:root{
    --bg:#0b1220;
    --bg2:#0f172a;
    --panel:#111827;
    --panel2:#162033;
    --text:#e5e7eb;
    --muted:#94a3b8;
    --line:#253146;
    --pri:#38bdf8;
    --ok:#22c55e;
    --bad:#ef4444;
    --warn:#f59e0b;
    --input:#0b1220;
}

:root[data-theme="light"]{
    --bg:#f3f6fb;
    --bg2:#ffffff;
    --panel:#ffffff;
    --panel2:#eef4fb;
    --text:#0f172a;
    --muted:#64748b;
    --line:#d7dee9;
    --pri:#0284c7;
    --ok:#16a34a;
    --bad:#dc2626;
    --warn:#d97706;
    --input:#ffffff;
}

*{box-sizing:border-box}
html{min-height:100%}
body{
    margin:0;
    min-height:100%;
    background:linear-gradient(135deg,var(--bg),var(--bg2));
    color:var(--text);
    font-family:Inter,Segoe UI,Arial,sans-serif;
    font-size:13px;
    line-height:1.38;
}
a{color:inherit;text-decoration:none}

.app{display:flex;min-height:100vh}
.sidebar{
    width:218px;
    min-width:218px;
    background:rgba(17,24,39,.92);
    border-right:1px solid var(--line);
    padding:16px 13px;
    position:sticky;
    top:0;
    height:100vh;
    overflow:auto;
}
:root[data-theme="light"] .sidebar{background:rgba(255,255,255,.94)}

.brand{display:flex;flex-direction:column;gap:2px;margin-bottom:12px}
.brand strong{font-size:17px;line-height:1.12}
.brand span,.muted{color:var(--muted)}

.nav{display:grid;gap:6px}
.nav a,.btn,.theme-toggle{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:7px;
    border:1px solid var(--line);
    background:var(--panel2);
    padding:8px 10px;
    min-height:35px;
    border-radius:11px;
    color:var(--text);
    font-weight:700;
    font-size:12px;
    cursor:pointer;
}
.btn-sm{min-height:29px;padding:5px 8px;font-size:11px;border-radius:9px}
.nav a.active,.btn-primary{background:linear-gradient(135deg,#0284c7,#0ea5e9);border-color:#38bdf8;color:#fff}
.danger,.btn-danger{background:#7f1d1d!important;border-color:#ef4444!important;color:#fff!important}

.content{
    flex:1;
    width:calc(100% - 218px);
    max-width:1160px;
    margin:0 auto;
    padding:18px 22px;
}
.topbar{
    display:flex;
    justify-content:space-between;
    gap:14px;
    align-items:flex-start;
    margin-bottom:14px;
}
.topbar h1{font-size:22px;line-height:1.12;margin:0 0 7px}
.topbar p{margin:0}

.grid{display:grid;gap:10px}
.cards{grid-template-columns:repeat(4,minmax(120px,1fr))}
.card,.panel{
    background:rgba(17,24,39,.84);
    border:1px solid var(--line);
    border-radius:16px;
    padding:12px;
    box-shadow:0 8px 24px rgba(0,0,0,.13);
}
:root[data-theme="light"] .card,:root[data-theme="light"] .panel{background:rgba(255,255,255,.92)}
.card small{color:var(--muted);font-size:11px}
.card strong{display:block;font-size:20px;margin-top:4px;line-height:1.15}
.panel h3{margin:0 0 8px;font-size:15px}

.table-wrap{width:100%;overflow-x:auto}
.table{width:100%;border-collapse:collapse;font-size:12px}
.table th,.table td{padding:7px 8px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}
.table th{color:var(--muted);font-size:11px}

.form{display:grid;gap:9px}
.form.two{grid-template-columns:repeat(2,1fr)}
label{display:grid;gap:5px;color:var(--muted);font-weight:700;font-size:12px}
input,select,textarea{
    width:100%;
    border:1px solid var(--line);
    border-radius:11px;
    background:var(--input);
    color:var(--text);
    padding:8px 10px;
    min-height:35px;
    font-size:12px;
}
textarea{min-height:82px;resize:vertical}
.actions{display:flex;gap:7px;flex-wrap:wrap;justify-content:flex-end;align-items:center}
.actions input,.actions select{min-width:210px;max-width:360px}

.alert{padding:9px 11px;border-radius:11px;margin:9px 0;border:1px solid var(--line);font-size:12px}
.alert-sucesso{background:#052e1a;border-color:#16a34a}
.alert-erro{background:#3b0a0a;border-color:#ef4444}
.alert-info{background:#082f49;border-color:#0ea5e9}

.side-users{margin-top:12px;border-top:1px solid var(--line);padding-top:10px}
.side-users h4{color:var(--muted);margin:0 0 7px;font-size:12px}
.side-users a{display:block;padding:8px;border:1px solid var(--line);border-radius:11px;margin-bottom:7px;background:var(--input)}
.side-users a span{font-weight:800;display:block;margin-bottom:2px;font-size:12px}
.side-users small{display:block;color:var(--muted);font-size:10px;line-height:1.3}

.auth{min-height:100vh;display:grid;place-items:center;padding:20px}
.auth-card{width:min(400px,100%);background:var(--panel);border:1px solid var(--line);border-radius:20px;padding:24px}
.bars{display:grid;gap:8px}
.bar{background:var(--input);border-radius:999px;overflow:hidden;border:1px solid var(--line)}
.bar span{display:block;height:10px;background:linear-gradient(90deg,#38bdf8,#22c55e)}
.print-only{display:none}.kpi-good{color:var(--ok)}.kpi-bad{color:var(--bad)}
.mini-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:9px}
.logo-print{max-height:56px;max-width:150px;object-fit:contain}
.assinatura-print{max-height:66px;max-width:210px;object-fit:contain}
.pill{display:inline-flex;padding:3px 7px;border:1px solid var(--line);border-radius:999px;color:var(--muted);font-size:11px}

.theme-icon-toggle{
    position:fixed;
    top:12px;
    right:12px;
    z-index:9999;
    width:34px;
    height:34px;
    border-radius:999px;
    border:1px solid var(--line);
    background:var(--panel);
    color:var(--text);
    display:inline-flex;
    align-items:center;
    justify-content:center;
    font-size:16px;
    cursor:pointer;
    box-shadow:0 7px 18px rgba(0,0,0,.20);
    transition:transform .15s ease, box-shadow .15s ease;
}
.theme-icon-toggle:hover{transform:translateY(-1px);box-shadow:0 10px 24px rgba(0,0,0,.25)}

@media(max-width:1280px){
    .content{max-width:none;padding:16px 18px}
    .cards{grid-template-columns:repeat(4,minmax(110px,1fr))}
    .card strong{font-size:19px}
}
@media(max-width:1100px){
    .sidebar{width:205px;min-width:205px;padding:14px 11px}
    .content{width:calc(100% - 205px);padding:14px}
    .topbar{flex-direction:column}
    .actions{width:100%;justify-content:flex-start;padding-right:42px}
    .actions input,.actions select{min-width:170px;flex:1}
}
@media(max-width:900px){
    .app{display:block}
    .sidebar{position:relative;width:auto;min-width:0;height:auto}
    .content{width:100%;padding:12px}
    .cards,.form.two,.mini-grid{grid-template-columns:1fr}
    .topbar{display:block}
    .table{font-size:11px}
    .theme-icon-toggle{top:9px;right:9px;width:32px;height:32px}
}
@media print{
    .sidebar,.topbar .actions,.no-print,.btn,.theme-toggle,.theme-icon-toggle{display:none!important}
    body{background:#fff!important;color:#111!important}
    .content{padding:0!important;max-width:none!important}
    .panel,.card{box-shadow:none!important;background:#fff!important;color:#111!important;border-color:#ccc!important}
    .print-only{display:block!important}
}


/* ===== Módulo funcionários / folha ===== */
.funcionario-grid{
    grid-template-columns:1.15fr .85fr;
    margin-top:14px;
}

.mt{margin-top:14px}

.calendar{
    display:grid;
    grid-template-columns:repeat(7,1fr);
    gap:6px;
}

.cal-head{
    text-align:center;
    color:var(--muted);
    font-weight:800;
    font-size:11px;
    padding:4px 0;
}

.cal-empty,
.cal-day{
    min-height:48px;
    border:1px solid var(--line);
    border-radius:10px;
    background:var(--input);
    padding:6px;
}

.cal-day strong{
    display:block;
    font-size:13px;
}

.cal-day small{
    display:block;
    margin-top:4px;
    font-size:10px;
    color:var(--muted);
}

.cal-day.presenca{
    background:rgba(34,197,94,.16);
    border-color:rgba(34,197,94,.55);
}

.cal-day.falta{
    background:rgba(239,68,68,.16);
    border-color:rgba(239,68,68,.55);
}

.folha-print-title{
    text-align:center;
    margin-bottom:10px;
}

.folha-print-title h2{
    margin:0;
    font-size:18px;
}

.folha-print-title p{
    margin:3px 0 0;
    color:#4b5563;
}

.side-add{
    border-style:dashed!important;
}

@media(max-width:1100px){
    .funcionario-grid{
        grid-template-columns:1fr;
    }
}

@media print{
    @page{size:A4 portrait;margin:7mm}
    body{font-size:11px!important}
    .folha-table{font-size:10px!important}
    .folha-table th,.folha-table td{padding:4px!important}
    .cards{grid-template-columns:repeat(4,1fr)!important}
    .card{padding:7px!important}
    .card strong{font-size:15px!important}
}

/* Multi-seleção do calendário de funcionários */
.cal-day{
    width:100%;
    text-align:left;
    color:var(--text);
    cursor:pointer;
    transition:transform .12s ease, border-color .12s ease, background .12s ease, box-shadow .12s ease;
}
.cal-day:hover{
    transform:translateY(-1px);
    border-color:rgba(56,189,248,.55);
    box-shadow:0 6px 16px rgba(0,0,0,.16);
}
.cal-day.selecionado{
    background:rgba(14,165,233,.22)!important;
    border-color:#38bdf8!important;
    box-shadow:0 0 0 2px rgba(56,189,248,.22), 0 8px 22px rgba(14,165,233,.20)!important;
}
.cal-day.selecionado small::after{
    content:" • selecionado";
    color:#38bdf8;
}
.selection-info{
    border:1px dashed var(--line);
    border-radius:12px;
    background:rgba(56,189,248,.06);
    padding:9px 10px;
}
.selection-info strong{display:block;margin-bottom:2px}
