.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-weight:500;border-radius:6px;border:none;cursor:pointer;font-family:inherit;transition:all .15s ease}.btn-md{padding:.5rem 1rem;font-size:.875rem}.btn-primary{background-color:#2d0040!important;color:#fff!important}.btn-primary:hover:not(:disabled){background-color:#4a0d6b!important}.btn-accent{background-color:#4ad6d6!important;color:#2d0040!important}.btn-accent:hover:not(:disabled){background-color:#3bc4c4!important}.btn-outline{background-color:transparent!important;border:1px solid #e8e8f0!important;color:#1a1a2e!important}.btn-outline:hover:not(:disabled){background-color:#f8f7fa!important}.btn-danger{background-color:#ef4444!important;color:#fff!important}.btn-danger:hover:not(:disabled){background-color:#dc2626!important}.btn-loading{opacity:.7}.app-layout{display:flex;min-height:100vh}.sidebar{width:260px;background-color:#2d0040;color:#fff;display:flex;flex-direction:column;padding:1.5rem 1rem}.sidebar-brand{display:flex;align-items:center;gap:.75rem;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-logo{width:40px;height:40px;background:linear-gradient(135deg,#4ad6d6,#2d0040);border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.875rem}.sidebar-title{font-weight:600;font-size:1rem}.sidebar-nav{display:flex;flex-direction:column;gap:.25rem}.sidebar-link{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:6px;color:#fffc;text-decoration:none;transition:all .15s ease}.sidebar-link:hover{background-color:#ffffff1a;color:#fff}.sidebar-link.active{background-color:#4ad6d633;color:#4ad6d6}.app-main{flex:1;padding:2rem;background-color:#f8f7fa;overflow-y:auto}.mobile-menu-toggle{display:none;align-items:center;justify-content:center;background:none;border:none;color:#1a1a2e;cursor:pointer;padding:.25rem}.sidebar-close{display:none;position:absolute;top:1rem;right:1rem;background:none;border:none;color:#fff;font-size:1.5rem;line-height:1;cursor:pointer;z-index:1001;width:2rem;height:2rem;align-items:center;justify-content:center}.sidebar-wrapper{flex-shrink:0}.sidebar-overlay{display:none}@media(max-width:768px){.mobile-menu-toggle{display:flex}.sidebar-wrapper{position:fixed;top:0;left:0;bottom:0;width:260px;z-index:1000;transform:translate(-100%);transition:transform .25s ease}.app-layout.mobile-menu-open .sidebar-wrapper{transform:translate(0)}.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:999;opacity:0;pointer-events:none;transition:opacity .25s ease}.app-layout.mobile-menu-open .sidebar-overlay{opacity:1;pointer-events:auto}.sidebar-close{display:flex}.app-main{padding:1rem}}._item_3vcnt_1{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem 0;border-bottom:1px solid var(--border-color, rgba(255, 255, 255, .1))}._item_3vcnt_1:last-child{border-bottom:none}._iconWrapper_3vcnt_13{flex-shrink:0;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center}._content_3vcnt_23{flex:1;min-width:0}._message_3vcnt_28{margin:0;font-size:.875rem;color:var(--text-primary, #fff);line-height:1.4}._meta_3vcnt_35{display:flex;align-items:center;gap:.5rem;margin-top:.25rem;font-size:.75rem;color:var(--text-secondary, #9ca3af)}._actor_3vcnt_44{font-weight:500}._separator_3vcnt_48{opacity:.5}._time_3vcnt_52{white-space:nowrap}._container_3vcnt_56{background:var(--card-bg, rgba(255, 255, 255, .05));border:1px solid var(--border-color, rgba(255, 255, 255, .1));border-radius:.75rem;padding:1rem}._title_3vcnt_63{margin:0 0 .5rem;font-size:1rem;font-weight:600;color:var(--text-primary, #fff)}._list_3vcnt_70{display:flex;flex-direction:column}._loading_3vcnt_75,._empty_3vcnt_76,._error_3vcnt_77{padding:1rem 0;text-align:center;font-size:.875rem;color:var(--text-secondary, #9ca3af)}._error_3vcnt_77{color:#ef4444}._loadMore_3vcnt_88{width:100%;margin-top:.75rem;padding:.5rem;background:transparent;border:1px solid var(--border-color, rgba(255, 255, 255, .1));border-radius:.5rem;color:var(--text-secondary, #9ca3af);font-size:.875rem;cursor:pointer;transition:all .2s ease}._loadMore_3vcnt_88:hover:not(:disabled){background:var(--hover-bg, rgba(255, 255, 255, .05));color:var(--text-primary, #fff)}._loadMore_3vcnt_88:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){._container_3vcnt_56{padding:.75rem;border-radius:.5rem}._iconWrapper_3vcnt_13{width:44px;height:44px}._item_3vcnt_1{gap:.5rem;padding:.625rem 0}._meta_3vcnt_35{flex-wrap:wrap;gap:.25rem}._time_3vcnt_52{white-space:normal}._loadMore_3vcnt_88{padding:.625rem;min-height:44px}}*{margin:0;padding:0;box-sizing:border-box}.sidebar{display:flex;flex-direction:column;height:100%;overflow-y:auto}.sidebar-nav{display:flex;flex-direction:column}.sidebar-nav--bottom{margin-top:auto;padding-top:.5rem;border-top:1px solid var(--border)}.birth-date-grid{max-width:400px;width:100%}:root{--primary: #2D0040;--primary-light: #4a0d6b;--primary-hover: #4a0d6b;--accent: #4AD6D6;--accent-hover: #3bc4c4;--background: #f8f7fa;--surface: #ffffff;--text-primary: #1a1a2e;--text-secondary: #6b6b80;--text-muted: #9a9ab0;--border: #e8e8f0;--success: #22c55e;--warning: #f59e0b;--danger: #ef4444;--shadow-sm: 0 1px 2px rgba(45, 0, 64, .05);--shadow-md: 0 4px 6px -1px rgba(45, 0, 64, .1);--shadow-lg: 0 10px 15px -3px rgba(45, 0, 64, .1);--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--transition-fast: .15s ease;--transition-normal: .2s ease}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--background);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}.container{width:100%;padding:0 1rem}.card{background-color:var(--surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:1.5rem}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;font-weight:500;border-radius:var(--radius-sm);border:none;cursor:pointer;transition:all .2s;font-size:.875rem}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--primary-hover)}.btn-accent{background-color:var(--accent);color:var(--primary)}.btn-accent:hover:not(:disabled){background-color:var(--accent-hover)}.btn-danger{background-color:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background-color:#dc2626}.btn-outline{background-color:transparent;border:1px solid var(--border);color:var(--text-primary)}.btn-outline:hover:not(:disabled){background-color:var(--background)}.btn-sm{padding:.375rem .75rem;font-size:.75rem}.btn-lg{padding:.75rem 1.5rem;font-size:1rem}.input{width:100%;padding:.5rem .75rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.875rem;transition:border-color .2s}.input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #4ad6d626}.input-error{border-color:var(--danger)}.settings-input{width:100%;max-width:280px}.label{display:block;margin-bottom:.5rem;font-weight:500;font-size:.875rem;color:var(--text-primary)}.error-message{color:var(--danger);font-size:.75rem;margin-top:.25rem}.loading{display:inline-block;width:1rem;height:1rem;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.table-container{overflow-x:auto}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--border)}.table th{font-weight:600;background-color:var(--background);color:var(--text-primary)}.table tr:hover{background-color:var(--background)}.badge{display:inline-flex;align-items:center;padding:.25rem .5rem;font-size:.75rem;font-weight:500;border-radius:9999px}.badge-employee{background-color:#4ad6d633;color:#2a9d9d}.badge-project-manager{background-color:#f59e0b33;color:#b45309}.badge-admin{background-color:#ef444433;color:#dc2626}.badge-super-admin{background-color:#2d004033;color:var(--primary)}.badge-active{background-color:#22c55e33;color:#16a34a}.badge-completed{background-color:#4ad6d633;color:#2a9d9d}.badge-archived{background-color:#6b6b8033;color:var(--text-secondary)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background-color:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-width:500px;width:100%;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--border)}.modal-title{font-size:1.25rem;font-weight:600}.modal-body{padding:1.5rem}.modal-footer{display:flex;justify-content:flex-end;gap:.5rem;padding:1.5rem;border-top:1px solid var(--border)}.role-modal-content{background:var(--surface);border-radius:16px;padding:1.5rem;width:100%;max-width:480px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;gap:1.25rem}.role-modal-section{display:flex;flex-direction:column;gap:.75rem}.role-modal-section-title{font-size:.875rem;font-weight:600;color:var(--text-primary);margin:0}.role-modal-option{display:flex;align-items:center;gap:.625rem;cursor:pointer;font-size:.9375rem;line-height:1.4;padding:.5rem .75rem;border-radius:10px;border:1.5px solid transparent;transition:all .15s ease}button.role-modal-option{background:transparent;color:inherit;font-family:inherit;font-size:inherit;line-height:inherit;text-align:left;width:100%}.role-modal-option:hover{background-color:#2d00400a}.role-modal-option.active{border-color:var(--primary);background-color:#2d00400f}.role-modal-option input[type=radio]{flex-shrink:0;width:20px;height:20px;margin:0;cursor:pointer;accent-color:var(--primary)}.role-modal-nested{margin-left:1.75rem;display:flex;flex-direction:column;gap:.5rem}.role-modal-divider{height:1px;background:var(--border);margin:0;border:none}.role-modal-input-group{display:flex;gap:.5rem;align-items:center}.role-modal-input-group .form-input{flex:1}.role-modal-input-suffix{font-size:.875rem;color:var(--text-muted);white-space:nowrap;font-weight:500}@media(max-width:768px){.role-modal-content{padding:1rem;max-width:100%;border-radius:12px 12px 0 0;max-height:90vh;overflow-y:auto;position:fixed;bottom:0;left:0;right:0;margin:0;gap:1rem}.role-modal-nested{margin-left:1.25rem}.role-modal-option{font-size:.9375rem;padding:.625rem .75rem}.role-modal-option input[type=radio]{width:22px;height:22px}}.app-layout{display:flex;height:100vh;overflow:hidden}.app-sidebar{flex-shrink:0}.app-main{flex:1;overflow:auto;background-color:var(--background);padding:2rem}.app-header{position:relative;z-index:100}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.page-title-group{display:flex;align-items:center;gap:.75rem}.page-title{font-size:1.75rem;font-weight:600;color:var(--text-primary);margin:0}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:1.5rem}.stat-grid--wide{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.stat-grid--xl{grid-template-columns:repeat(auto-fit,minmax(450px,1fr))}.stat-card{padding:1.5rem;background-color:var(--surface);border-radius:var(--radius-md);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.stat-card-icon{width:48px;height:48px}.stat-card-label{font-size:.875rem;color:var(--text-secondary);margin-bottom:.5rem}.stat-card-value{font-size:2rem;font-weight:600;color:var(--primary)}.stat-label{font-size:.75rem;color:var(--text-muted);margin-bottom:.25rem}.stat-value{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.filter-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;margin-bottom:1.5rem}.table-wrapper{background-color:var(--surface);border-radius:var(--radius-md);border:1px solid var(--border);overflow:hidden}.table-header-row{border-bottom:1px solid var(--border)}.table-header-cell{padding:.875rem 1rem;text-align:left;font-weight:600;color:var(--text-primary);cursor:pointer;-webkit-user-select:none;user-select:none}.table-row{border-bottom:1px solid var(--border);transition:background-color .2s}.table-row:hover{background-color:var(--background)}.table-cell{padding:1rem}.empty-state{text-align:center;padding:3rem;background-color:var(--surface);border-radius:var(--radius-md);border:1px dashed var(--border)}.action-btn{display:inline-flex;align-items:center;justify-content:center;padding:.375rem;border:1px solid var(--border);border-radius:var(--radius-sm);background-color:var(--background);color:var(--text-secondary);cursor:pointer;transition:background-color .2s}.action-btn:hover{background-color:var(--border)}.action-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.action-btn--danger{color:var(--danger)}@keyframes fadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.projects-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.date-range-inputs{flex-wrap:wrap}.modal-create-employee{box-sizing:border-box}@media(max-width:768px){.container{padding:0 .5rem}.card{padding:1rem}.app-header{position:fixed;top:0;left:0;right:0;z-index:100;padding-top:env(safe-area-inset-top)}.app-main{padding:calc(64px + env(safe-area-inset-top)) .5rem env(safe-area-inset-bottom)}.page-header{flex-direction:column;align-items:flex-start;gap:1rem;margin-bottom:1.5rem}.page-title{font-size:1.125rem;line-height:1.3}.page-title-group{gap:.5rem}.settings-input{max-width:100%}.stat-grid{grid-template-columns:repeat(2,1fr);gap:.5rem;margin-bottom:1rem}.stat-grid--wide{grid-template-columns:repeat(2,1fr)}.stat-grid--xl{grid-template-columns:1fr}.stat-card{padding:.75rem}.stat-card-icon{width:36px;height:36px;margin-bottom:.5rem}.stat-card-label{font-size:.75rem;line-height:1.2;margin-bottom:.25rem}.stat-card-value{font-size:1.125rem;word-break:keep-all}.filter-grid{grid-template-columns:1fr;gap:.75rem;margin-bottom:1rem}.table th,.table td{padding:.5rem;font-size:.875rem}.empty-state{padding:2rem 1rem}.modal-header,.modal-body,.modal-footer{padding:1rem}.modal-title{font-size:1rem}.user-menu-name{display:none}.auth-card{padding:1.5rem}.birth-date-grid{grid-template-columns:1fr!important;max-width:400px;width:100%;margin:0 auto}.project-card-header{flex-wrap:wrap;gap:.5rem;padding:.75rem}.project-card-meta{margin-left:0!important;width:100%;justify-content:space-between;flex-wrap:wrap}.project-employee-item{flex-wrap:wrap;padding:.625rem}.project-employee-actions{width:100%;justify-content:flex-end;margin-top:.25rem}.slide-over-panel{width:100vw!important;max-width:100vw!important}.info-field-row{flex-wrap:wrap;gap:.25rem}.dept-list-header{flex-wrap:wrap;row-gap:.25rem}.project-modal-grid,.project-view-info-grid{grid-template-columns:1fr!important}.day-row-header{flex-wrap:wrap;gap:.5rem}.report-type-buttons{flex-wrap:wrap}.projects-card-grid{grid-template-columns:1fr}.date-range-inputs>div{flex:1 1 100%}.modal-create-employee{max-width:100vw!important;width:100%!important;max-height:100dvh!important;height:100%!important;border-radius:0!important;padding:1rem!important;margin:0!important}.modal-create-employee input,.modal-create-employee select,.modal-create-employee button{min-height:44px;font-size:16px}.modal-create-employee input[type=radio],.modal-create-employee input[type=checkbox]{min-width:20px;min-height:20px}.modal-create-employee form>div>div{margin-bottom:1rem}.modal-create-employee .employee-type-options{flex-direction:column}.modal-create-employee .employee-type-option{min-width:100%!important;padding:1rem!important}.modal-create-employee button[type=submit],.modal-create-employee button[type=button]{width:100%;justify-content:center;padding:.75rem 1rem}.table-wrapper>div,.table-container{-webkit-overflow-scrolling:touch}.tabs-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;display:flex;gap:.25rem;padding-bottom:.25rem}.tabs-scroll button{flex-shrink:0;white-space:nowrap}.toast-mobile{min-width:auto!important;width:calc(100% - 2rem)!important;max-width:400px;left:1rem!important;right:1rem!important;transform:none!important}.reports-page{padding:1rem!important}.projects-header-actions{flex-wrap:wrap;width:100%;justify-content:flex-start}.action-btn{min-width:44px;min-height:44px}.hide-mobile,.budget-full{display:none!important}.budget-compact{display:inline!important}}.budget-compact{display:none}.employee-table-desktop{display:block}.employee-cards-mobile{display:none!important}.worker-projects-desktop{display:block}.worker-projects-mobile{display:none!important}.daily-summary-desktop{display:block}.daily-summary-mobile{display:none!important}.projects-table-desktop{display:block}.projects-table-mobile{display:none!important}.employees-table-desktop{display:block}.employees-table-mobile{display:none!important}.employee-tabs-desktop{display:flex;gap:.25rem}.employee-tabs-mobile{display:none!important}@media(max-width:768px){.employee-table-desktop{display:none!important}.employee-cards-mobile{display:flex!important}.employee-tabs-desktop{display:none!important}.employee-tabs-mobile{display:block!important}.worker-projects-desktop{display:none!important}.worker-projects-mobile{display:flex!important}.daily-summary-desktop{display:none!important}.daily-summary-mobile{display:flex!important}.projects-table-desktop{display:none!important}.projects-table-mobile{display:flex!important}.employees-table-desktop{display:none!important}.employees-table-mobile{display:flex!important}}.slide-over-panel{position:fixed;top:0;right:0;width:600px;max-width:90vw;height:100vh;background-color:var(--surface);box-shadow:var(--shadow-lg);z-index:1001;display:flex;flex-direction:column}.slide-over-header{padding:1.5rem;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:1rem}.slide-over-avatar{width:48px;height:48px;border-radius:50%;background-color:var(--primary);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:1.125rem;flex-shrink:0}.slide-over-title-wrap{flex:1;min-width:0;overflow:hidden}.slide-over-title{margin:0;font-size:1.125rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.slide-over-subtitle{font-size:.875rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.slide-over-close-btn{background:none;border:none;cursor:pointer;padding:.5rem;color:var(--text-muted);min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:background-color .2s}.slide-over-close-btn:hover{background-color:var(--background)}.slide-over-tabs{display:flex;border-bottom:1px solid var(--border)}.slide-over-tab{flex:1;padding:1rem;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-weight:400;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all .2s}.slide-over-tab:hover{background-color:var(--background)}.slide-over-tab.active{border-bottom-color:var(--primary);color:var(--primary);font-weight:600}.slide-over-content{flex:1;overflow:auto;padding:1.5rem}@media(max-width:768px){.slide-over-panel{width:100vw!important;max-width:100vw!important}.slide-over-header{padding:1rem;gap:.75rem}.slide-over-avatar{width:40px;height:40px;font-size:1rem}.slide-over-title{font-size:1rem}.slide-over-subtitle{font-size:.8125rem}.slide-over-tab{padding:.75rem .5rem;font-size:0}.slide-over-tab svg{width:24px;height:24px}.slide-over-tab .tab-label{display:none}.slide-over-content{padding:1rem}}.settings-section{border:1px solid var(--border);border-radius:var(--radius-md);background-color:var(--surface);overflow:hidden}.settings-section-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;background-color:var(--background);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s}.settings-section-header:hover{background-color:#2d004008}.settings-section-title{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;color:var(--text-primary);margin:0}.settings-section-icon{color:var(--text-muted);transition:transform .2s}.settings-section.expanded .settings-section-icon{transform:rotate(180deg)}.settings-section-content{padding:1.25rem;display:none}.settings-section.expanded .settings-section-content{display:block}@media(min-width:769px){.settings-section-icon{display:none}.settings-section-header{cursor:default}.settings-section-header:hover{background-color:var(--background)}.settings-section-content{display:block!important}}@media(max-width:768px){.settings-section{margin-bottom:.75rem}.settings-section-header{padding:.875rem 1rem}.settings-section-title{font-size:.8125rem}.settings-section-content{padding:1rem}}.dept-list-desktop{display:flex;flex-direction:column;gap:.5rem}.dept-list-mobile{display:none}.dept-card{background-color:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:1rem;margin-bottom:.75rem}.dept-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem;margin-bottom:.75rem}.dept-card-title{font-weight:600;font-size:.9375rem;color:var(--text-primary)}.dept-card-meta{font-size:.8125rem;color:var(--text-secondary);margin-top:.25rem}.dept-card-actions{display:flex;gap:.5rem;flex-shrink:0}.dept-card-members{border-top:1px solid var(--border);padding-top:.75rem}.dept-card-members-header{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.dept-member-chip{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .625rem;background-color:var(--background);border-radius:9999px;font-size:.8125rem;color:var(--text-primary);margin:0 .375rem .375rem 0}.dept-member-remove{background:none;border:none;cursor:pointer;padding:2px;color:var(--text-muted);display:inline-flex;align-items:center;justify-content:center;border-radius:50%}.dept-card-add{display:flex;gap:.5rem;margin-top:.75rem}@media(max-width:768px){.dept-list-desktop{display:none}.dept-list-mobile{display:block}}@media(max-width:768px){.form-row{flex-direction:column;gap:.75rem}.form-col{width:100%}.form-select,.form-input{width:100%;min-height:44px;font-size:16px}.form-label{font-size:.8125rem;margin-bottom:.375rem}}@media(max-width:768px){.info-field-row{flex-direction:column;align-items:flex-start;gap:.25rem;padding:.625rem 0}.info-field-label{font-size:.8125rem;color:var(--text-muted)}.info-field-value{font-size:.9375rem}}.settings-actions{display:flex;gap:.75rem;margin-top:1rem}@media(max-width:768px){.settings-actions{flex-direction:column;gap:.5rem;position:sticky;bottom:0;background-color:var(--surface);padding:1rem 0;margin-top:0;border-top:1px solid var(--border)}.settings-actions button{width:100%;min-height:48px}}.invitations-table-wrapper{overflow-x:auto}.invitations-table{width:100%;border-collapse:collapse;font-size:.875rem}.invitations-table th,.invitations-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--border)}.invitations-table th{color:var(--text-muted);font-weight:500}.invitation-qr-btn{background:none;border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);cursor:pointer;padding:4px 10px;font-size:.8rem;display:inline-flex;align-items:center;gap:4px;transition:all .2s}.invitation-qr-btn:hover{background-color:var(--background);border-color:var(--primary)}.invitation-accepted-label{color:var(--text-muted);font-size:.8rem;display:inline-flex;align-items:center;gap:4px}.invitations-cards-mobile{display:none}.invitation-card{background-color:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:1rem;margin-bottom:.75rem}.invitation-card:last-child{margin-bottom:0}.invitation-card-header{margin-bottom:.75rem}.invitation-card-main{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem;margin-bottom:.25rem}.invitation-card-name{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.invitation-card-role{font-size:.8125rem;color:var(--text-secondary)}.invitation-card-meta{display:flex;gap:1rem;margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.invitation-card-meta-item{display:flex;align-items:center;gap:.375rem;font-size:.8125rem;color:var(--text-muted)}.invitation-card-token-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.invitation-card-token{font-family:SF Mono,Monaco,monospace;font-size:1.125rem;font-weight:700;letter-spacing:.15em;color:var(--primary);background-color:var(--background);padding:.5rem .75rem;border-radius:6px}.invitation-card-qr-btn{background-color:var(--primary);border:none;border-radius:8px;color:#fff;cursor:pointer;padding:.625rem 1rem;font-size:.875rem;font-weight:500;display:inline-flex;align-items:center;gap:.5rem;transition:background-color .2s}.invitation-card-qr-btn:hover{background-color:var(--primary-hover)}.qr-popup-content{max-width:380px;width:90vw}.qr-popup-body{display:flex;flex-direction:column;align-items:center;gap:1rem}.qr-token-display{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center}.qr-token-digit{width:44px;height:52px;background:var(--surface);border:2px solid var(--primary);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;font-weight:700;color:var(--text-primary)}.qr-url-box{width:100%;background:var(--background);border:1px solid var(--border);border-radius:6px;padding:.5rem .75rem;word-break:break-all}.qr-url-box span{font-size:.75rem;color:var(--primary)}.qr-popup-footer{gap:.5rem}.qr-popup-footer .btn{flex:1}@media(max-width:768px){.invitations-table-wrapper{display:none!important}.invitations-cards-mobile{display:block}.qr-popup-content{max-width:100%;width:calc(100% - 2rem);margin:1rem}.qr-token-digit{width:40px;height:48px;font-size:1.25rem}.qr-popup-footer{flex-direction:column}.qr-popup-footer .btn{width:100%}.invitation-card-token{font-size:1rem;letter-spacing:.1em;padding:.375rem .625rem}.invitation-card-qr-btn span{display:none}.invitation-card-qr-btn{padding:.625rem;min-width:44px;min-height:44px;justify-content:center}}.btn-text-short{display:none}@media(max-width:768px){.btn-text-full{display:none}.btn-text-short{display:inline}.btn-mobile-icon .mobile-icon-only{margin-right:0!important}}.empty-state{text-align:center;padding:3rem 2rem;color:var(--text-muted)}.empty-state p:first-of-type{font-size:1rem;margin:0}.empty-state p:last-of-type{font-size:.875rem;margin-top:.5rem;color:var(--text-secondary)}@media(max-width:768px){.empty-state{padding:2rem 1rem}}.reports-page{padding:2rem}@media(max-width:768px){.reports-page{padding:1rem;padding-bottom:calc(4rem + env(safe-area-inset-bottom))}}.reports-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.reports-title{font-size:1.75rem;font-weight:600;margin:0}@media(max-width:768px){.reports-header{flex-wrap:wrap;gap:1rem}.reports-title{font-size:1.25rem}}.report-type-selector{display:flex;gap:.5rem;margin-bottom:1.5rem;flex-wrap:wrap}.report-type-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:var(--radius-sm);cursor:pointer;font-size:.875rem;font-weight:500;background-color:var(--background);color:var(--text-primary);border:1px solid var(--border);transition:all .2s}.report-type-btn:hover{background-color:var(--border)}.report-type-btn.active{background-color:var(--primary);color:#fff;border-color:var(--primary)}.report-type-short-label{display:none}@media(max-width:768px){.report-type-selector{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.5rem}.report-type-btn{justify-content:center;padding:.625rem}.report-type-label{display:none}.report-type-short-label{display:inline}}.report-filters-section{background-color:var(--surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border:1px solid var(--border);margin-bottom:1.5rem;overflow:hidden}.report-filters-header{display:none;align-items:center;justify-content:space-between;padding:1rem;cursor:pointer;-webkit-user-select:none;user-select:none;background-color:var(--background)}.report-filters-header:hover{background-color:#2d004008}.report-filters-title{margin:0;font-size:1rem;font-weight:600}.report-filters-icon{color:var(--text-muted);transition:transform .2s}.report-filters-section.expanded .report-filters-icon{transform:rotate(180deg)}.report-filters-content{padding:1.5rem}@media(max-width:768px){.report-filters-header{display:flex}.report-filters-content{display:none;padding:1rem}.report-filters-section.expanded .report-filters-content{display:block}.report-filters-section:not(.expanded){margin-bottom:1rem}}.report-generate-btn{margin-top:1rem;padding:.75rem 1.5rem;background-color:var(--success);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;width:100%}.report-generate-btn:hover:not(:disabled){background-color:#16a34a}.report-generate-btn:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.report-generate-btn{position:sticky;bottom:calc(1rem + env(safe-area-inset-bottom));z-index:10;box-shadow:0 4px 12px #00000026}}.report-result{margin-top:2rem}@media(max-width:768px){.report-result{margin-top:1.5rem}}.report-container{display:flex;flex-direction:column;gap:1.5rem}.report-header-card{padding:1.5rem}.report-header-content{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;gap:1rem}.report-header-content.employee{align-items:center}.report-header-main{flex:1;min-width:0}.report-project-name{margin:0;font-size:1.5rem;font-weight:600;word-break:break-word}.report-project-period{margin:.5rem 0 0;color:var(--text-muted);font-size:.875rem}.report-status-badge{padding:4px 12px;border-radius:12px;font-size:.875rem;font-weight:500;white-space:nowrap;flex-shrink:0}.report-status-badge.active{background-color:#22c55e1a;color:#22c55e}.report-status-badge:not(.active){background-color:#6b72801a;color:#6b7280}.report-rate-box{text-align:right;flex-shrink:0}.report-rate-label{font-size:.875rem;color:var(--text-muted)}.report-rate-value{font-size:1.25rem;font-weight:600;color:var(--primary)}@media(max-width:768px){.report-header-card{padding:1rem}.report-header-content{flex-direction:column;align-items:flex-start}.report-header-content.employee{align-items:flex-start}.report-project-name{font-size:1.25rem}.report-rate-box{text-align:left;width:100%;padding-top:.75rem;border-top:1px solid var(--border)}.report-status-badge{order:-1}}.report-budget-section{margin-top:1.5rem}.report-budget-header{display:flex;justify-content:space-between;margin-bottom:.5rem;flex-wrap:wrap;gap:.5rem}.report-budget-label{font-size:.875rem;color:var(--text-muted)}.report-budget-value{font-size:.875rem;font-weight:500}.report-progress-bar{width:100%;height:8px;background-color:var(--background);border-radius:4px;overflow:hidden}.report-progress-fill{height:100%;border-radius:4px;transition:width .3s ease}.report-progress-fill.success{background-color:#22c55e}.report-progress-fill.warning{background-color:#f59e0b}.report-progress-fill.over{background-color:#ef4444}.report-budget-footer{display:flex;justify-content:space-between;margin-top:.5rem;font-size:.75rem;color:var(--text-muted)}.report-budget-remaining.over{color:#ef4444}.report-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.report-stats-grid.four-cols{grid-template-columns:repeat(4,1fr)}.report-stat-card{padding:1.5rem;text-align:center}.report-stat-value{font-size:2rem;font-weight:700;color:var(--primary)}.report-stat-label{font-size:.875rem;color:var(--text-muted);margin-top:.25rem}@media(max-width:768px){.report-stats-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.report-stats-grid.four-cols{grid-template-columns:repeat(2,1fr)}.report-stat-card{padding:1rem}.report-stat-value{font-size:1.5rem}.report-stat-label{font-size:.75rem}}.report-table-card{padding:1.5rem}.report-section-title{margin:0 0 1rem;font-size:1.125rem;font-weight:600}.report-empty-state{text-align:center;padding:2rem;color:var(--text-muted)}.report-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.report-table{width:100%;border-collapse:collapse;font-size:.875rem}.report-table th,.report-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--border)}.report-table th{color:var(--text-muted);font-weight:500}.report-table th.numeric,.report-table td.numeric{text-align:right}.report-table td.employee-name,.report-table td.project-name{font-weight:500}.report-table td.employee-position,.report-table td.project-period{color:var(--text-secondary)}.report-table td.hours,.report-table td.cost{font-weight:500}.report-table td.cost{color:var(--primary)}.report-table tfoot td{background-color:var(--background);font-weight:600}.report-table .total-label,.report-table .total-hours,.report-table .total-cost{text-align:right}.report-table .total-cost{color:var(--primary)}.report-cards-mobile{display:none}.report-employee-cards,.report-project-cards{display:flex;flex-direction:column;gap:.75rem}.report-employee-card,.report-project-card{padding:1rem}.report-employee-card-header,.report-project-card-header{margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.report-employee-name,.report-project-card-name{margin:0 0 .25rem;font-size:1rem;font-weight:600}.report-employee-position,.report-project-card-period{font-size:.8125rem;color:var(--text-secondary)}.report-employee-card-stats,.report-project-card-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.report-employee-stat,.report-project-stat{display:flex;flex-direction:column;gap:.25rem}.report-employee-stat .stat-label,.report-project-stat .stat-label{font-size:.75rem;color:var(--text-muted)}.report-employee-stat .stat-value,.report-project-stat .stat-value{font-size:.9375rem;font-weight:500}.report-employee-stat .stat-value.hours,.report-project-stat .stat-value.hours{color:var(--text-primary)}.report-employee-stat .stat-value.cost,.report-project-stat .stat-value.cost{color:var(--primary);font-weight:600}.report-total-card{padding:1rem;background-color:var(--background);border:2px solid var(--primary)}.report-total-row{display:flex;justify-content:space-between;align-items:center}.report-total-row .total-label{font-weight:600;font-size:1rem}.total-values{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem}.total-hours{font-weight:500;font-size:.875rem}.total-cost{font-weight:600;font-size:1.125rem;color:var(--primary)}@media(max-width:768px){.report-table-card.hide-mobile{display:none}.report-cards-mobile{display:block}.report-employee-card-stats,.report-project-card-stats{grid-template-columns:repeat(3,1fr)}}.summary-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.75rem}.summary-view-toggle{display:flex;gap:.5rem;background:var(--background);padding:4px;border-radius:8px}.summary-view-toggle button{padding:6px 16px;border-radius:6px;border:none;cursor:pointer;font-size:.875rem;font-weight:500;background-color:transparent;color:var(--text-muted);transition:all .2s}.summary-view-toggle button.active{background-color:var(--surface);color:var(--primary);box-shadow:var(--shadow-sm)}.report-matrix-card{padding:0;overflow:hidden}.report-matrix-wrapper{overflow:auto;max-height:600px;-webkit-overflow-scrolling:touch}.report-matrix-table{width:100%;border-collapse:collapse;font-size:.8125rem}.report-matrix-table th,.report-matrix-table td{padding:.75rem;text-align:center;border-bottom:1px solid var(--border)}.report-matrix-table th{font-weight:600;background-color:var(--background);position:sticky;top:0;z-index:10}.report-matrix-table th.sticky-col,.report-matrix-table td.sticky-col{position:sticky;left:0;background-color:var(--background);z-index:20;text-align:left;min-width:150px}.report-matrix-table td.sticky-col{background-color:var(--surface);border-right:1px solid var(--border)}.report-matrix-table th.total-col,.report-matrix-table td.total-col{background-color:var(--surface);font-weight:600;min-width:100px}.report-matrix-table td.total-col.grand-total{color:var(--primary);font-size:1rem}.report-matrix-table .employee-name,.report-matrix-table .matrix-cell.has-value{font-weight:500}.report-matrix-table .empty-cell{color:var(--border)}.report-matrix-table tfoot td{background-color:var(--background);font-weight:600;position:sticky;bottom:0;z-index:10}.report-matrix-table tfoot td.sticky-col{z-index:20}.summary-employee-card{padding:1rem}.summary-employee-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid var(--border);flex-wrap:wrap;gap:.5rem}.summary-employee-name{margin:0;font-size:1rem;font-weight:600}.summary-employee-total{display:flex;align-items:center;gap:.5rem}.summary-employee-total .total-label{font-size:.75rem;color:var(--text-muted)}.summary-employee-total .total-value{font-weight:600;color:var(--primary)}.summary-projects-list{display:flex;flex-direction:column;gap:.5rem}.summary-project-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem;background-color:var(--background);border-radius:6px}.summary-project-item .project-name{font-size:.875rem;color:var(--text-secondary)}.summary-project-item .project-value{font-size:.875rem;font-weight:500;color:var(--text-primary)}.summary-grand-total-card{padding:1rem;background-color:var(--primary);color:#fff}.summary-grand-total-row{display:flex;justify-content:space-between;align-items:center}.grand-total-label{font-size:1rem;font-weight:600}.grand-total-value{font-size:1.25rem;font-weight:700}@media(max-width:768px){.summary-header{flex-direction:column;align-items:flex-start}.summary-view-toggle{width:100%}.summary-view-toggle button{flex:1}.report-matrix-card.hide-mobile{display:none}}.date-range-picker{display:flex;flex-direction:column;gap:.75rem}.date-range-presets-desktop{display:flex;flex-wrap:wrap;gap:.5rem}.date-range-preset-btn{padding:.375rem .75rem;font-size:.75rem;background-color:var(--background);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary);transition:all .2s;white-space:nowrap}.date-range-preset-btn:hover{background-color:var(--border)}.date-range-preset-btn.active{background-color:var(--primary);border-color:var(--primary);color:#fff}.date-range-presets-mobile{display:none}.date-range-preset-select-wrapper{position:relative;width:100%}.date-range-preset-select{width:100%;padding:.75rem 2.5rem .75rem 1rem;font-size:.9375rem;font-weight:500;border:1.5px solid var(--border);border-radius:var(--radius-md);background-color:var(--surface);color:var(--text-primary);cursor:pointer;outline:none;min-height:48px;appearance:none;-webkit-appearance:none;-moz-appearance:none;transition:all .2s ease}.date-range-preset-select:hover{border-color:var(--primary);background-color:#2d004005}.date-range-preset-select:focus{border-color:var(--primary);box-shadow:0 0 0 4px #2d004014}.date-range-preset-select-wrapper:after{content:"";position:absolute;right:1rem;top:50%;transform:translateY(-50%);width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top:5px solid var(--primary);pointer-events:none}.date-range-preset-select option{padding:.75rem;font-size:.9375rem}.date-range-inputs{display:flex;gap:1rem}.date-range-field{flex:1 1 140px}.date-range-label{display:block;font-size:.75rem;color:var(--text-muted);margin-bottom:.25rem}.date-range-input{padding:.5rem .75rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.875rem;color:var(--text-primary);background-color:var(--surface);font-family:inherit;outline:none;transition:border-color .2s,box-shadow .2s;width:100%}.date-range-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2d00401a}@media(max-width:768px){.date-range-presets-desktop{display:none}.date-range-presets-mobile{display:block}.date-range-inputs{gap:.75rem}.date-range-input{font-size:16px;padding:.625rem .75rem;min-height:44px}}@media(max-width:768px){.auth-page-container{padding:1rem .75rem .75rem!important;align-items:flex-start!important;min-height:100svh!important}.auth-card{max-width:100%!important;width:100%!important;margin:0!important}.auth-card .card-body{padding:1.25rem!important}.birth-date-grid{grid-template-columns:1fr!important;gap:.75rem!important}.birth-date-grid select{min-height:48px;font-size:16px;padding:.75rem!important}.dept-selection-mobile{max-height:250px!important}.dept-selection-mobile label{padding:.5rem 0;min-height:44px}.auth-form input,.auth-form select,.auth-form button{min-height:48px}.auth-form input[type=text],.auth-form input[type=email],.auth-form input[type=password]{font-size:16px}.invite-code-inputs{gap:.75rem!important}.invite-code-inputs input{width:56px!important;height:64px!important;font-size:1.75rem!important}.auth-submit-sticky{position:sticky;bottom:.75rem;z-index:10;background:var(--surface);margin:0 -1.25rem -1.25rem;padding:.75rem 1.25rem;box-shadow:0 -4px 12px #00000014}.auth-header-mobile h1{font-size:1.375rem!important}.auth-header-mobile .auth-logo{width:44px!important;height:44px!important;margin-bottom:.75rem!important}.auth-header-mobile .auth-logo span{font-size:1rem!important}}@media(max-width:380px){.auth-card .card-body{padding:1rem!important}.invite-code-inputs{gap:.5rem!important}.invite-code-inputs input{width:48px!important;height:56px!important;font-size:1.5rem!important}}input[type=date]{-webkit-appearance:none;-moz-appearance:none;appearance:none;min-height:44px}input[type=date]::-webkit-date-and-time-value{text-align:left}@media(max-width:640px){input[type=date]{font-size:16px;max-width:100%}}.form-select{width:100%;display:block;font-family:inherit;font-size:.875rem;margin:0;box-sizing:border-box;padding:.625rem 2.5rem .625rem .875rem;height:2.75rem;line-height:1.25rem;border:1px solid var(--border);border-radius:var(--radius-sm);background-color:var(--surface);color:var(--text-primary);appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b6b80' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:1rem;cursor:pointer;transition:border-color .2s,box-shadow .2s;outline:none}.form-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2d00401a}.form-select:hover{border-color:var(--primary-light, #4a0d6b)}.form-select[multiple]{height:auto;min-height:8rem;padding:.5rem;background-image:none}.form-input{width:100%;padding:.625rem .75rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.875rem;font-family:inherit;color:var(--text-primary);background-color:var(--surface);outline:none;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2d00401a}.form-select.error,.form-input.error{border-color:var(--danger)}.form-select.error:focus,.form-input.error:focus{box-shadow:0 0 0 3px #ef44441a}.form-label{display:block;margin-bottom:.5rem;font-weight:500;font-size:.875rem;color:var(--text-primary)}.form-hint{font-size:.75rem;color:var(--text-muted);margin-left:.5rem}.form-select:disabled,.form-input:disabled{opacity:.6;cursor:not-allowed;background-color:var(--background)}.form-field-wrap{margin-bottom:1.25rem}.form-error{font-size:.75rem;color:var(--danger);margin-top:.25rem;display:block}.form-select.has-icon{padding-left:2.5rem}
