*{margin:0;padding:0;box-sizing:border-box}:root{font-family:Trebuchet MS,Gill Sans,Segoe UI,sans-serif;line-height:1.5;font-weight:400;--bg: #f3f1ea;--panel: #fffef9;--brand: #134873;--accent: #c16f2f;--text: #15202b;--muted: #5d6873;--border: #d8d2c5}body{margin:0;min-height:100vh;background:radial-gradient(circle at 0% 0%,#f8e4cb 0%,transparent 35%),radial-gradient(circle at 100% 100%,#d9e8f4 0%,transparent 35%),var(--bg)}#app{width:100%;min-height:100vh}.app-shell{padding:24px}.top-nav{max-width:1440px;margin:0 auto 12px;display:flex;justify-content:flex-end}.nav-link{text-decoration:none;color:#fff;background:linear-gradient(120deg,var(--accent),#a2531c);padding:8px 14px;border-radius:999px;font-size:.9rem;font-weight:700}.nav-link:hover{filter:brightness(1.06)}.marcador-shell .panel{max-width:520px;margin:0 auto}.panel-shell .panel{max-width:1440px;margin:0 auto}.split-layout{max-width:1440px;margin:0 auto;display:grid;grid-template-columns:360px 1fr;gap:20px}.panel{background:var(--panel);border:1px solid var(--border);border-radius:18px;padding:24px;box-shadow:0 14px 32px #121d2e14}.marcador-panel{display:flex;flex-direction:column;align-items:center;gap:18px;justify-content:center;min-height:calc(100vh - 48px)}.logo{max-width:280px;width:100%;height:auto;object-fit:contain}h1,h2{font-size:2rem;font-weight:700;color:var(--text);text-align:center}h3{margin:16px 0 10px;color:var(--text)}.subtitle{color:var(--muted);font-size:.95rem;text-align:center}.dni-input{width:300px;padding:1rem 1.5rem;font-size:1.5rem;border:2px solid var(--border);border-radius:10px;text-align:center;transition:border-color .3s ease;outline:none;background:#fff}.dni-input:focus{border-color:var(--brand)}.submit-btn{width:100%;max-width:300px;padding:1rem 2rem;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(120deg,var(--brand),#1b648f);border:none;border-radius:10px;cursor:pointer;transition:transform .2s ease,filter .2s ease}.submit-btn:hover{filter:brightness(1.05)}.submit-btn:active{transform:scale(.98)}.secondary-btn{background:#fff;color:var(--brand);border:1px solid var(--brand);border-radius:10px;height:42px;align-self:end;cursor:pointer;font-weight:600}.reporte-panel{animation:riseIn .5s ease}.panel-actions{display:flex;justify-content:flex-end;margin-bottom:10px}.filters-grid{display:grid;grid-template-columns:1.2fr 180px 1.2fr 1fr 1fr 140px 160px;gap:10px;align-items:end}.alta-empleado-box{border:1px dashed var(--border);border-radius:12px;padding:12px;margin-bottom:12px;background:#fffaf2}.alta-grid{display:grid;grid-template-columns:1fr 1fr 1fr 140px;gap:10px;align-items:end}label{display:flex;flex-direction:column;gap:4px;font-size:.9rem;color:var(--muted)}.check-label{flex-direction:row;align-items:center;gap:8px;font-size:.92rem;font-weight:600;color:var(--text);align-self:end;height:42px}.check-label input[type=checkbox]{width:16px;height:16px}input,select{height:42px;border:1px solid var(--border);border-radius:10px;padding:0 12px;background:#fff;color:var(--text)}input:focus,select:focus{outline:none;border-color:var(--brand)}.panel-estado{margin-top:12px;margin-bottom:12px;padding:10px 12px;border-radius:10px;background:#edf4fa;color:#1d3f5a}.panel-estado.error{background:#fdeceb;color:#7f1d1d}.trabajando-box{margin-bottom:18px;padding:14px;border:1px solid var(--border);border-radius:14px;background:linear-gradient(180deg,#fffaf2,#fff)}.trabajando-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px}.small-note{color:var(--muted);font-size:.88rem}.trabajando-resumen{margin-bottom:12px;font-weight:700;color:var(--brand)}.trabajando-lista{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.metricas-box{margin-bottom:18px;padding:16px;border:1px solid var(--border);border-radius:14px;background:linear-gradient(135deg,#1348730f,#c16f2f14),#fff}.metricas-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.metrica-card{padding:14px;border-radius:14px;background:#ffffffe6;border:1px solid #d9e5ef;box-shadow:inset 0 1px #ffffffd9}.metrica-label{display:block;color:var(--muted);font-size:.88rem;margin-bottom:6px}.metrica-value{display:block;color:var(--brand);font-size:1.7rem;line-height:1}.trabajando-card{border:1px solid #d9e5ef;border-radius:12px;padding:12px;background:#f8fbfd}.trabajando-card-name{font-weight:700;color:var(--text);margin-bottom:4px}.trabajando-card-dni,.trabajando-card-meta,.trabajando-empty{color:var(--muted);font-size:.9rem}.table-wrap{overflow-x:auto;margin-bottom:14px}table{width:100%;border-collapse:collapse;background:#fff}th,td{padding:10px 12px;border-bottom:1px solid #e7e2d8;text-align:left;font-size:.94rem}th{background:#f4f7fa;color:var(--brand);font-weight:700}tbody tr:nth-child(2n){background:#fcfbf8}.modal-backdrop{position:fixed;inset:0;background:#10192373;display:flex;align-items:center;justify-content:center;z-index:1200;padding:18px}.modal-backdrop.hidden{display:none}.modal-card{width:min(920px,100%);max-height:85vh;background:#fffef9;border:1px solid var(--border);border-radius:14px;box-shadow:0 20px 45px #0003;display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid #ebe7df}.icon-btn{border:1px solid var(--border);background:#fff;color:var(--text);width:34px;height:34px;border-radius:8px;cursor:pointer;font-weight:700}.modal-table-wrap{border:0;border-radius:0 0 14px 14px}.modal-action-btn{height:36px;min-width:96px}.badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:.82rem;font-weight:700}.badge-activo{color:#1f6d3c;background:#e8f7ee;border:1px solid #bce9cc}.badge-inactivo{color:#7f1d1d;background:#fdeceb;border:1px solid #f5c4c4}.table-wrap{width:100%;overflow:auto;border:1px solid var(--border);border-radius:10px;background:#fff}table{width:100%;border-collapse:collapse;min-width:760px}th,td{text-align:left;padding:10px 12px;border-bottom:1px solid #ebe7df;font-size:.92rem}th{background:#f6f3ec;color:#39424a;position:sticky;top:0}.toast-container{position:fixed;top:20px;right:20px;z-index:1000;display:flex;flex-direction:column;gap:10px}.toast{display:flex;align-items:center;gap:12px;padding:16px 20px;border-radius:10px;box-shadow:0 4px 12px #00000026;min-width:300px;max-width:400px;opacity:0;transform:translate(400px);transition:all .3s ease}.toast-show{opacity:1;transform:translate(0)}.toast-success{border-color:#2f7b4f;background-color:#fff;color:#2f7b4f}.toast-error{border-color:#9b2c2c;background-color:#fff;color:#9b2c2c}.toast-icon{font-size:1.5rem;font-weight:700;flex-shrink:0}.toast-message{flex:1;font-size:.95rem;line-height:1.4}.welcome-message{font-size:2.2rem;font-weight:700;color:var(--brand);text-align:center;animation:fadeInScale .5s ease}@keyframes riseIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.login-shell .panel{max-width:420px;margin:0 auto}.login-panel{display:flex;flex-direction:column;align-items:center;gap:20px;justify-content:center;min-height:calc(100vh - 48px)}.login-form{width:100%;display:flex;flex-direction:column;gap:16px}.login-form label{display:flex;flex-direction:column;gap:6px;font-size:.95rem;color:var(--text);font-weight:500}.login-form input{height:44px;border:1px solid var(--border);border-radius:10px;padding:0 14px;background:#fff;color:var(--text);font-size:1rem}.login-form input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px #1348731a}.login-error{padding:12px 16px;border-radius:10px;background:#fdeceb;color:#7f1d1d;border:1px solid #fbc9c9;font-size:.95rem}@media(max-width:768px){.login-panel{min-height:auto}.logo{max-width:220px}h1{font-size:1.6rem}}@media(max-width:768px){.app-shell{padding:12px}.split-layout{grid-template-columns:1fr}.marcador-panel{min-height:auto}.logo{max-width:220px}h1{font-size:1.6rem}h2{font-size:1.5rem}.welcome-message{font-size:2.2rem}.filters-grid,.alta-grid{grid-template-columns:1fr}.secondary-btn,.submit-btn{max-width:none}.dni-input{width:100%;font-size:1.2rem}}@media(max-width:480px){.welcome-message{font-size:1.8rem}.dni-input{font-size:1rem;padding:.8rem 1rem}.toast-container{top:10px;right:10px;left:10px}.toast{min-width:auto;max-width:100%}}
