:root{--bg:#f6f8fb;--card:#fff;--text:#0f172a;--muted:#64748b;--line:#e2e8f0;--primary:#0f172a;--primary2:#1d4ed8;--danger:#dc2626;--warn:#f59e0b;--success:#16a34a;--shadow:0 16px 40px rgba(15,23,42,.08);--radius:22px}*{box-sizing:border-box}body{margin:0;background:var(--bg);font-family:Inter,Segoe UI,Arial,sans-serif;color:var(--text)}button,input,select,textarea{font:inherit}label{display:block;font-size:13px;font-weight:700;color:#334155;margin-bottom:7px}.hidden{display:none!important}.muted{color:var(--muted)}.auth-screen{min-height:100vh;display:grid;place-items:center;padding:18px}.auth-card{width:min(430px,100%);background:var(--card);border:1px solid var(--line);border-radius:28px;box-shadow:var(--shadow);padding:30px}.logo{display:block;max-width:190px;max-height:82px;object-fit:contain;margin:0 auto 12px}.auth-card h1{margin:0;text-align:center;font-size:28px}.auth-card p{text-align:center;margin:8px 0 24px}.auth-card input{width:100%;margin-bottom:14px}.hint{margin-top:14px;font-size:13px;color:var(--muted);text-align:center}.app{padding:18px;max-width:1500px;margin:0 auto}.topbar{display:flex;justify-content:space-between;gap:16px;align-items:center;margin-bottom:16px}.topbar h1{margin:0;font-size:28px}.top-actions,.actions,.detail-actions,.modal-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}.toolbar{display:flex;justify-content:space-between;gap:14px;padding:16px;margin-bottom:16px}.filters{display:flex;gap:12px;align-items:end;flex-wrap:wrap}.filters label{margin-bottom:6px}.filters select,.filters input{min-width:120px}.admin-filter select{min-width:160px}.layout{display:grid;grid-template-columns:370px 1fr;gap:16px}.partes-panel,.detail-panel{padding:16px;min-height:620px}.section-title{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:14px}.section-title h2,.section-title h3{margin:0}.section-title.compact{margin:18px 0 10px}.pill{display:inline-flex;align-items:center;justify-content:center;background:#eef2ff;color:#3730a3;border-radius:999px;padding:6px 10px;font-weight:800;font-size:12px}.btn{border:1px solid var(--line);background:#fff;color:var(--text);border-radius:14px;padding:10px 14px;font-weight:800;cursor:pointer;transition:.15s}.btn:hover{transform:translateY(-1px);box-shadow:0 10px 24px rgba(15,23,42,.08)}.btn.primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn.success{background:var(--success);border-color:var(--success);color:#fff}.btn.warn{background:var(--warn);border-color:var(--warn);color:#111827}.btn.danger{background:var(--danger);border-color:var(--danger);color:#fff}.btn.danger-light{background:#fff1f2;border-color:#fecdd3;color:#be123c}.btn.full{width:100%;justify-content:center}input,select,textarea{border:1px solid var(--line);border-radius:14px;padding:11px 12px;background:#fff;color:var(--text);outline:none}input:focus,select:focus,textarea:focus{border-color:#2563eb;box-shadow:0 0 0 4px rgba(37,99,235,.11)}.partes-list{display:flex;flex-direction:column;gap:10px}.parte-item{border:1px solid var(--line);border-radius:18px;padding:14px;cursor:pointer;background:#fff;transition:.15s}.parte-item:hover,.parte-item.active{border-color:#1d4ed8;box-shadow:0 12px 28px rgba(29,78,216,.10)}.parte-item .row{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}.estado{font-size:12px;border-radius:999px;padding:5px 9px;font-weight:900}.estado.open{background:#dcfce7;color:#166534}.estado.closed{background:#fee2e2;color:#991b1b}.empty{height:100%;display:grid;place-content:center;text-align:center;color:var(--muted);padding:30px}.detail-head{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;border-bottom:1px solid var(--line);padding-bottom:14px;margin-bottom:14px}.detail-head h2{margin:0}.notice{border:1px solid #fed7aa;background:#fff7ed;color:#9a3412;border-radius:16px;padding:12px 14px;font-weight:800;margin-bottom:14px}.lineas-list{display:flex;flex-direction:column;gap:12px}.linea-card{border:1px solid var(--line);border-radius:20px;padding:14px;background:#fff}.linea-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:10px}.linea-head h3{margin:0;font-size:18px}.linea-actions{display:flex;gap:8px;flex-wrap:wrap}.mini-btn{border:1px solid var(--line);background:#fff;border-radius:12px;padding:7px 10px;font-size:13px;font-weight:800;cursor:pointer}.mini-btn.danger{border-color:#fecaca;color:#b91c1c}.employee-table{width:100%;border-collapse:collapse;margin-top:10px;overflow:hidden;border-radius:14px}.employee-table th,.employee-table td{border-bottom:1px solid var(--line);padding:10px;text-align:left;font-size:14px}.employee-table th{background:#f8fafc;color:#334155}.employee-table tr:last-child td{border-bottom:0}.modal-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.48);display:none;align-items:center;justify-content:center;padding:18px;z-index:50}.modal-backdrop.show{display:flex}.modal{width:min(560px,100%);max-height:92vh;overflow:auto;background:#fff;border-radius:26px;padding:20px;box-shadow:0 30px 80px rgba(0,0,0,.25)}.modal.wide{width:min(940px,100%)}.modal-head{display:flex;justify-content:space-between;gap:14px;align-items:center;border-bottom:1px solid var(--line);padding-bottom:12px;margin-bottom:16px}.modal-head h2{margin:0}.icon-btn{width:38px;height:38px;border:1px solid var(--line);border-radius:50%;background:#fff;font-size:24px;cursor:pointer}.form-grid,.form-row{display:grid;gap:14px}.form-row{grid-template-columns:190px 1fr}.combo-wrap{position:relative}.combo-menu{position:absolute;left:0;right:0;top:72px;max-height:260px;overflow:auto;background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);z-index:80}.combo-item,.combo-empty{padding:11px 12px;cursor:pointer}.combo-item:hover{background:#eff6ff}.employee-picker{display:grid;grid-template-columns:1fr;gap:8px}.employee-results{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px;max-height:130px;overflow:auto}.emp-chip{border:1px solid var(--line);background:#f8fafc;border-radius:999px;padding:8px 11px;font-weight:800;cursor:pointer}.emp-chip:hover{background:#e0f2fe}.selected-employees{display:grid;gap:10px}.selected-emp{display:grid;grid-template-columns:1.3fr 140px 1.5fr auto;gap:10px;align-items:start;border:1px solid var(--line);border-radius:18px;padding:12px;background:#fbfdff}.selected-emp strong{padding-top:11px}.selected-emp .remove{border:0;background:#fee2e2;color:#991b1b;border-radius:12px;padding:10px;cursor:pointer;font-weight:900}.msg{border-radius:14px;padding:11px 12px;background:#fee2e2;color:#991b1b;font-weight:800;margin-top:12px}.msg.success{background:#dcfce7;color:#166534}@media(max-width:920px){.topbar,.toolbar,.detail-head{flex-direction:column;align-items:stretch}.layout{grid-template-columns:1fr}.partes-panel,.detail-panel{min-height:auto}.form-row{grid-template-columns:1fr}.selected-emp{grid-template-columns:1fr}.top-actions,.actions,.detail-actions{width:100%}.btn{width:100%}.modal{padding:16px}.app{padding:10px}.toolbar{padding:12px}}
.top-right{display:flex;align-items:center;justify-content:flex-end;gap:16px;flex-wrap:wrap}.top-logo{height:54px;max-width:190px;object-fit:contain;border-radius:10px}.sidebar-lines{margin-top:12px;border-top:1px solid var(--line);padding-top:10px;display:grid;gap:8px}.sidebar-line{width:100%;border:1px solid var(--line);background:#f8fafc;border-radius:14px;padding:10px 11px;text-align:left;cursor:pointer;transition:.15s}.sidebar-line:hover,.sidebar-line.active{background:#eff6ff;border-color:#2563eb;box-shadow:0 8px 18px rgba(37,99,235,.10)}.sidebar-line-date{display:block;font-size:12px;font-weight:900;color:#1d4ed8;margin-bottom:3px}.sidebar-line-obra{display:block;font-size:13px;font-weight:800;line-height:1.25;color:var(--text)}.sidebar-empty-line{border:1px dashed var(--line);border-radius:14px;padding:10px;color:var(--muted);font-size:13px;font-weight:700}.linea-card-selected{border-color:#cbd5e1;background:linear-gradient(180deg,#fff,#fbfdff)}.small-label{font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px}@media(max-width:920px){.top-right{justify-content:stretch}.top-logo{margin:auto}.top-actions{justify-content:stretch}}
