:root{--green:#1B4332;--green2:#143229;--green3:#27503f;--gold:#C9A84C;--gold-d:#a8893a;--ink:#1c2420;--muted:#6b7470;--paper:#f6f4ee;--line:#e9e3d6;--red:#b5443a;}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
body{font-family:Inter,system-ui,sans-serif;color:var(--ink);background:var(--paper);min-height:100vh}
input,textarea,button{font-family:inherit}

/* LOGIN */
.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(160deg,var(--green),var(--green3));padding:24px}
.login-card{background:#fff;border-radius:22px;padding:34px 26px;width:100%;max-width:360px;box-shadow:0 20px 50px rgba(0,0,0,.25);text-align:center}
.logo{font-family:Fraunces,serif;font-size:34px;font-weight:600;color:var(--green)}
.logo-sub{font-size:13px;color:var(--muted);letter-spacing:.5px;text-transform:uppercase;margin-bottom:24px}
.login-card input{width:100%;border:1.5px solid var(--line);border-radius:13px;padding:15px;font-size:17px;margin-bottom:12px;outline:none;text-align:center}
.login-card input:focus{border-color:var(--gold)}
.login-card button{width:100%;border:none;background:var(--green);color:#fff;padding:16px;border-radius:13px;font-size:17px;font-weight:700;cursor:pointer}
.err{color:var(--red);font-size:13px;margin-top:12px;min-height:16px}

/* APP FUNCIONÁRIO */
.topbar{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;background:var(--green);color:#fff}
.hi{font-weight:700;font-size:16px}.setor{font-size:12px;opacity:.8;margin-top:2px}
.logout{background:rgba(255,255,255,.15);color:#fff;border:none;padding:8px 14px;border-radius:9px;font-size:13px;font-weight:600;cursor:pointer}
.clock-wrap{text-align:center;padding:30px 20px 18px}
.clock{font-family:Fraunces,serif;font-size:64px;font-weight:600;color:var(--green);line-height:1}
.cdate{font-size:14px;color:var(--muted);margin-top:6px;text-transform:capitalize}
.worked{font-size:14px;color:var(--gold-d);font-weight:600;margin-top:10px;min-height:18px}
.punch-btn{display:block;width:calc(100% - 36px);margin:8px 18px;border:none;border-radius:20px;background:linear-gradient(135deg,var(--gold),var(--gold-d));color:#1c2420;font-size:21px;font-weight:700;padding:26px;cursor:pointer;box-shadow:0 10px 24px rgba(201,168,76,.35);transition:.15s}
.punch-btn:active{transform:scale(.98)}
.punch-btn.done{background:#e3f0e8;color:#1f6e45;box-shadow:none}
.punch-btn b{font-weight:800}
.punch-hint{text-align:center;font-size:12.5px;color:var(--muted);padding:8px 24px 0;line-height:1.4}
.today{margin:24px 18px 0;background:#fff;border:1px solid var(--line);border-radius:16px;padding:16px}
.today-h{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);margin-bottom:10px}
.today-list{display:flex;flex-direction:column;gap:2px}
.treg{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid #f3efe6}
.treg:last-child{border-bottom:none}
.tr-dot{width:10px;height:10px;border-radius:50%;flex:0 0 auto}
.tr-dot.entrada{background:#1f6e45}.tr-dot.saida_almoco{background:var(--gold)}.tr-dot.volta_almoco{background:#2a8fd6}.tr-dot.saida{background:var(--red)}
.tr-l{flex:1;font-size:14.5px}.tr-h{font-weight:700;font-size:15px}
.tr-empty{color:var(--muted);font-size:13.5px;font-style:italic;text-align:center;padding:6px}
.just-link{display:block;margin:18px auto 30px;background:none;border:none;color:var(--muted);font-size:13.5px;text-decoration:underline;cursor:pointer}

.overlay{position:fixed;inset:0;background:rgba(20,30,25,.55);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:#fff;font-size:16px;z-index:60}
.spin{width:44px;height:44px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:sp 1s linear infinite}
@keyframes sp{to{transform:rotate(360deg)}}
.success{position:fixed;inset:0;background:rgba(27,67,50,.96);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;color:#fff;z-index:70;animation:fade .2s}
@keyframes fade{from{opacity:0}}
.sok{width:90px;height:90px;border-radius:50%;background:var(--gold);color:var(--green);display:flex;align-items:center;justify-content:center;font-size:50px;font-weight:800}
.stxt{font-size:18px;font-weight:600;text-align:center;padding:0 30px}

/* MODAIS */
.modal-bg{display:none;position:fixed;inset:0;background:rgba(20,30,25,.5);align-items:center;justify-content:center;padding:18px;z-index:80}
.modal-bg.show{display:flex}
.modal{background:#fff;border-radius:18px;padding:22px;width:100%;max-width:420px;max-height:90vh;overflow-y:auto}
.modal-h{font-family:Fraunces,serif;font-size:20px;font-weight:600;margin-bottom:14px}
.modal label{display:block;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;color:var(--muted);margin:10px 0 5px}
.modal input,.modal textarea{width:100%;border:1.5px solid var(--line);border-radius:11px;padding:12px;font-size:15px;outline:none}
.modal input:focus,.modal textarea:focus{border-color:var(--gold)}
.modal .ck{display:flex;align-items:center;gap:8px;text-transform:none;font-size:14px;color:var(--ink);margin-top:12px}
.modal .ck input{width:18px;height:18px}
.modal-acts{display:flex;gap:10px;justify-content:flex-end;margin-top:18px}
.modal-acts button{border:none;background:var(--green);color:#fff;padding:11px 18px;border-radius:11px;font-size:15px;font-weight:600;cursor:pointer}
.modal-acts .ghost{background:#eee;color:var(--muted)}
.fmap{margin-top:12px;font-size:14px}.fmap a{color:var(--green);font-weight:600}

/* ADMIN */
.admin-body{background:var(--paper);max-width:760px;margin:0 auto}
.tabs{display:flex;background:#fff;border-bottom:1px solid var(--line);overflow-x:auto;position:sticky;top:0;z-index:5}
.tab{flex:1;border:none;background:none;padding:14px 10px;font-size:13.5px;font-weight:600;color:var(--muted);border-bottom:2.5px solid transparent;cursor:pointer;white-space:nowrap}
.tab.active{color:var(--green);border-bottom-color:var(--gold)}
.badge{background:var(--red);color:#fff;font-size:10.5px;padding:1px 6px;border-radius:9px;margin-left:3px}
.pane{padding:16px}
.kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:16px}
.kpi{background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px;text-align:center}
.kpi b{display:block;font-family:Fraunces,serif;font-size:26px;color:var(--green)}
.kpi span{font-size:11px;color:var(--muted)}
.frow{background:#fff;border:1px solid var(--line);border-radius:14px;padding:13px 15px;margin-bottom:10px}
.frow.off{opacity:.55}
.fr-top{display:flex;justify-content:space-between;align-items:center}
.fr-name{font-weight:700;font-size:15px;display:flex;align-items:center;gap:6px}
.dot-in{width:9px;height:9px;border-radius:50%;background:#1f6e45;display:inline-block}
.fr-h{font-weight:700;color:var(--green)}
.fr-sub{font-size:12.5px;color:var(--muted);margin-top:4px}
.fr-bat{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-top:10px}
.bchip{font-size:12px;text-align:center;padding:6px 4px;border-radius:8px;background:#f1ece1;color:var(--muted);font-weight:600}
.bchip.on{background:#e3f0e8;color:#1f6e45}
.fr-bat2{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.bpill{font-size:12px;border:1px solid var(--line);background:#fbfaf6;border-radius:8px;padding:5px 9px;cursor:pointer}
.bpill:hover{border-color:var(--gold)}
.rep-h,.today-h{font-size:12px;font-weight:700;text-transform:uppercase;color:var(--muted);margin-bottom:10px}
.st{font-size:11px;font-weight:700;padding:2px 9px;border-radius:8px;text-transform:uppercase}
.st-pendente{background:#fbf0d8;color:#9a7b1e}.st-aprovado{background:#e3f0e8;color:#1f6e45}.st-rejeitado{background:#f7e2df;color:var(--red)}
.jacts{display:flex;gap:8px;margin-top:10px}
.jacts button{flex:1;border:none;border-radius:9px;padding:9px;font-weight:600;font-size:13.5px;cursor:pointer}
.jacts .ok{background:var(--green);color:#fff}.jacts .no{background:#f7e2df;color:var(--red)}
.add-btn{width:100%;border:1.5px dashed var(--gold);background:#fff;color:var(--gold-d);padding:13px;border-radius:13px;font-size:14.5px;font-weight:600;margin-bottom:14px;cursor:pointer}
.edit{background:none;border:1px solid var(--line);color:var(--muted);font-size:12px;padding:4px 10px;border-radius:8px;cursor:pointer}
.edit.rosto{border-color:var(--gold);color:var(--gold-d)}
.rosto-ok{font-size:11px;background:#e3f0e8;color:#1f6e45;padding:1px 8px;border-radius:7px;font-weight:600}
.kiosk-link{background:var(--gold);color:#1c2420;text-decoration:none;font-size:13px;font-weight:700;padding:8px 13px;border-radius:9px}
.rosto-stage{border-radius:14px;overflow:hidden;background:#000;aspect-ratio:4/3}
.rosto-stage video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}
.rosto-msg{text-align:center;font-size:13.5px;color:var(--muted);margin-top:12px}

/* QUIOSQUE */
.kiosk-body{background:linear-gradient(160deg,var(--green2),var(--green3));min-height:100vh;color:#fff;display:flex;flex-direction:column;align-items:center;overflow:hidden}
.kiosk-head{width:100%;display:flex;justify-content:space-between;align-items:center;padding:18px 24px}
.logo-k{font-family:Fraunces,serif;font-size:24px;font-weight:600;color:var(--gold)}
.clock-k{font-family:Fraunces,serif;font-size:28px;font-weight:600}
.kiosk-stage{position:relative;width:min(78vw,420px);aspect-ratio:1;margin-top:10px}
.kiosk-stage video{width:100%;height:100%;object-fit:cover;border-radius:50%;transform:scaleX(-1);border:5px solid rgba(255,255,255,.15)}
.face-ring{position:absolute;inset:-6px;border-radius:50%;border:5px solid transparent;transition:.3s}
.face-ring.on{border-color:var(--gold);box-shadow:0 0 30px rgba(201,168,76,.5)}
.kiosk-msg{font-family:Fraunces,serif;font-size:30px;font-weight:600;text-align:center;margin-top:26px;padding:0 20px}
.kiosk-sub{font-size:15px;opacity:.8;margin-top:6px;text-align:center;padding:0 20px}
.k-success{position:fixed;inset:0;background:rgba(27,67,50,.97);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;z-index:80;animation:fade .25s}
.ks-av{width:120px;height:120px;border-radius:50%;background:var(--gold);color:var(--green);display:flex;align-items:center;justify-content:center;font-size:46px;font-weight:800}
.ks-name{font-family:Fraunces,serif;font-size:32px;font-weight:600}
.ks-reg{font-size:20px;color:var(--gold)}
.ks-nsr{font-size:14px;opacity:.8}
.banco-saldo{font-family:Fraunces,serif;font-size:20px;font-weight:600}
.banco-saldo.pos{color:#1f6e45}.banco-saldo.neg{color:var(--red)}
.venc{color:#9a7b1e;font-weight:600}.venc.bad{color:var(--red)}
