@import "https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700&display=swap";:root{--font-sans:"Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--bg-app:#0b0f19;--bg-card:#151c2c;--bg-card-hover:#1e2638;--border-color:#242f47;--text-primary:#f3f4f6;--text-secondary:#9ca3af;--text-muted:#6b7280;--primary:#6366f1;--primary-hover:#4f46e5;--primary-glow:#6366f126;--success:#10b981;--success-bg:#10b9811a;--success-border:#10b98133;--warning:#f59e0b;--warning-bg:#f59e0b1a;--warning-border:#f59e0b33;--danger:#ef4444;--danger-bg:#ef44441a;--danger-border:#ef444433;--info:#06b6d4;--info-bg:#06b6d41a;--weekend-bg:#e5cdcd59;--holiday-bg:#e5cdcd59;--holiday-border:#a9595959;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -2px #0000000d;--shadow-xl:0 20px 25px -5px #0003, 0 10px 10px -5px #0000000a;--radius-sm:.375rem;--radius-md:.5rem;--radius-lg:.75rem;--radius-xl:1rem;--transition-fast:.15s ease;--transition-normal:.25s ease}:root[data-theme=light]{--bg-app:#f8fafc;--bg-card:#fff;--bg-card-hover:#f1f5f9;--border-color:#e2e8f0;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--primary:#4f46e5;--primary-hover:#3730a3;--primary-glow:#4f46e51a;--weekend-bg:#e5cdcd59;--holiday-bg:#e5cdcd59;--shadow-md:0 4px 6px -1px #0f172a14, 0 2px 4px -1px #0f172a0a;--shadow-lg:0 10px 15px -3px #0f172a0d, 0 4px 6px -2px #0f172a05}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--bg-app);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;transition:background-color var(--transition-normal), color var(--transition-normal);line-height:1.5}#root{min-height:100vh;display:flex}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-app)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes pulseGlow{0%,to{opacity:.6;transform:scale(1)}50%{opacity:.9;transform:scale(1.05)}}.animate-fade-in{animation:fadeIn var(--transition-normal) forwards}.btn{font-family:var(--font-sans);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);border:1px solid #0000;justify-content:center;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.875rem;font-weight:600;text-decoration:none;display:inline-flex}.btn-primary{background-color:var(--primary);color:#fff}.btn-primary:hover{background-color:var(--primary-hover);box-shadow:0 0 12px var(--primary-glow)}.btn-secondary{border-color:var(--border-color);color:var(--text-primary);background-color:#0000}.btn-secondary:hover{background-color:var(--bg-card-hover)}.btn-danger{background-color:var(--danger-bg);border-color:var(--danger-border);color:#ef4444}.btn-danger:hover{background-color:var(--danger);color:#fff}.btn-success{background-color:var(--success-bg);border-color:var(--success-border);color:#10b981}.btn-success:hover{background-color:var(--success);color:#fff}.card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:1.5rem}.app-container{width:100%;min-height:100vh;display:flex}.sidebar{background-color:var(--bg-card);border-right:1px solid var(--border-color);flex-direction:column;flex-shrink:0;justify-content:space-between;width:260px;height:100vh;padding:1.5rem;display:flex;position:sticky;top:0}.main-content{flex-grow:1;max-width:calc(100% - 260px);padding:2rem;overflow-y:auto}.form-group{text-align:left;flex-direction:column;gap:.375rem;margin-bottom:1.25rem;display:flex}.form-label{color:var(--text-secondary);font-size:.85rem;font-weight:600}.form-input,.form-select,.form-textarea{font-family:var(--font-sans);background-color:var(--bg-app);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none;padding:.625rem .875rem;font-size:.9rem}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.login-wrapper{background:radial-gradient(circle at 10% 20%,#6366f114 0%,#0000 45%),radial-gradient(circle at 90% 80%,#06b6d414 0%,#0000 45%);justify-content:center;align-items:center;width:100%;height:100vh;display:flex}.login-card{width:100%;max-width:440px;animation:.4s forwards fadeIn}.login-header{text-align:center;margin-bottom:2rem}.login-logo{background:linear-gradient(135deg, var(--primary), var(--info));-webkit-text-fill-color:transparent;-webkit-background-clip:text;justify-content:center;align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:2rem;font-weight:700;display:flex}.login-quick-access{border-top:1px solid var(--border-color);margin-top:1.5rem;padding-top:1.5rem}.login-quick-btns{grid-template-columns:1fr 1fr;gap:.75rem;margin-top:.75rem;display:grid}.toast-container{z-index:2500;flex-direction:column;align-items:stretch;gap:.6rem;width:min(520px,100vw - 2rem);display:flex;position:fixed;top:1rem;left:50%;transform:translate(-50%)}.toast-item{border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-card);box-shadow:var(--shadow-lg);animation:fadeIn var(--transition-normal) forwards;justify-content:space-between;align-items:center;gap:.75rem;padding:.7rem .8rem;display:flex}.toast-content{align-items:center;gap:.55rem;font-size:.85rem;display:flex}.toast-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none}.toast-success{border-color:var(--success-border)}.toast-error{border-color:var(--danger-border)}.toast-info{border-color:var(--warning-border)}.sidebar-logo{background:linear-gradient(135deg, var(--primary), var(--info));-webkit-text-fill-color:transparent;-webkit-background-clip:text;align-items:center;gap:.5rem;margin-bottom:2rem;font-size:1.25rem;font-weight:700;display:flex}.sidebar-menu{flex-direction:column;gap:.375rem;list-style:none;display:flex}.sidebar-item-btn{border-radius:var(--radius-md);width:100%;color:var(--text-secondary);font-family:var(--font-sans);cursor:pointer;text-align:left;transition:all var(--transition-fast);background:0 0;border:none;align-items:center;gap:.75rem;padding:.75rem 1rem;font-size:.9rem;font-weight:500;display:flex}.sidebar-item-btn:hover{background-color:var(--bg-card-hover);color:var(--text-primary)}.sidebar-item-btn.active{background-color:var(--primary);color:#fff}.sidebar-profile{border-top:1px solid var(--border-color);align-items:center;gap:.75rem;padding-top:1rem;display:flex}.sidebar-avatar{background:linear-gradient(135deg, var(--primary), var(--info));color:#fff;border-radius:50%;justify-content:center;align-items:center;width:38px;height:38px;font-size:.9rem;font-weight:600;display:flex}.sidebar-user-info{text-align:left;flex-direction:column;display:flex;overflow:hidden}.sidebar-username{white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:600;overflow:hidden}.sidebar-role{color:var(--text-muted);font-size:.75rem}.sidebar-logout{color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);transition:color var(--transition-fast), background var(--transition-fast);background:0 0;border:none;align-items:center;margin-left:auto;padding:.25rem;display:flex}.sidebar-logout:hover{color:var(--danger);background-color:var(--danger-bg)}.timesheet-header-actions{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.timesheet-grid-card{padding:0;overflow:visible}.timesheet-page-shell{flex-direction:column;height:calc(100vh - 4rem);max-height:calc(100vh - 4rem);display:flex;overflow:hidden}.timesheet-header-block{flex-shrink:0;padding-top:.25rem}.timesheet-content-scroll{flex:1;min-height:0;padding-right:.25rem;position:relative;overflow:auto}.timesheet-submit-dock{flex-shrink:0;margin-top:1rem}.timesheet-table-wrapper{overflow:visible}.timesheet-table{border-collapse:separate;border-spacing:0;text-align:left;width:100%;font-size:.875rem}.timesheet-table th{background-color:var(--bg-card-hover);color:var(--text-primary);border-bottom:1px solid var(--border-color);padding:.875rem 1rem;font-weight:600;position:static}.timesheet-table thead{position:static}.timesheet-table thead tr{background-color:var(--bg-card-hover)}.timesheet-table thead th{z-index:30;background-color:var(--bg-card-hover);box-shadow:0 1px 0 var(--border-color);position:sticky;top:0}.timesheet-table td{border-bottom:1px solid var(--border-color);vertical-align:middle;padding:.75rem 1rem}.timesheet-row-weekend{background-color:var(--weekend-bg)}.timesheet-row-holiday{background-color:var(--holiday-bg)}.timesheet-row-smart{background-color:#10b98108}.day-badge{background-color:var(--border-color);width:28px;height:28px;color:var(--text-secondary);border-radius:50%;justify-content:center;align-items:center;font-size:.8rem;font-weight:600;display:inline-flex}.timesheet-row-weekend .day-badge{color:#7b3f3f;background-color:#a9595938}.timesheet-row-holiday .day-badge{border:1px solid var(--holiday-border);color:#7b3f3f;background-color:#a9595938}.holiday-name{color:#8f4b4b;margin-left:.5rem;font-size:.75rem;font-weight:500}.inline-input-hours{background-color:var(--bg-app);border:1px solid var(--border-color);border-radius:var(--radius-sm);width:60px;color:var(--text-primary);text-align:center;padding:.375rem;font-weight:500}.inline-input-hours:focus{border-color:var(--primary);outline:none}.inline-input-note{background-color:var(--bg-app);border:1px solid var(--border-color);border-radius:var(--radius-sm);width:100%;min-width:150px;color:var(--text-primary);padding:.375rem .5rem}.inline-input-note:focus{border-color:var(--primary);outline:none}.badge{text-transform:uppercase;letter-spacing:.05em;border-radius:50px;align-items:center;gap:.375rem;padding:.25rem .625rem;font-size:.75rem;font-weight:600;display:inline-flex}.badge-draft{background-color:var(--text-muted);color:#fff}.badge-submitted{background-color:var(--warning-bg);border:1px solid var(--warning-border);color:var(--warning)}.badge-approved{background-color:var(--success-bg);border:1px solid var(--success-border);color:var(--success)}.badge-root,.badge-rejected{background-color:var(--danger-bg);border:1px solid var(--danger-border);color:var(--danger)}.switch{width:44px;height:22px;display:inline-block;position:relative}.switch input{opacity:0;width:0;height:0}.slider{cursor:pointer;background-color:var(--border-color);border-radius:34px;transition:all .2s;position:absolute;inset:0}.slider:before{content:"";background-color:#fff;border-radius:50%;width:16px;height:16px;transition:all .2s;position:absolute;bottom:3px;left:3px}input:checked+.slider{background-color:var(--success)}input:focus+.slider{box-shadow:0 0 1px var(--success)}input:checked+.slider:before{transform:translate(22px)}.builder-layout{grid-template-columns:240px 1fr;gap:1.5rem;min-height:500px;margin-top:1.5rem;display:grid}.builder-sidebar{background-color:var(--bg-card-hover);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1rem}.builder-elements{flex-direction:column;gap:.75rem;margin-top:1rem;display:flex}.draggable-element{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:grab;transition:transform var(--transition-fast), border-color var(--transition-fast);align-items:center;gap:.5rem;padding:.75rem;font-size:.85rem;font-weight:500;display:flex}.draggable-element:hover{border-color:var(--primary);transform:translateY(-2px)}.builder-canvas{background-color:var(--bg-app);border:2px dashed var(--border-color);border-radius:var(--radius-lg);flex-direction:column;gap:1rem;min-height:450px;padding:2rem;display:flex;position:relative}.builder-canvas.drag-over{border-color:var(--primary);background-color:#6366f108}.builder-canvas-empty{height:100%;min-height:380px;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:.5rem;display:flex}.canvas-element{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);justify-content:space-between;align-items:center;padding:1rem;animation:.2s forwards fadeIn;display:flex}.canvas-element-content{align-items:center;gap:.75rem;font-size:.9rem;display:flex}.canvas-element-actions{gap:.5rem;display:flex}.canvas-element-btn{color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast);background:0 0;border:none;align-items:center;padding:.25rem;display:flex}.canvas-element-btn:hover{background-color:var(--danger-bg);color:var(--danger)}.btn-icon-sm{border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-card-hover);width:28px;height:28px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;display:inline-flex}.btn-icon-sm:hover{border-color:var(--primary);color:var(--primary)}.btn-icon-danger:hover{border-color:var(--danger);color:var(--danger);background:var(--danger-bg)}.checkbox-list{background:var(--bg-app);border:1px solid var(--border-color);border-radius:var(--radius-md);flex-direction:column;gap:.5rem;max-height:140px;padding:.75rem;display:flex;overflow-y:auto}.checkbox-item{cursor:pointer;color:var(--text-secondary);align-items:center;gap:.5rem;font-size:.85rem;display:flex}.checkbox-item input{accent-color:var(--primary)}.client-rules-table{border:1px solid var(--border-color);border-radius:var(--radius-md);overflow-x:auto}.excel-builder-layout{grid-template-columns:220px minmax(0,1fr) 280px;gap:1rem;min-height:520px;display:grid}.excel-sheet-wrapper{border:1px solid var(--border-color);border-radius:var(--radius-lg);color:#1e293b;background:#fff;overflow:hidden}.excel-grid-scroll{max-height:520px;overflow:auto}.excel-sheet-header{color:#fff;background:#217346;padding:.5rem 1rem;font-size:.8rem;font-weight:600}.excel-grid{background:#d1d5db;gap:1px;width:max-content;min-width:100%;min-height:480px;padding:1px;display:grid}.excel-cell{background:#fff;align-items:stretch;min-height:32px;font-size:.65rem;display:flex;position:relative}.excel-cell-coord{color:#94a3b8;pointer-events:none;font-size:.6rem;position:absolute;top:2px;left:4px}.excel-cell-drag-over{outline:2px dashed var(--primary);background:#6366f126}.excel-cell-filled{background:#f8fafc}.excel-block{cursor:pointer;flex:1;padding:.35rem;position:relative;overflow:hidden}.excel-block-selected{outline:2px solid var(--primary);outline-offset:-2px}.excel-block-remove{color:#fff;cursor:pointer;opacity:0;transition:opacity var(--transition-fast);background:#00000080;border:none;border-radius:3px;padding:2px;position:absolute;top:2px;right:2px}.excel-block:hover .excel-block-remove{opacity:1}.excel-block-logo{color:#64748b;border:2px dashed #cbd5e1;justify-content:center;align-items:center;height:100%;font-size:.75rem;font-weight:600;display:flex}.excel-block-title{justify-content:center;align-items:center;height:100%;padding:.25rem;font-size:.85rem;font-weight:700;display:flex}.excel-block-info{color:#475569;flex-direction:column;gap:.15rem;padding:.25rem;font-size:.7rem;display:flex}.excel-preview-table{border-collapse:collapse;width:100%;font-size:.65rem}.excel-preview-table th,.excel-preview-table td{text-align:left;white-space:nowrap;border:1px solid #cbd5e1;padding:.2rem .35rem}.excel-block-totals,.excel-block-notes{color:#334155;padding:.35rem;font-size:.75rem;font-weight:600}.excel-block-signature{color:#475569;flex-direction:column;justify-content:flex-end;height:100%;padding:.35rem;font-size:.7rem;display:flex}.excel-signature-line{border-bottom:1px solid #334155;margin-top:1.5rem}.excel-properties-panel{background:var(--bg-card-hover);border:1px solid var(--border-color);border-radius:var(--radius-lg);max-height:560px;padding:1rem;overflow-y:auto}.column-config-row{grid-template-columns:1fr 36px 28px;align-items:center;gap:.35rem;margin-bottom:.35rem;display:grid}.column-config-card{border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-card);margin-bottom:.45rem;padding:.45rem}.column-config-meta{grid-template-columns:1fr 88px;gap:.35rem;margin-bottom:.35rem;display:grid}.color-input-row{align-items:center;gap:.5rem;display:flex}.color-input{border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;background:0 0;width:44px;min-width:44px;height:34px;padding:0}.color-code-chip{color:var(--text-secondary);border-radius:var(--radius-sm);background:var(--bg-app);border:1px solid var(--border-color);padding:.35rem .5rem;font-size:.75rem}.dialog-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background-color:#0009;justify-content:center;align-items:center;animation:.2s forwards fadeIn;display:flex;position:fixed;inset:0}.dialog-content{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:100%;max-width:500px;box-shadow:var(--shadow-xl);padding:2rem}.dialog-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.dialog-close{color:var(--text-secondary);cursor:pointer;transition:background var(--transition-fast);background:0 0;border:none;border-radius:50%;align-items:center;padding:.25rem;display:flex}.dialog-close:hover{background-color:var(--bg-card-hover)}.admin-grid{grid-template-columns:1fr;gap:1.5rem;display:grid}.admin-section-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.quick-insert-bar{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);grid-template-columns:repeat(auto-fit,minmax(150px,1fr)) auto;align-items:flex-end;gap:1rem;margin-bottom:1.5rem;padding:1.25rem;display:grid}.tabs-container{border-bottom:1px solid var(--border-color);gap:.5rem;margin-bottom:1.5rem;display:flex}.tab-btn{color:var(--text-secondary);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;border-bottom:2px solid #0000;padding:.75rem 1.25rem;font-size:.9rem;font-weight:600}.tab-btn:hover{color:var(--text-primary)}.tab-btn.active{color:var(--primary);border-bottom-color:var(--primary)}.holiday-list{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;margin-top:1rem;display:grid}.holiday-item{background-color:var(--bg-card-hover);border:1px solid var(--border-color);border-radius:var(--radius-md);justify-content:space-between;align-items:center;padding:.75rem 1rem;font-size:.875rem;display:flex}.holiday-item-name{font-weight:600}.holiday-item-date{color:var(--text-muted);font-size:.75rem}.settings-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;display:grid}@media (width<=900px){.app-container{flex-direction:column}.sidebar{border-right:none;border-bottom:1px solid var(--border-color);width:100%;height:auto;position:relative}.main-content{max-width:100%;padding:1.5rem}.quick-insert-bar{grid-template-columns:1fr;align-items:stretch}.builder-layout,.excel-builder-layout{grid-template-columns:1fr}}
