:root{
  --bg:#f7f9fb;
  --card:#ffffff;
  --line:#d8d8d8;
  --text:#111;
  --blue:#eaf6fb;
  --orange:#fff7ed;
  --yellow:#fffde7;
  --green:#eaffea;
  --red:#ffeaea;
  --gray:#f5f5f5;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);font-family:'Segoe UI',Arial,sans-serif;color:var(--text)}
.hidden{display:none!important}
.login{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}
.login-card{background:#fff;width:min(430px,100%);padding:24px;border-radius:14px;box-shadow:0 3px 12px rgba(0,0,0,.08);border:1px solid var(--line)}
.login-card h1{margin:0 0 6px;font-size:28px}
.login-card p{margin:0 0 18px;color:#555}
.alert{background:#fff3cd;border:1px solid #e5c46b;border-radius:8px;padding:10px;margin:12px 0;font-size:13px}
.field{display:flex;flex-direction:column;gap:5px;min-width:130px;flex:1}
.field label{font-weight:700;font-size:13px}
.field input,.field select{height:38px;border:1px solid #aaa;border-radius:7px;padding:7px 10px;font-size:15px;background:#fff}
.btn{height:38px;border:1px solid #aaa;border-radius:7px;padding:0 14px;font-weight:700;cursor:pointer;background:#222;color:#fff}
.btn.alt{background:#fff;color:#111}
.btn.danger{background:#7b2630;color:#fff}
.btn.blue{background:#2b7c95;color:#fff}
.btn.soft{background:#f4f4f4;color:#111}
.btn:disabled{opacity:.55;cursor:not-allowed}
.app{max-width:1340px;margin:0 auto;padding:14px}
.topbar{display:flex;justify-content:space-between;gap:12px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:12px 12px 0 0;padding:10px 14px;font-weight:700}
.dev{font-size:13px;font-weight:400}
.panel{background:#fff;border:1px solid var(--line);border-top:0;border-radius:0 0 12px 12px;padding:12px;margin-bottom:12px;box-shadow:0 2px 6px rgba(0,0,0,.04)}
.toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:end}
.rules{display:grid;grid-template-columns:repeat(4,minmax(160px,1fr));gap:10px;margin-top:10px}
.status{margin-left:auto;font-size:12px;font-weight:700;color:#333}
.sheet-wrap{background:#fff;border:1px solid var(--line);padding:14px;overflow:auto;box-shadow:0 2px 6px rgba(0,0,0,.04)}
.sheet-area{display:flex;flex-direction:column;align-items:center;gap:22px;width:max-content;margin:0 auto}
.main-table{border-collapse:collapse;table-layout:fixed;width:980px;font-size:12px;font-weight:700}
.main-table td,.main-table th{border:1px solid var(--line);height:26px;padding:5px 7px;text-align:center;white-space:nowrap;vertical-align:middle}
.w-dia{width:60px}.w-hora{width:135px}.w-trab{width:135px}.w-saldo{width:125px}
.top{background:var(--orange)}
.empresa{color:#2b5d7c;font-weight:900}
.jornada{background:var(--blue);font-size:15px}
.subheader{background:var(--orange);font-size:15px}
.cols{background:var(--yellow)}
.sabado{background:var(--blue)}
.domingo,.bloqueado{background:var(--gray)}
.saldo-neg{background:var(--red)}
.saldo-pos{background:var(--green)}
.saldo-zero{background:#fff}
input.time{width:100%;border:0;background:transparent;text-align:center;font:inherit;font-weight:400;outline:none}
.summary{display:flex;flex-direction:row;justify-content:center;gap:20px;width:100%;margin-top:10px}
.box{width:220px;border:1px solid var(--line);text-align:center;font-weight:800;background:#fff;box-shadow:0 2px 6px rgba(0,0,0,.04)}
.box-title{height:34px;display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--line)}
.box-val{height:36px;display:flex;align-items:center;justify-content:center;font-size:18px}
.credit .box-title,.credit .box-val{background:var(--green)}
.debit .box-title,.debit .box-val{background:var(--red)}
.bank .box-title,.bank .box-val{background:#fffbe8}
.small{font-size:11px;color:#444}
.danger-text{color:#a00000;font-weight:700}
.modal{position:fixed;inset:0;background:#0007;display:grid;place-items:center;padding:20px;z-index:10}
.modal-card{background:#fff;width:min(980px,100%);max-height:90vh;overflow:auto;border-radius:14px;padding:18px;border:1px solid #ccc}
.modal-card textarea{width:100%;min-height:260px;font-family:monospace;font-size:12px}
.report{background:#fff;padding:22px}
.report-table{width:100%;border-collapse:collapse;margin-top:12px;font-size:12px}
.report-table th,.report-table td{border:1px solid #ccc;padding:6px;text-align:center}
.signatures{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-top:44px}
.signature-line{border-top:1px solid #111;padding-top:8px;text-align:center;font-weight:700;min-height:44px}
@media (max-width:760px){
  .topbar{align-items:flex-start;flex-direction:column}
  .rules{grid-template-columns:1fr}
  .summary{align-items:center;flex-direction:column}
}
@media print{
  @page{size:A4 portrait;margin:8mm}
  body{background:#fff}
  .app{padding:0;max-width:none}
  .topbar,.panel,.no-print{display:none!important}
  .sheet-wrap{border:0;padding:0;overflow:visible;box-shadow:none}
  .sheet-area{transform:scale(.76);transform-origin:top left;margin:0}
  .report{display:block!important}
  *{-webkit-print-color-adjust:exact;print-color-adjust:exact}
}
