*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{color:#1f2937;background:#f8f9fb;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;font-size:14px}button{cursor:pointer;background:0 0;border:none;font-family:inherit;font-size:14px}input,select,textarea{font-family:inherit;font-size:14px}.layout{height:100vh;display:flex;overflow:hidden}.main{flex-direction:column;flex:1;display:flex;overflow:hidden}.sidebar{color:#fff;background:#1e293b;flex-direction:column;flex-shrink:0;align-items:center;width:64px;padding:12px 0;display:flex}.sidebar-logo{background:#4361ee;border-radius:8px;justify-content:center;align-items:center;width:40px;height:40px;margin-bottom:16px;font-size:20px;display:flex}.sidebar-nav{flex-direction:column;align-items:center;gap:4px;width:100%;display:flex}.sidebar-btn{color:#94a3b8;border-radius:8px;justify-content:center;align-items:center;width:44px;height:44px;font-size:20px;transition:all .15s;display:flex}.sidebar-btn:hover{color:#fff;background:#ffffff14}.sidebar-btn.active{color:#fff;background:#4361ee33}.sidebar-bottom{flex-direction:column;align-items:center;gap:12px;margin-top:auto;padding-bottom:8px;display:flex}.sidebar-status{color:#fff;background:#10b981;border-radius:4px;padding:4px 10px;font-size:11px;font-weight:700}.sidebar-avatar{background:#475569;border:2px solid #4361ee;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;display:flex}.toolbar{background:#fff;border-bottom:1px solid #e5e7eb;flex-shrink:0;align-items:center;gap:12px;padding:12px 24px;display:flex}.toolbar-left{align-items:center;gap:12px;display:flex}.icon-btn{color:#475569;background:#fff;border:1px solid #e5e7eb;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;transition:background .15s;display:inline-flex}.icon-btn:hover{background:#f1f5f9}.text-btn{color:#475569;border-radius:6px;padding:6px 12px;transition:background .15s}.text-btn:hover{background:#f1f5f9}.week-label{color:#1e293b;margin-left:8px;font-size:16px;font-weight:600}.toolbar-center{flex:1;justify-content:center;display:flex}.view-switcher{background:#f1f5f9;border-radius:8px;padding:3px;display:inline-flex}.view-switcher button{color:#475569;border-radius:6px;padding:6px 16px;font-weight:500;transition:all .15s}.view-switcher button.active{color:#1e293b;background:#fff;box-shadow:0 1px 2px #0000000d}.toolbar-right{align-items:center;gap:6px;display:flex}.ghost-btn{color:#1e293b;background:#fff;border:1px solid #e5e7eb;border-radius:6px;align-items:center;gap:6px;padding:7px 14px;font-weight:500;transition:background .15s;display:inline-flex}.ghost-btn:hover{background:#f1f5f9}.ghost-btn.primary-text{color:#4361ee}.primary-btn{color:#fff;background:#4361ee;border-radius:6px;align-items:center;gap:6px;padding:7px 16px;font-weight:500;transition:background .15s;display:inline-flex}.primary-btn:hover{background:#3a52d4}.schedule-grid{background:#fff;flex:1;padding:0 24px 24px;overflow:auto}.grid-row{border-bottom:1px solid #f1f5f9;grid-template-columns:220px repeat(7,minmax(140px,1fr));display:grid}.grid-cell{border-right:1px solid #f1f5f9;min-height:60px;padding:8px;position:relative}.grid-cell:last-child{border-right:none}.header-row{z-index:10;background:#fff;border-bottom:1px solid #e5e7eb;position:sticky;top:0}.corner-cell{background:#fff}.day-header{flex-direction:column;justify-content:center;align-items:center;gap:4px;min-height:auto;padding:16px 8px 12px;display:flex}.day-name{color:#64748b;font-size:13px;font-weight:500}.day-num{color:#1e293b;font-size:16px;font-weight:600}.day-num.today-pill{color:#fff;background:#4361ee;border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;font-size:13px;display:inline-flex}.notes-row .grid-cell{background:#fafbfd;min-height:38px;font-size:13px}.label-cell{color:#64748b;text-transform:lowercase;align-items:center;gap:6px;font-size:12px;font-weight:500;display:flex}.label-cell.label-insight{text-transform:uppercase;letter-spacing:.04em;justify-content:space-between;font-size:11px;font-weight:600}.insight-total{color:#1e293b;font-size:13px;font-weight:700}.note-cell{cursor:pointer;color:#475569;align-items:center;gap:4px;font-size:13px;transition:background .15s;display:flex}.note-cell:hover{background:#f1f5f9}.day-note{align-items:center;gap:4px;display:inline-flex}.dept-header{background:#fafbfd;border-bottom:1px solid #f1f5f9;align-items:center;gap:8px;padding:10px 8px 8px;display:flex}.dept-toggle{color:#64748b;font-size:11px}.dept-name{color:#475569;letter-spacing:.04em;flex:1;font-size:12px;font-weight:600}.dept-add{color:#64748b;border-radius:4px;padding:4px 8px;font-size:12px}.dept-add:hover{color:#4361ee;background:#f1f5f9}.employee-cell{background:#fff;align-items:center;gap:10px;padding:10px 8px;display:flex}.emp-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:12px;font-weight:600;display:flex}.emp-avatar.small{width:26px;height:26px;font-size:11px}.emp-info{flex:1;min-width:0}.emp-name{color:#1e293b;white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.emp-role{color:#64748b;font-size:12px}.emp-target{color:#475569;font-size:13px;font-weight:600}.open-row .open-cell{background:#fafbfd}.shift-cell{cursor:pointer;flex-direction:column;gap:4px;transition:background .1s;display:flex}.shift-cell:hover{background:#fafbfd}.shift-cell.today{background:#f0f7ff}.shift-cell.today:hover{background:#e0eeff}.cell-add{color:#cbd5e1;justify-content:center;align-items:center;font-size:18px;display:none;position:absolute;inset:0}.shift-cell:hover .cell-add{display:flex}.shift-pill{cursor:pointer;-webkit-user-select:none;user-select:none;background:#4361ee1a;border-left:3px solid #4361ee;border-radius:4px;padding:4px 8px;font-size:12px;transition:filter .15s,transform 50ms}.shift-pill:hover{filter:brightness(1.05);transform:translateY(-1px)}.shift-pill:active{transform:translateY(0)}.shift-pill.draft{opacity:.85;border-left-style:dashed}.shift-pill.conflict{outline-offset:-2px;outline:2px solid #ef4444;animation:2s infinite pulseConflict}@keyframes pulseConflict{0%,to{box-shadow:0 0 #ef444466}50%{box-shadow:0 0 0 4px #ef444400}}.pill-time{color:#1e293b;margin-bottom:1px;font-size:12px;font-weight:600}.pill-role{color:#475569;font-size:11px}.shift-pill.timeoff{color:#475569;background:repeating-linear-gradient(-45deg,#f1f5f9,#f1f5f9 4px,#e2e8f0 4px 8px);border-left:3px solid #94a3b8}.insights .label-insight{background:#fafbfd}.insight-row .grid-cell{color:#475569;align-items:center;min-height:38px;font-size:13px;display:flex}.insight-pct,.insight-cost,.insight-hours{font-weight:500}.modal-bg{z-index:1000;background:#0f172a80;justify-content:center;align-items:center;animation:.15s ease-out fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.new-shift-modal,.day-note-modal{background:#fff;border-radius:12px;flex-direction:column;gap:12px;width:380px;padding:16px;animation:.2s ease-out slideUp;display:flex;box-shadow:0 20px 50px #0f172a40}.modal-head{justify-content:space-between;align-items:center;display:flex}.modal-head h3{margin:0;font-size:15px;font-weight:600}.modal-close{color:#94a3b8;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;font-size:22px;display:flex}.modal-close:hover{color:#475569;background:#f1f5f9}.title-input{border:1px solid #e5e7eb;border-radius:6px;padding:8px 10px;font-size:14px}.title-input:focus{outline-offset:-1px;border-color:#0000;outline:2px solid #4361ee}.row-time{justify-content:space-between;align-items:center;gap:10px;display:flex}.time-pill{border:1px solid #e5e7eb;border-radius:6px;align-items:center;gap:4px;padding:4px 8px;display:inline-flex}.time-pill input{background:0 0;border:none;width:75px;font-size:13px}.time-pill input:focus{outline:none}.toggle-row{color:#475569;cursor:pointer;align-items:center;gap:8px;font-size:13px;display:flex}.toggle{background:#cbd5e1;border-radius:999px;width:36px;height:20px;transition:background .15s;position:relative}.toggle.on{background:#4361ee}.toggle-knob{background:#fff;border-radius:50%;width:16px;height:16px;transition:transform .15s;position:absolute;top:2px;left:2px;box-shadow:0 1px 2px #0003}.toggle.on .toggle-knob{transform:translate(16px)}.day-toggles{flex-wrap:wrap;gap:2px;display:inline-flex}.day-checkbox{color:#475569;cursor:pointer;border-radius:3px;align-items:center;gap:3px;padding:2px 4px;font-size:12px;display:inline-flex}.day-checkbox input{cursor:pointer;margin:0}.row-emp-color{align-items:center;gap:8px;display:flex}.emp-select{border:1px solid #e5e7eb;border-radius:6px;flex:1;padding:8px 10px;font-size:13px}.color-picker{position:relative}.color-swatch{cursor:pointer;border:1px solid #e5e7eb;border-radius:6px;width:36px;height:36px}.color-options{z-index:10;background:#fff;border:1px solid #e5e7eb;border-radius:6px;grid-template-columns:repeat(4,1fr);gap:4px;padding:6px;display:none;position:absolute;top:calc(100% + 4px);right:0;box-shadow:0 4px 12px #0000001a}.color-picker:hover .color-options{display:grid}.color-opt{cursor:pointer;border:2px solid #0000;border-radius:4px;width:22px;height:22px}.color-opt.selected{border-color:#1e293b}.notes-input{resize:vertical;border:1px solid #e5e7eb;border-radius:6px;padding:8px 10px;font-size:13px}.notes-input:focus{outline-offset:-1px;border-color:#0000;outline:2px solid #4361ee}.templates{flex-direction:column;gap:6px;display:flex}.templates-label{color:#64748b;font-size:12px;font-weight:500}.template-list{grid-template-columns:repeat(3,1fr);gap:6px;display:grid}.template-btn{text-align:left;background:#fff;border:1.5px solid #e5e7eb;border-radius:6px;flex-direction:column;gap:2px;padding:6px;font-size:11px;transition:background .15s;display:flex}.template-btn:hover{background:#f8fafc}.template-btn strong{font-size:12px}.template-btn small{color:#64748b}.modal-foot{justify-content:flex-end;gap:8px;margin-top:4px;display:flex}.modal-foot button{background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:7px 16px;font-weight:500;transition:background .15s}.modal-foot button:hover{background:#f1f5f9}.modal-foot .primary{color:#fff;background:#4361ee;border-color:#4361ee}.modal-foot .primary:hover{background:#3a52d4}.modal-foot .danger{color:#fff;background:#ef4444;border-color:#ef4444;margin-right:auto}button.danger.small{color:#c00;background:#fee;border-radius:4px;padding:4px 10px;font-size:12px}.existing-notes{background:#f8fafc;border-radius:6px;flex-direction:column;gap:4px;padding:8px;display:flex}.existing-label{color:#64748b;text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px;font-size:11px}.existing-note{background:#fff;border-radius:4px;justify-content:space-between;align-items:center;padding:4px 8px;font-size:13px;display:flex}.icon-grid{grid-template-columns:repeat(8,1fr);gap:4px;display:grid}.icon-opt{cursor:pointer;background:#fff;border:1.5px solid #e5e7eb;border-radius:6px;width:36px;height:36px;font-size:18px;transition:all .15s}.icon-opt:hover{background:#f1f5f9}.icon-opt.selected{background:#eff3ff;border-color:#4361ee}.toast{color:#fff;z-index:2000;background:#1e293b;border-radius:8px;padding:12px 20px;font-size:13px;font-weight:500;animation:.2s ease-out slideUp;position:fixed;bottom:24px;right:24px;box-shadow:0 10px 30px #0003}.toast.error{background:#ef4444}.content-pad{flex:1;padding:24px;overflow:auto}.emp-view-head{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.emp-view h2{margin:0;font-size:20px}.emp-table{border-collapse:collapse;background:#fff;border-radius:8px;width:100%;overflow:hidden;box-shadow:0 1px 3px #0000000d}.emp-table th,.emp-table td{text-align:left;border-bottom:1px solid #f1f5f9;padding:10px 16px}.emp-table th{color:#64748b;text-transform:uppercase;letter-spacing:.04em;background:#f8fafc;font-size:12px;font-weight:600}.emp-table td button{background:#fff;border:1px solid #e5e7eb;border-radius:4px;margin-right:4px;padding:4px 10px;font-size:12px}.emp-table td button:hover{background:#f1f5f9}.emp-form{background:#fff;border-left:4px solid #4361ee;border-radius:8px;margin-bottom:16px;padding:16px;box-shadow:0 1px 3px #0000000d}.emp-form h3{margin-top:0}.form-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;display:grid}.form-grid label{color:#64748b;flex-direction:column;gap:4px;font-size:12px;display:flex}.form-grid input,.form-grid select{border:1px solid #e5e7eb;border-radius:6px;padding:7px 10px}.form-actions{justify-content:flex-end;gap:8px;margin-top:12px;display:flex}.form-actions button{background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:7px 16px;font-weight:500}.form-actions .primary{color:#fff;background:#4361ee;border-color:#4361ee}.placeholder{color:#94a3b8;flex-direction:column;justify-content:center;align-items:center;display:flex}.settings-view h2{margin:0 0 20px;font-size:22px}.settings-section{background:#fff;border-radius:10px;margin-bottom:16px;padding:20px;box-shadow:0 1px 3px #0000000d}.settings-section-head{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:16px;display:flex}.settings-section h3{margin:0 0 4px;font-size:16px}.settings-hint{color:#64748b;margin:0;font-size:13px}.template-cards{flex-direction:column;gap:8px;display:flex}.template-card{background:#f8fafc;border-left:4px solid #4361ee;border-radius:6px;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;display:flex}.template-card-info{flex-direction:column;gap:2px;display:flex}.template-card-info strong{font-size:14px}.template-times{color:#475569;font-size:13px;font-weight:500}.template-id{color:#94a3b8;font-family:monospace;font-size:11px}.template-actions{gap:6px;display:flex}.template-actions button{background:#fff;border:1px solid #e5e7eb;border-radius:4px;padding:5px 10px;font-size:12px}.template-actions button:hover{background:#f1f5f9}.template-actions .danger.small{color:#c00;background:#fee;border-color:#fee}.template-form{background:#f8fafc;border-left:4px solid #4361ee;border-radius:6px;margin-bottom:12px;padding:16px}.template-form h4{margin:0 0 12px;font-size:14px}.template-form-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;display:grid}.template-form-grid label{color:#64748b;flex-direction:column;gap:4px;font-size:12px;display:flex}.template-form-grid input,.template-form-grid select{border:1px solid #e5e7eb;border-radius:6px;padding:7px 10px;font-size:14px}.color-row{flex-wrap:wrap;align-items:center;gap:4px;display:flex}.color-row .color-opt{cursor:pointer;border:2px solid #0000;border-radius:6px;width:26px;height:26px;padding:0}.color-row .color-opt.selected{border-color:#1e293b}.color-custom{cursor:pointer;border:1px solid #e5e7eb;border-radius:6px;width:32px;height:32px;padding:0}.placeholder-mini{text-align:center;color:#94a3b8;padding:20px;font-size:13px}.error-banner{color:#c00;cursor:pointer;background:#fee;border-left:4px solid #c00;border-radius:6px;margin-bottom:12px;padding:8px 12px;font-size:13px}.emp-table .antiquity{color:#64748b;font-size:13px}.emp-legajo{color:#94a3b8;margin-right:6px;font-family:ui-monospace,monospace;font-size:11px;font-weight:600}.emp-table .legajo{color:#475569;font-family:ui-monospace,monospace;font-weight:600}.week-nav{align-items:center;gap:2px;display:inline-flex}.icon-btn.compact{width:28px;height:28px;font-size:14px}.text-btn.compact{margin-left:4px;padding:5px 10px;font-size:13px}.week-label{color:#475569;white-space:nowrap;margin-left:8px;font-size:14px;font-weight:500}.toolbar-title{margin:0 8px 0 0;font-size:17px;font-weight:600}.shift-pill.color-only{cursor:pointer;border-left-width:4px;border-radius:3px;height:18px;min-height:18px;padding:0;transition:filter .15s,transform 50ms}.shift-pill.color-only:hover{filter:brightness(1.08);transform:translateY(-1px)}.shift-pill.color-only.draft{opacity:.55;border-left-style:dashed}.shift-pill.color-only.timeoff{background:repeating-linear-gradient(-45deg,#cbd5e1,#cbd5e1 4px,#e2e8f0 4px 8px);border-left-color:#94a3b8}.shift-pill.color-only.conflict{outline-offset:-1px;outline:2px solid #ef4444;animation:2s infinite pulseConflict}.shifts{gap:3px}.shift-tooltip{color:#fff;pointer-events:none;z-index:5000;background:#1e293b;border-radius:6px;flex-direction:column;gap:3px;min-width:160px;max-width:260px;padding:8px 12px;font-size:12px;animation:.12s ease-out tooltipIn;display:flex;position:fixed;transform:translate(-50%,-100%);box-shadow:0 6px 20px #00000040}@keyframes tooltipIn{0%{opacity:0;transform:translate(-50%,-90%)}to{opacity:1;transform:translate(-50%,-100%)}}.shift-tooltip:after{content:"";border:5px solid #0000;border-top-color:#1e293b;border-bottom-width:0;position:absolute;bottom:-5px;left:50%;transform:translate(-50%)}.shift-tooltip strong{font-size:13px;font-weight:600}.tooltip-line{color:#e2e8f0;font-size:12px}.tooltip-line.muted{color:#94a3b8;font-size:11px}.tooltip-line.warn{color:#fbbf24;font-weight:500}
