:root{--bg:#e9e9e2;--bg-card:#fff;--bg-soft:#f4f2ea;--bg-dark:#132435;--ink:#132435;--ink-soft:#5a6470;--ink-faint:#9aa0a8;--line:#ddd9ce;--line-strong:#cbd1dd;--accent:#c78538;--accent-soft:#f1e0cc;--beige:#d0b48f;--beige-soft:#ede0cc;--olive:#8c8135;--olive-soft:#dedbc2;--green:#5a7045;--green-soft:#dee5d4;--amber:#c78538;--amber-soft:#f1e0cc;--red:#b94a3b;--red-soft:#f3d4cf;--shadow-sm:0 1px 2px rgba(19,36,53,.04);--shadow:0 4px 16px rgba(19,36,53,.08);--shadow-lg:0 12px 32px rgba(19,36,53,.12);--r-sm:8px;--r:14px;--r-lg:22px;--display:"Instrument Serif","Times New Roman",Georgia,serif;--body:"Barlow Semi Condensed",-apple-system,sans-serif}*{box-sizing:border-box;margin:0;padding:0}body,html{height:100%}body{font-family:var(--body);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;line-height:1.5;overflow-x:hidden}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}input,select,textarea{font-family:inherit;font-size:inherit}a{color:inherit}.splash{position:fixed;inset:0;display:grid;place-items:center;background:var(--bg);z-index:200;transition:opacity .3s}.splash.hidden{opacity:0;pointer-events:none}.splash-mark{width:60px;height:60px;background:var(--ink);border-radius:50%;display:grid;place-items:center;color:var(--bg);font-family:var(--display);font-style:italic;font-size:28px;letter-spacing:-.04em;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.85}}.toast{position:fixed;bottom:calc(80px + env(safe-area-inset-bottom));left:50%;transform:translateX(-50%);background:var(--ink);color:var(--bg);padding:12px 20px;border-radius:99px;font-size:14px;font-weight:500;z-index:150;box-shadow:var(--shadow-lg);opacity:0;transition:opacity .2s;pointer-events:none;max-width:90vw;text-align:center}.toast.show{opacity:1}.toast.error{background:var(--red)}.toast.success{background:var(--green)}.login-screen{min-height:100vh;min-height:100dvh;display:grid;place-items:center;padding:24px;background:radial-gradient(ellipse at 15% 20%,hsla(34,41%,69%,.5) 0,transparent 50%),radial-gradient(ellipse at 85% 80%,rgba(199,133,56,.18) 0,transparent 55%),radial-gradient(ellipse at 50% 100%,rgba(203,209,221,.4) 0,transparent 55%),var(--bg)}.login-card{width:100%;max-width:420px;background:var(--bg-card);border-radius:var(--r-lg);padding:44px 36px;box-shadow:var(--shadow-lg);border:1px solid var(--line)}.login-brand{display:flex;align-items:center;gap:12px;margin-bottom:32px}.login-mark{width:44px;height:44px;background:var(--ink);border-radius:50%;display:grid;place-items:center;color:var(--bg);font-family:var(--display);font-style:italic;font-size:22px;letter-spacing:-.04em}.login-brand-text{font-size:11px;color:var(--ink-soft);letter-spacing:.18em;text-transform:uppercase;font-weight:500}.login-title{font-family:var(--display);font-size:38px;line-height:1.05;margin-bottom:8px;color:var(--ink)}.login-title em{font-style:italic}.login-sub{color:var(--ink-soft);font-size:15px;margin-bottom:28px;line-height:1.5}.login-error{background:var(--red-soft);color:var(--red);padding:10px 12px;border-radius:var(--r-sm);font-size:13px;border:1px solid #e0b0a8}.field,.login-error{margin-bottom:16px}.field label{display:block;font-size:11px;font-weight:600;color:var(--ink-soft);margin-bottom:6px;letter-spacing:.08em;text-transform:uppercase}.input{width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:var(--r-sm);background:var(--bg-card);font-size:15px;color:var(--ink);transition:border-color .15s,box-shadow .15s}.input:focus{outline:none;border-color:var(--ink);box-shadow:0 0 0 3px rgba(19,36,53,.06)}.btn{width:100%;padding:13px 16px;border-radius:var(--r-sm);font-weight:600;font-size:15px;transition:transform .08s,background .15s,opacity .15s;display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn:active{transform:scale(.98)}.btn-primary{background:var(--ink);color:var(--bg)}.btn-primary:hover{background:#0a1726}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-ghost{background:transparent;border:1.5px solid var(--line-strong)}.btn-ghost:hover{background:var(--bg)}.btn-accent{background:var(--accent);color:#fff}.btn-danger{background:var(--red);color:#fff}.btn-sm{padding:8px 12px;font-size:13px;width:auto}.app{min-height:100vh;min-height:100dvh}.topbar{position:-webkit-sticky;position:sticky;top:0;z-index:50;background:hsla(60,14%,90%,.85);backdrop-filter:saturate(180%) blur(14px);-webkit-backdrop-filter:saturate(180%) blur(14px);border-bottom:1px solid var(--line);padding:14px 20px;justify-content:space-between;gap:12px}.topbar,.topbar-left{display:flex;align-items:center}.topbar-left{gap:10px;min-width:0}.topbar-mark{width:36px;height:36px;background:var(--ink);border-radius:50%;display:grid;place-items:center;color:var(--bg);font-family:var(--display);font-style:italic;font-size:18px;letter-spacing:-.04em;flex-shrink:0}.topbar-name{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar-role{font-size:10px;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.08em;font-weight:500}.topbar-actions{display:flex;gap:8px}.icon-btn{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;background:var(--bg-card);border:1px solid var(--line);transition:background .15s}.icon-btn:hover{background:var(--bg)}.icon-btn svg{width:18px;height:18px;stroke:var(--ink)}.container{max-width:1100px;margin:0 auto;padding:24px 20px 100px}@media (min-width:768px){.container{padding:32px 32px 100px}}.tabs{position:fixed;bottom:0;left:0;right:0;background:hsla(0,0%,100%,.92);backdrop-filter:saturate(180%) blur(14px);-webkit-backdrop-filter:saturate(180%) blur(14px);border-top:1px solid var(--line);padding:6px 4px calc(6px + env(safe-area-inset-bottom));z-index:40}.tab,.tabs{display:flex}.tab{flex:1 1;flex-direction:column;align-items:center;gap:2px;padding:8px 4px;color:var(--ink-faint);font-size:10px;font-weight:500;letter-spacing:.03em;border-radius:10px;transition:color .15s}.tab svg{width:22px;height:22px;stroke:currentColor;stroke-width:1.8;fill:none}.tab.active{color:var(--ink)}.tab.active svg{stroke-width:2.2}.hero{background:var(--ink);color:var(--bg);border-radius:var(--r-lg);padding:32px 28px;margin-bottom:24px;position:relative;overflow:hidden}.hero:before{content:"";position:absolute;top:-60%;right:-20%;width:70%;height:220%;background:radial-gradient(ellipse,rgba(199,133,56,.22) 0,transparent 60%);pointer-events:none}.hero-greet{font-size:11px;opacity:.65;letter-spacing:.18em;text-transform:uppercase;font-weight:500}.hero-name{font-size:34px;margin:6px 0 20px}.hero-name,.hero-time{font-family:var(--display);line-height:1}.hero-time{font-size:64px;letter-spacing:-.02em;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;margin-bottom:6px}.hero-date{font-size:13px;opacity:.7;margin-bottom:24px;text-transform:capitalize;letter-spacing:.02em}.clock-status{background:hsla(0,0%,100%,.08);border:1px solid hsla(0,0%,100%,.12);border-radius:var(--r);padding:14px 16px;margin-bottom:16px;display:flex;align-items:center;gap:12px}.status-dot{width:10px;height:10px;border-radius:50%;background:#888;flex-shrink:0}.status-dot.working{background:#4ade80;box-shadow:0 0 12px rgba(74,222,128,.6);animation:pulse-dot 2s infinite}.status-dot.paused{background:var(--amber)}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.5}}.status-text{flex:1 1;font-size:14px}.status-text strong{display:block;font-weight:600}.status-text span{opacity:.7;font-size:12px;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.clock-actions{display:grid;grid-template-columns:1fr 1fr;grid-gap:10px;gap:10px}.clock-btn{padding:14px;border-radius:var(--r);font-weight:600;font-size:14px;transition:transform .08s,background .15s,opacity .15s;display:flex;align-items:center;justify-content:center;gap:8px}.clock-btn:active{transform:scale(.97)}.clock-btn.start{background:#4ade80;color:#0a2e1a}.clock-btn.pause{background:var(--amber);color:#4a3410}.clock-btn.resume{background:#4ade80;color:#0a2e1a}.clock-btn.stop{background:var(--accent);color:#fff}.clock-btn:disabled{opacity:.3;cursor:not-allowed;background:hsla(0,0%,100%,.08);color:hsla(0,0%,100%,.4)}.clock-btn svg{width:16px;height:16px}.section{margin-bottom:28px}.section-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:14px;gap:12px}.section-title{font-family:var(--display);font-size:26px;line-height:1}.section-link{font-size:12px;color:var(--ink-soft);text-decoration:underline;-webkit-text-decoration-color:var(--line-strong);text-decoration-color:var(--line-strong);text-underline-offset:3px;text-transform:uppercase;letter-spacing:.08em;font-weight:500;cursor:pointer;background:none;border:none}.card{background:var(--bg-card);border-radius:var(--r);border:1px solid var(--line);padding:16px;box-shadow:var(--shadow-sm)}.week-grid{display:grid;grid-gap:8px;gap:8px}.day-row{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--r);padding:14px 16px;display:grid;grid-template-columns:60px 1fr auto;align-items:center;grid-gap:14px;gap:14px}.day-row.today{border-color:var(--ink);box-shadow:0 0 0 1px var(--ink)}.day-row.libre{background:#faf8f3;opacity:.8}.day-num{font-family:var(--display);font-size:32px;line-height:1;letter-spacing:-.02em}.day-name{font-size:10px;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.1em;font-weight:500;margin-top:2px}.day-shift{font-weight:500;font-size:14px;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.day-shift small{color:var(--ink-faint);display:block;font-size:11px;font-feature-settings:normal;font-variant-numeric:normal;margin-top:2px}.day-libre{color:var(--ink-faint);font-style:italic;font-size:13px}.day-hours{font-family:var(--display);font-size:20px;color:var(--ink-soft)}.task-list{display:grid;grid-gap:10px;gap:10px}.task{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--r);padding:14px 16px;display:flex;gap:12px;align-items:flex-start;transition:opacity .2s}.task.done{opacity:.55}.task.done .task-title{text-decoration:line-through}.task-check{width:22px;height:22px;border:2px solid var(--line-strong);border-radius:6px;flex-shrink:0;margin-top:1px;display:grid;place-items:center;transition:all .15s;cursor:pointer}.task-check:hover{border-color:var(--ink)}.task.done .task-check{background:var(--green);border-color:var(--green)}.task-check svg{width:14px;height:14px;stroke:#fff;stroke-width:3;fill:none;opacity:0;transition:opacity .15s}.task.done .task-check svg{opacity:1}.task-body{flex:1 1;min-width:0}.task-title{font-weight:600;font-size:15px;margin-bottom:4px}.task-meta{display:flex;gap:10px;flex-wrap:wrap;font-size:12px;color:var(--ink-faint)}.task-tag{display:inline-block;padding:2px 8px;border-radius:99px;font-size:11px;font-weight:500;background:var(--bg);border:1px solid var(--line)}.task-tag.urgent{background:var(--accent-soft);color:var(--accent);border-color:#e8c5bc}.task-tag.normal{background:var(--green-soft);color:var(--green);border-color:#c2d4c5}.payroll-list{display:grid;grid-gap:10px;gap:10px}.payroll{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--r);padding:14px 16px;display:flex;align-items:center;gap:14px}.payroll-icon{width:42px;height:42px;border-radius:10px;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;flex-shrink:0}.payroll-icon svg{width:20px;height:20px;stroke:currentColor;stroke-width:1.8;fill:none}.payroll-body{flex:1 1;min-width:0}.payroll-title{font-weight:600;font-size:15px;text-transform:capitalize}.payroll-meta{font-size:12px;color:var(--ink-faint)}.news{display:grid;grid-gap:10px;gap:10px}.notice{background:var(--bg-card);border-radius:var(--r);padding:16px;border:1px solid var(--line);border-left:3px solid var(--ink)}.notice.pinned{border-left-color:var(--accent);background:linear-gradient(to right,var(--accent-soft) 0,var(--bg-card) 8%)}.notice-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px;gap:8px}.notice-title{font-weight:600;font-size:15px}.notice-date{font-size:11px;color:var(--ink-faint);white-space:nowrap;text-transform:uppercase;letter-spacing:.04em}.notice-body{font-size:14px;color:var(--ink-soft);line-height:1.55;white-space:pre-wrap}.notice-author{margin-top:8px;font-size:11px;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.04em}.admin-grid{display:grid;grid-gap:16px;gap:16px}@media (min-width:700px){.admin-grid{grid-template-columns:1fr 1fr}}.admin-card{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--r);padding:18px}.admin-card h3{font-family:var(--display);font-size:22px;margin-bottom:14px}.stat-row{display:flex;justify-content:space-between;padding:6px 0;font-size:14px;border-bottom:1px dashed var(--line)}.stat-row:last-child{border:0}.stat-row strong{font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.emp-row{padding:10px 12px;border-radius:var(--r-sm);background:var(--bg);margin-bottom:6px;display:flex;justify-content:space-between;align-items:center;font-size:14px;gap:8px}.emp-status{font-size:11px;font-weight:600;padding:2px 8px;border-radius:99px;text-transform:uppercase;letter-spacing:.04em}.emp-status.working{background:var(--green-soft);color:var(--green)}.emp-status.paused{background:var(--amber-soft);color:#8a6920}.emp-status.off{background:var(--bg);color:var(--ink-faint);border:1px solid var(--line)}.modal-bg{position:fixed;inset:0;background:rgba(19,36,53,.4);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:100;display:flex;align-items:flex-end;justify-content:center;padding:0}@media (min-width:700px){.modal-bg{align-items:center;padding:24px}}.modal{background:var(--bg-card);border-radius:var(--r-lg) var(--r-lg) 0 0;width:100%;max-width:560px;max-height:92vh;overflow-y:auto;padding:24px 22px calc(24px + env(safe-area-inset-bottom))}@media (min-width:700px){.modal{border-radius:var(--r-lg)}}.modal-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:20px}.modal-title{font-family:var(--display);font-size:26px}.modal-close{width:32px;height:32px;border-radius:8px;background:var(--bg);display:grid;place-items:center;font-size:20px;color:var(--ink-soft)}.form-grid{display:grid;grid-gap:12px;gap:12px}@media (min-width:500px){.form-grid.cols-2{grid-template-columns:1fr 1fr}}textarea.input{resize:vertical;min-height:80px;font-family:inherit}.empty{text-align:center;padding:40px 20px;color:var(--ink-faint);font-size:14px}.empty-icon{font-size:32px;margin-bottom:8px;opacity:.4}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}.view{animation:fadeIn .25s}.row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.grow{flex:1 1}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-20{margin-top:20px}.text-soft{color:var(--ink-soft)}.text-faint{color:var(--ink-faint)}.small{font-size:13px}.chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:99px;background:var(--bg);border:1px solid var(--line);font-size:12px;font-weight:500}.must-change-banner{background:var(--accent-soft);border:1px solid #e8c5bc;border-radius:var(--r);padding:14px 16px;margin-bottom:16px;color:#6b3a1f;font-size:14px;display:flex;gap:12px;align-items:center}.must-change-banner button{margin-left:auto;padding:6px 12px;background:var(--accent);color:#fff;border-radius:var(--r-sm);font-weight:600;font-size:13px;border:none;cursor:pointer}