.login-container{display:flex;min-height:100vh;font-family:Inter,system-ui,-apple-system,sans-serif;background-color:#f8fafc}.login-presentation{flex:1;background:linear-gradient(135deg,#1e3a8a,#3b82f6);color:#fff;display:flex;flex-direction:column;justify-content:flex-start;padding:15vh 4rem 4rem 4rem;position:relative}.login-presentation:before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 10% 20%,rgba(255,255,255,.1) 0%,transparent 20%),radial-gradient(circle at 90% 80%,rgba(255,255,255,.1) 0%,transparent 20%);pointer-events:none}.brand-wrapper{margin-bottom:2rem;animation:fadeInDown .8s ease-out}.brand-logo{font-size:3.5rem;font-weight:800;color:#fff;display:inline-block;white-space:nowrap;line-height:1.2;margin:0}.brand-tagline{font-size:1.5rem;font-weight:300;color:#dbeafe;margin-top:3rem;line-height:1.4;max-width:600px}.features-list{display:grid;gap:1.5rem;margin-top:3rem;animation:fadeInUp .8s ease-out .2s backwards}.feature-item{display:flex;align-items:center;gap:1rem;font-size:1.1rem;color:#eff6ff}.feature-icon-wrapper{background:#fff3;padding:.75rem;border-radius:12px;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.login-form-wrapper{width:500px;display:flex;align-items:center;justify-content:center;background-color:#fff;padding:2rem;box-shadow:-10px 0 30px #0000000d;z-index:10}.login-card-content{width:100%;max-width:360px;animation:fadeIn 1s ease-out}.login-header-text{margin-bottom:2.5rem;text-align:left}.login-welcome{font-size:1.75rem;font-weight:700;color:#1e293b;margin:0 0 .5rem;line-height:1.2;display:block}.login-instruction{color:#64748b;font-size:.95rem}.form-field{margin-bottom:1.5rem}.field-label{display:block;font-size:.9rem;font-weight:600;color:#334155;margin-bottom:.5rem}.field-input{width:100%;padding:.875rem 1rem;background-color:#f1f5f9;border:1px solid #cbd5e1;border-radius:8px;font-size:1rem;color:#1e293b;transition:all .2s}.field-input:focus{outline:none;border-color:#2563eb;background-color:#fff;box-shadow:0 0 0 3px #2563eb1a}.submit-btn{width:100%;padding:.875rem;background-color:#2563eb;color:#fff;font-weight:600;border:none;border-radius:8px;font-size:1rem;cursor:pointer;transition:all .2s;margin-top:1rem}.submit-btn:hover{background-color:#1d4ed8;transform:translateY(-1px);box-shadow:0 4px 12px #2563eb33}.submit-btn:active{transform:translateY(0)}.submit-btn:disabled{background-color:#94a3b8;cursor:not-allowed;transform:none}.forgot-link{display:block;text-align:right;margin-top:.5rem;font-size:.85rem;color:#2563eb;text-decoration:none;cursor:pointer;background:none;border:none;padding:0}.forgot-link:hover{text-decoration:underline}.error-banner{background-color:#fef2f2;border-left:4px solid #ef4444;color:#b91c1c;padding:1rem;border-radius:4px;margin-bottom:1.5rem;font-size:.9rem;display:flex;align-items:center;gap:.5rem}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media(max-width:960px){.login-container{flex-direction:column}.login-presentation{padding:3rem 2rem;flex:0 0 auto;min-height:300px}.brand-logo{font-size:2.5rem}.brand-tagline{font-size:1.2rem}.features-list{display:none}.login-form-wrapper{width:100%;flex:1;padding:2rem;box-shadow:none;border-radius:20px 20px 0 0;margin-top:-20px}}.dashboard-container{padding:2rem;max-width:1200px;margin:0 auto;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;animation:fadeIn .5s ease-in-out}@media(max-width:768px){.dashboard-container{padding:.5rem 1rem 2rem}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.dashboard-header{margin-bottom:2rem}.dashboard-title{font-size:1.8rem;font-weight:700;color:var(--text-color);margin-bottom:.5rem}.dashboard-subtitle{color:var(--text-secondary);font-size:1rem}.dashboard-grid{display:grid;grid-template-columns:repeat(1,1fr);gap:1.5rem;margin-bottom:2rem}@media(min-width:768px){.dashboard-grid{grid-template-columns:repeat(3,1fr)}}.manager-grid{display:grid;grid-template-columns:repeat(1,1fr);gap:1.5rem}@media(min-width:768px){.manager-grid{grid-template-columns:repeat(2,1fr)}}.dashboard-card{background-color:var(--surface-color);border-radius:12px;padding:1.5rem;box-shadow:0 1px 3px #0000001a;border:1px solid var(--border-color);display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s}.dashboard-card:hover{transform:translateY(-2px);box-shadow:0 4px 6px #0000001a}.card-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);margin-bottom:.5rem;font-weight:600}.balance-card{align-items:center;justify-content:center;text-align:center}.balance-value{font-size:2.5rem;font-weight:800;color:var(--primary-color);line-height:1}.balance-unit{font-size:1rem;color:var(--text-secondary);font-weight:400;margin-left:.25rem}.balance-year{font-size:.875rem;color:var(--text-secondary);margin-top:.5rem}.vacation-date{font-size:1.5rem;font-weight:700;color:var(--text-color)}.status-badge{margin-top:.25rem;font-size:.875rem;color:#10b981;font-weight:500}.no-vacation{color:var(--text-secondary);font-style:italic}.status-list{display:flex;flex-direction:column;gap:.75rem;width:100%}.status-item{display:flex;justify-content:space-between;align-items:center}.status-label{display:flex;align-items:center;gap:.5rem;font-size:.95rem;color:var(--text-color)}.status-dot{width:8px;height:8px;border-radius:50%}.dot-yellow{background-color:#facc15}.dot-green{background-color:#10b981}.dot-red{background-color:#f87171}.status-count{font-weight:700;color:var(--text-color)}.manager-section{padding-top:0}.section-title{font-size:1.25rem;font-weight:600;color:var(--text-color);margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.action-card{background:var(--surface-color);border-color:var(--primary-light);cursor:pointer;position:relative;overflow:hidden}.action-card-content{position:relative;z-index:10}.action-label{color:var(--primary-color);font-weight:700;font-size:.75rem;text-transform:uppercase;margin-bottom:.25rem}.action-value{font-size:3rem;font-weight:800;color:var(--text-color);line-height:1;margin-bottom:.5rem}.action-desc{color:var(--text-secondary);font-size:.95rem}.action-link{margin-top:1rem;color:var(--primary-color);font-weight:600;font-size:.875rem}.action-icon-bg{position:absolute;right:-1rem;top:-1rem;color:var(--primary-color);opacity:.1;transform:rotate(15deg)}.team-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.team-member{display:flex;align-items:center;gap:.75rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color)}.team-member:last-child{border-bottom:none}.member-avatar{width:32px;height:32px;border-radius:50%;background-color:var(--primary-light);color:var(--primary-color);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.75rem}.member-info{flex:1}.member-name{font-size:.9rem;font-weight:600;color:var(--text-color)}.member-id{font-size:.75rem;color:var(--text-secondary)}.empty-state{display:flex;align-items:center;justify-content:center;padding:2rem;color:var(--text-secondary);font-size:.9rem}.status-item.warning{background-color:var(--warning-light-bg, #fffbeb);border:1px solid var(--warning-color);padding:.75rem;border-radius:6px}[data-theme=dark] .status-item.warning{background-color:#f59e0b1a;border-color:#f59e0b4d}.status-item.info{background-color:var(--info-light-bg, #eff6ff);border:1px solid var(--primary-light);padding:.75rem;border-radius:6px}[data-theme=dark] .status-item.info{background-color:transparent;border:none}.status-label.warning{color:var(--warning-text, #92400e)}[data-theme=dark] .status-label.warning{color:var(--warning-color)}.status-label.info{color:var(--primary-dark, #1e40af)}[data-theme=dark] .status-label.info{color:var(--text-color)}.critical-alert{background-color:var(--danger-light);border-left:4px solid var(--danger-color)}[data-theme=dark] .critical-alert{background-color:#ef44441a}.annual-calendar-container{background:transparent;padding:0;width:100%;height:100%;display:flex;flex-direction:column;overflow:hidden}.annual-calendar-header{display:flex;justify-content:flex-end;align-items:center;margin-bottom:.5rem;flex-shrink:0}.year-selector{display:flex;align-items:center;gap:.5rem}.year-selector button{background:var(--surface-color);border:1px solid var(--border-color);border-radius:4px;padding:.1rem .5rem;cursor:pointer;font-weight:500;font-size:.8rem;color:var(--text-color)}.year-selector button:hover{background-color:var(--hover-bg)}.year-dropdown{font-size:1.5rem;font-weight:700;padding:.25rem 1rem;border:1px solid var(--border-color);border-radius:.5rem;background-color:var(--surface-color);color:var(--text-color);cursor:pointer;outline:none}.year-display{font-size:1rem;font-weight:600;min-width:60px;text-align:center}.months-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(3,1fr);gap:.75rem;flex-grow:1;min-height:0}@media(max-width:1000px){.months-grid{grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(4,1fr);overflow-y:auto}}@media(max-width:768px){.annual-calendar-container{height:auto;overflow-y:auto}.months-grid{grid-template-columns:1fr;grid-template-rows:auto;display:flex;flex-direction:column;gap:1.5rem;overflow-y:visible}.month-container{min-height:250px}.day-cell{min-height:30px;font-size:.9rem}}.month-container{background:var(--surface-color);border:1px solid var(--border-color);border-radius:4px;padding:.25rem;box-shadow:0 1px 2px #0000000d;display:flex;flex-direction:column;max-width:100%}.month-title{text-align:center;font-weight:600;margin-bottom:.25rem;color:var(--text-color);text-transform:capitalize;font-size:.8rem;flex-shrink:0}.days-grid{display:grid;grid-template-columns:repeat(7,1fr);grid-template-rows:repeat(7,1fr);gap:0;text-align:center;font-size:.65rem;flex-grow:1;height:100%}.day-header{color:var(--text-secondary);font-size:.6rem;font-weight:600;display:flex;align-items:center;justify-content:center}.day-cell{width:100%;height:100%;display:flex;align-items:center;justify-content:center;border-radius:1px;cursor:default;border:1px solid transparent;color:var(--text-color)}.day-cell:hover{background-color:var(--hover-bg)}.day-cell.weekend{color:var(--text-secondary);background-color:var(--background-color)}.day-cell.holiday{background-color:#e0f7ff;color:#1e3a8a}.day-cell.type-1{background-color:#fef08a;color:#854d0e}.day-cell.type-2{background-color:#fbcfe8;color:#9d174d}.day-cell.taken{text-decoration:line-through;opacity:.7}.legend{display:flex;gap:1rem;margin-top:.5rem;justify-content:center;font-size:.75rem;color:var(--text-secondary);background:var(--surface-color);padding:.25rem .75rem;border-radius:4px;width:fit-content;margin-left:auto;margin-right:auto;flex-shrink:0}.legend-item{display:flex;align-items:center;gap:.25rem}.legend-color{width:.75rem;height:.75rem;border-radius:2px}.day-cell.pending-change{border:2px solid #22c55e!important;position:relative;z-index:1}.day-cell.pending-change.pending-clear{border:2px solid #ef4444!important}.annual-calendar-container.auto-height{height:auto!important;overflow:visible!important;display:block!important}.annual-calendar-container.auto-height .months-grid{overflow:visible!important;height:auto!important;display:flex!important;flex-wrap:wrap!important;justify-content:center!important;gap:.25rem!important}.annual-calendar-container.auto-height .month-container{width:24%;min-width:200px;margin-bottom:.25rem;padding:.1rem;border:none;box-shadow:none}.annual-calendar-container.auto-height .month-title{font-size:.75rem;margin-bottom:.1rem;padding-top:.1rem}.annual-calendar-container.auto-height .days-grid{font-size:.55rem;gap:0}.annual-calendar-container.auto-height .day-cell{height:1.1rem}.day-cell.disabled-date{background-color:var(--hover-bg);color:var(--text-secondary);cursor:not-allowed;opacity:.6}.day-cell.disabled-date:hover{background-color:var(--hover-bg);border-color:var(--hover-bg);transform:none;box-shadow:none}.vacation-summary{background-color:var(--surface-color);padding:.25rem 1rem;border-radius:6px;margin-bottom:.5rem;box-shadow:0 1px 2px #0000000d;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;min-height:32px;font-size:.85rem;border:1px solid var(--border-color)}.vacation-summary.is-editing{border-radius:6px 6px 0 0;margin-bottom:0;border-bottom:none}.summary-stats{display:flex;gap:2rem;font-size:.9rem;font-weight:500;color:var(--text-color)}.stat-item{display:flex;align-items:center}.stat-label{color:var(--text-secondary)}.stat-value{margin-left:.5rem;font-weight:600;color:var(--text-color)}.year-blocked-badge{background-color:var(--danger-light);color:var(--danger-text);padding:.1rem .5rem;border-radius:4px;font-size:.75rem;font-weight:700;border:1px solid var(--danger-color)}[data-theme=dark] .year-blocked-badge{background-color:#ef44441a;border-color:#ef44444d}.status-alert{padding:.1rem .5rem;border-radius:4px;font-size:.75rem;font-weight:700;border:1px solid transparent}.status-alert.submitted{background-color:var(--success-light);color:var(--success-text);border-color:var(--success-color)}[data-theme=dark] .status-alert.submitted{background-color:#10b9811a;border-color:#10b9814d}.status-alert.pending{background-color:var(--warning-light-bg);color:var(--warning-text);border-color:var(--warning-color)}[data-theme=dark] .status-alert.pending{background-color:#f59e0b1a;border-color:#f59e0b4d}.actions-group{display:flex;gap:.5rem}.vacation-summary .btn-vacation{border:none;padding:.2rem .7rem;border-radius:4px;cursor:pointer;font-weight:500;color:#fff;transition:background-color .2s;font-size:.85rem;line-height:1.2}@media(max-width:768px){.vacation-summary{flex-direction:column;align-items:stretch;padding:1rem;gap:1rem}.summary-stats{display:grid;grid-template-columns:1fr 1fr;gap:1rem;width:100%}.stat-item{flex-direction:column;align-items:flex-start;background-color:#00000005;padding:.5rem;border-radius:4px}.stat-value{margin-left:0;font-size:1.1rem;margin-top:.2rem}.stat-label{font-size:.75rem}.actions-group{width:100%}.vacation-summary .btn-vacation{width:100%;padding:.5rem}}.vacation-summary .btn-vacation.btn-secondary{background-color:#6b7280;color:#fff}.vacation-summary .btn-vacation.btn-secondary:hover{background-color:#4b5563}@media print{.vacation-summary{visibility:visible!important;display:flex!important;flex-direction:row!important;justify-content:space-between!important;align-items:center!important;border:1px solid #000!important;background-color:#fff!important;color:#000!important;box-shadow:none!important;margin-bottom:20px!important}.vacation-summary *{visibility:visible!important}.summary-stats{display:flex!important;gap:2rem!important}.stat-item,.stat-label,.stat-value{color:#000!important}.actions-group,.btn-vacation{display:none!important}}.vacation-toolbar{background-color:var(--hover-bg);padding:.5rem 1rem;border-radius:0 0 6px 6px;margin-bottom:.5rem;display:flex;justify-content:space-between;align-items:center;width:100%;box-sizing:border-box;box-shadow:0 1px 2px #0000000d}.toolbar-left,.toolbar-right{display:flex;gap:1rem;align-items:center}.btn-vacation{border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-weight:500;color:#fff;transition:background-color .2s}.btn-primary{background-color:var(--primary-color)}.btn-primary:hover{background-color:var(--secondary-color)}.btn-success{background-color:var(--success-color)}.btn-success:hover{opacity:.9}.btn-danger{background-color:var(--danger-color)}.btn-danger:hover{background-color:#dc2626}.tool-button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:4px;background-color:var(--surface-color);cursor:pointer;font-weight:500;border:1px solid var(--border-color);color:var(--text-color);transition:all .2s}.tool-button:hover{background-color:var(--hover-bg)}.tool-button.selected{border:2px solid var(--primary-color);background-color:var(--primary-light);color:var(--primary-dark)}[data-theme=dark] .tool-button.selected{background-color:#3b82f633;color:var(--primary-color)}.color-indicator{width:1rem;height:1rem;border-radius:2px}.color-indicator.day{background-color:#fef08a}.color-indicator.half{background-color:#fbcfe8}@media(max-width:768px){.vacation-toolbar{flex-direction:column;align-items:stretch;gap:1rem}.toolbar-left,.toolbar-right{width:100%;justify-content:space-between}.tool-button,.btn-vacation{flex:1;justify-content:center;text-align:center}}.approval-modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.approval-modal-container{background-color:var(--surface-color);border-radius:8px;width:90%;max-width:1200px;max-height:90%;display:flex;flex-direction:column;overflow:hidden;color:var(--text-color);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.approval-modal-header{padding:.75rem;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.approval-modal-title{font-size:1.1rem;font-weight:700;color:var(--text-color)}.header-actions{display:flex;align-items:center;gap:1.5rem}.toggle-sidebar-btn{display:flex;align-items:center;gap:.5rem;background:transparent;border:none;cursor:pointer;color:var(--text-secondary);font-size:.9rem;padding:.25rem .5rem;border-radius:4px;transition:background-color .2s,color .2s}.toggle-sidebar-btn:hover{background-color:var(--hover-bg);color:var(--text-color)}.toggle-text{font-weight:500}.toggle-badge{background-color:var(--danger-color);color:#fff;font-size:.75rem;font-weight:700;border-radius:12px;padding:0 6px;min-width:18px;height:18px;display:flex;align-items:center;justify-content:center;line-height:1}.approval-modal-body{flex:1;overflow-y:auto;padding:0;display:flex;flex-direction:column}.approval-modal-body-layout{display:flex;flex:1;overflow:hidden;gap:0}.approval-modal-main{flex:1;padding:.75rem;overflow-y:auto;display:flex;flex-direction:column;gap:.5rem}.approval-modal-sidebar{width:280px;background-color:var(--hover-bg);border-left:1px solid var(--border-color);padding:1rem;overflow-y:auto;display:flex;flex-direction:column}.sidebar-title{font-size:1rem;font-weight:600;margin-bottom:1rem;color:var(--text-color)}.changes-list{display:flex;flex-direction:column;gap:.25rem}.change-item{background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:6px;padding:.25rem;font-size:.85rem;border-left-width:4px;display:flex;align-items:center;gap:.5rem}.border-green{border-left-color:var(--success-color)}.border-red{border-left-color:var(--danger-color)}.change-date{font-weight:600;color:var(--text-color);font-size:.8rem;white-space:nowrap}.separator{color:var(--text-secondary);font-weight:700}.change-desc{font-size:.85rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.desc-add{color:var(--success-color)}.desc-remove{color:var(--danger-color)}.no-changes{color:var(--text-secondary);font-style:italic;text-align:center;margin-top:1rem;font-size:.85rem}.summary-section{padding:.5rem .75rem;background-color:var(--hover-bg);border-radius:8px;display:flex;gap:2rem;align-items:center;font-size:.9rem;color:var(--text-color)}.summary-item{display:flex;gap:.5rem}.delta-positive{color:var(--danger-color)}.delta-negative{color:var(--success-color)}.calendar-wrapper{border-radius:8px;overflow:visible}.actions-section{border-top:1px solid var(--border-color);padding-top:.5rem;margin-bottom:.5rem}.comments-area{width:100%;padding:.4rem;border-radius:4px;border:1px solid var(--border-color);min-height:40px;font-size:.85rem;background-color:var(--input-bg);color:var(--text-color)}.buttons-row{display:flex;justify-content:flex-end;gap:.75rem;align-items:center;margin-top:.5rem}.processing-indicator{font-size:.9rem;color:var(--text-secondary);display:flex;align-items:center;gap:.5rem}.btn-action{display:flex;align-items:center;gap:.5rem;padding:.4rem .75rem;border:none;border-radius:4px;font-weight:500;cursor:pointer;font-size:.9rem;transition:opacity .2s}.btn-action:disabled{cursor:not-allowed;opacity:.5}.btn-reject{background-color:var(--danger-light);color:var(--danger-text)}[data-theme=dark] .btn-reject{background-color:#ef444433;color:var(--danger-color)}.btn-approve{background-color:var(--success-light);color:var(--success-text)}[data-theme=dark] .btn-approve{background-color:#10b98133;color:var(--success-color)}.btn-close{background-color:var(--hover-bg);color:var(--text-color);border:1px solid var(--border-color)}.history-modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.history-modal-container{background-color:var(--surface-color);border-radius:8px;width:90%;max-width:600px;max-height:80%;display:flex;flex-direction:column;overflow:hidden;color:var(--text-color);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.history-modal-header{padding:1rem;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.history-modal-title{font-size:1.25rem;font-weight:700;color:var(--text-color)}.close-btn{background:none;border:none;cursor:pointer;font-size:1.5rem;line-height:1;color:var(--text-secondary)}.close-btn:hover{color:var(--text-color)}.history-modal-body{flex:1;overflow-y:auto;padding:1.5rem}.history-timeline{position:relative;padding-left:1rem;border-left:2px solid var(--border-color)}.timeline-item{margin-bottom:1.5rem;position:relative}.timeline-bullet{position:absolute;left:-1.45rem;top:0;width:.8rem;height:.8rem;border-radius:50%;background-color:var(--surface-color);border:2px solid var(--text-secondary)}.timeline-date{margin-bottom:.25rem;display:flex;align-items:center;gap:.5rem}.date-text{font-size:.85rem;color:var(--text-secondary);display:flex;align-items:center;gap:.25rem}.timeline-content{background-color:var(--hover-bg);padding:1rem;border-radius:.5rem;border:1px solid var(--border-color);color:var(--text-color)}.content-header{display:flex;justify-content:space-between;margin-bottom:.5rem}.action-type{display:flex;align-items:center;gap:.5rem;color:var(--text-color)}.user-info{font-size:.9rem;color:var(--text-secondary);display:flex;align-items:center;gap:.25rem}.unit-info{font-size:.8rem;color:var(--text-secondary);margin-bottom:.5rem}.comments-text{margin-top:.5rem;font-size:.9rem;color:var(--text-color);font-style:italic;display:flex;gap:.5rem}.history-modal-footer{padding:.75rem;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;background-color:var(--background-color)}.btn-close{padding:.5rem 1rem;background-color:var(--surface-color);color:var(--text-color);border:1px solid var(--border-color);border-radius:4px;font-weight:500;cursor:pointer;font-size:.9rem}.btn-close:hover{background-color:var(--hover-bg)}.org-tree ul{padding-top:20px;position:relative;transition:all .5s;-webkit-transition:all .5s;-moz-transition:all .5s;display:flex;justify-content:center}.org-tree li{float:left;text-align:center;list-style-type:none;position:relative;padding:20px 5px 0;transition:all .5s;-webkit-transition:all .5s;-moz-transition:all .5s}.org-tree li:before,.org-tree li:after{content:"";position:absolute;top:0;right:50%;border-top:2px solid #ccc;width:50%;height:20px}.org-tree li:after{right:auto;left:50%;border-left:2px solid #ccc}.org-tree li:only-child:after,.org-tree li:only-child:before{display:none}.org-tree li:only-child{padding-top:0}.org-tree li:first-child:before,.org-tree li:last-child:after{border:0 none}.org-tree li:last-child:before{border-right:2px solid #ccc;border-radius:0 5px 0 0;-webkit-border-radius:0 5px 0 0;-moz-border-radius:0 5px 0 0}.org-tree li:first-child:after{border-radius:5px 0 0;-webkit-border-radius:5px 0 0 0;-moz-border-radius:5px 0 0 0}.org-tree ul ul:before{content:"";position:absolute;top:0;left:50%;border-left:2px solid #ccc;width:0;height:20px}.org-tree-node{border:1px solid var(--border-color);padding:10px;text-decoration:none;color:var(--text-color);font-family:arial,verdana,tahoma;font-size:11px;display:inline-block;border-radius:5px;transition:all .5s;-webkit-transition:all .5s;-moz-transition:all .5s;background-color:var(--surface-color);min-width:120px;box-shadow:0 2px 4px #0000001a}.org-tree-node.root-node{background-color:#2563eb;color:#fff;font-weight:700;font-size:14px}.org-tree-node:hover,.org-tree-node:hover+ul li .org-tree-node{background:var(--hover-bg);color:var(--text-color);border:1px solid var(--border-color)}.org-tree-node:hover+ul li:after,.org-tree-node:hover+ul li:before,.org-tree-node:hover+ul:before,.org-tree-node:hover+ul ul:before{border-color:#94a0b4}.expense-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.expense-modal-content{background:#fff;border-radius:8px;width:600px;max-width:90%;box-shadow:0 4px 6px #0000001a;display:flex;flex-direction:column;overflow:hidden}.modal-header{background-color:#1e3a8a;color:#fff;padding:1rem 1.5rem;display:flex;justify-content:space-between;align-items:center}.modal-header h2{margin:0;font-size:1.25rem;font-weight:600}.btn-close-header{background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:0;display:flex;align-items:center}.modal-body{padding:1.5rem;overflow-y:auto;max-height:70vh}.form-group{margin-bottom:1rem;display:flex;flex-direction:column}.form-group label{margin-bottom:.5rem;font-weight:500;color:#333}.form-group input,.form-group select,.form-group textarea{padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.95rem}.file-preview{font-size:.85rem;color:#666;margin-top:.25rem}.modal-footer{padding:1rem 1.5rem;background-color:#f9fafb;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end;gap:.75rem}.btn-cancel,.btn-delete,.btn-save,.btn-submit{padding:.5rem 1rem;border:none;border-radius:4px;cursor:pointer;font-weight:500;font-size:.9rem;color:#fff}.btn-cancel{background:#6b7280}.btn-delete{background:#dc2626}.btn-save{background:#2563eb}.btn-submit{background:#16a34a}.btn-submit:hover,.btn-save:hover,.btn-delete:hover,.btn-cancel:hover{opacity:.9}.rte-container{border:1px solid var(--border-color);border-radius:.375rem;overflow:hidden;background-color:var(--input-bg-color, var(--surface-color))}.rte-toolbar{display:flex;gap:.5rem;padding:.5rem;background-color:var(--background-color);border-bottom:1px solid var(--border-color)}.rte-btn{padding:.25rem .5rem;background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:.25rem;font-weight:700;cursor:pointer;min-width:2rem;text-align:center;color:var(--text-color)}.rte-btn:hover{background-color:var(--hover-color, #e5e7eb)}.rte-editor{padding:.75rem;min-height:150px;outline:none;overflow-y:auto;color:var(--text-color);background-color:var(--input-bg-color, var(--surface-color))}.rte-editor ul{list-style-type:disc;margin-left:1.5rem}.rte-editor ol{list-style-type:decimal;margin-left:1.5rem}.messages-container{padding:2rem;font-family:Inter,system-ui,-apple-system,sans-serif}.messages-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.page-title{font-size:1.875rem;font-weight:700;color:var(--text-color);margin:0}.btn-primary{background-color:var(--primary-color);color:#fff;padding:.625rem 1.25rem;border-radius:.5rem;border:none;display:flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:500;font-size:.875rem;transition:all .2s;box-shadow:0 1px 2px #0000000d}.btn-primary:hover{background-color:#1d4ed8;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.btn-secondary{background-color:var(--surface-color);color:var(--text-color);padding:.625rem 1.25rem;border-radius:.5rem;border:1px solid var(--border-color);cursor:pointer;font-weight:500;font-size:.875rem;transition:all .2s}.btn-secondary:hover{background-color:var(--hover-color);border-color:var(--text-secondary)}.tabs-container{display:flex;border-bottom:2px solid var(--border-color);margin-bottom:2rem;gap:2rem}.tab-button{padding:1rem 0;border:none;background:none;cursor:pointer;font-weight:500;color:var(--text-secondary);border-bottom:2px solid transparent;margin-bottom:-2px;display:flex;align-items:center;gap:.5rem;transition:color .2s}.tab-button:hover{color:var(--text-color)}.tab-button.active{color:var(--primary-color);border-bottom-color:var(--primary-color)}.messages-list-container{background-color:var(--surface-color);border-radius:.75rem;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;border:1px solid var(--border-color);overflow:hidden}.messages-list{list-style:none;padding:0;margin:0}.message-item{padding:.5rem .75rem;border-bottom:1px solid var(--border-color);cursor:pointer;transition:background-color .15s}.message-item:last-child{border-bottom:none}.message-item:hover{background-color:var(--background-color)}.message-item.unread{background-color:#3b82f61a}.message-item.unread:hover{background-color:#3b82f633}.message-content{display:flex;justify-content:space-between;align-items:center}.message-info{display:flex;gap:.75rem;align-items:center}.message-icon{padding:.35rem;border-radius:50%;background-color:var(--background-color);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;width:32px;height:32px}.message-icon.unread{background-color:#3b82f633;color:var(--primary-color)}.message-details h3{margin:0;font-size:.95rem;font-weight:500;color:var(--text-color);line-height:1.2}.message-details h3.bold{font-weight:700;color:var(--text-color)}.message-meta{font-size:.8rem;color:var(--text-secondary);margin:0;line-height:1.2}.message-actions-right{display:flex;align-items:center;gap:10px}.icon-btn{background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:4px;border-radius:4px;display:flex;align-items:center;transition:background-color .2s,color .2s}.icon-btn:hover{background-color:var(--hover-color);color:var(--primary-color)}.message-badges{display:flex;gap:8px;flex-shrink:0;align-items:center}.badge{font-size:.75rem;padding:.25rem .625rem;border-radius:9999px;font-weight:600;display:flex;align-items:center;gap:.25rem}.badge-critical{background-color:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.badge-required{background-color:#f9731633;color:#f97316;border:1px solid rgba(249,115,22,.3)}.modal-overlay{position:fixed;inset:0;background-color:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:50;padding:1rem;animation:fadeIn .2s ease-out}.modal-content.compose-modal{background-color:var(--surface-color);border-radius:1rem;box-shadow:0 25px 50px -12px #00000040;width:100%;max-width:32rem;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .3s cubic-bezier(.16,1,.3,1)}.modal-header{padding:.75rem 1.25rem;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center;background-color:var(--background-color);border-top-left-radius:1rem;border-top-right-radius:1rem}.modal-header h2{margin:0;font-size:1.125rem;font-weight:600;color:var(--text-color)}.close-btn{background:none;border:none;font-size:1.5rem;line-height:1;color:var(--text-secondary);cursor:pointer;padding:.25rem;border-radius:.375rem;transition:all .2s}.close-btn:hover{color:var(--text-color);background-color:var(--border-color)}.compose-modal form{padding:.5rem .75rem;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:.25rem}.compose-modal .form-group{display:flex;flex-direction:column;gap:0;margin-bottom:0!important}.compose-modal .form-group label{font-size:.75rem;font-weight:500;color:var(--text-secondary);margin-bottom:.1rem}.compose-modal .form-group input[type=text],.compose-modal .form-group select{width:100%;padding:.25rem .5rem;border:1px solid var(--border-color);border-radius:.375rem;font-size:.8125rem;color:var(--text-color);background-color:var(--input-bg-color, var(--background-color));transition:border-color .2s,box-shadow .2s;height:1.8rem}.compose-modal .form-group input[type=text]:focus,.compose-modal .form-group select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #2563eb1a}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.compose-modal .form-group.checkbox{margin-top:.25rem;flex-direction:row;align-items:center;gap:.375rem}.compose-modal .form-group.checkbox label{margin-bottom:0;display:flex;align-items:center;gap:.375rem;font-weight:400;cursor:pointer;font-size:.8125rem}.compose-modal .form-group.checkbox input[type=checkbox]{width:.875rem;height:.875rem;border-radius:.25rem;border:1px solid var(--border-color);accent-color:var(--primary-color);cursor:pointer;margin:0}.suggestions-list{position:absolute;top:100%;left:0;width:100%;background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:.375rem;box-shadow:0 4px 6px -1px #0000001a;max-height:200px;overflow-y:auto;z-index:60;list-style:none;padding:0;margin:.25rem 0 0}.suggestions-list li{padding:.5rem;font-size:.8125rem;cursor:pointer;border-bottom:1px solid var(--border-color);color:var(--text-color)}.suggestions-list li:hover{background-color:var(--background-color)}.suggestions-list li.no-results{color:var(--text-secondary);cursor:default;background-color:transparent;text-align:center}.modal-actions{margin-top:auto;padding-top:.5rem;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:.5rem}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message-detail-container{padding:2rem;max-width:1000px;margin:0 auto}.back-link{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);text-decoration:none;margin-bottom:1.5rem;cursor:pointer;background:none;border:none;font-size:1rem}.back-link:hover{color:var(--text-color)}.message-card{background-color:var(--surface-color);border-radius:.75rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;overflow:hidden}.message-card-header{padding:1.5rem;border-bottom:1px solid var(--border-color);background-color:var(--background-color)}.header-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem}.message-subject{font-size:1.5rem;font-weight:700;color:var(--text-color);margin:0}.header-meta{font-size:.875rem;color:var(--text-secondary);display:flex;flex-direction:column;gap:.25rem}.meta-row{display:flex;align-items:center;gap:.5rem}.dot-separator{color:var(--text-tertiary)}.message-body{padding:2rem;color:var(--text-color);line-height:1.625;border-bottom:1px solid var(--border-color);min-height:100px}.replies-section{background-color:var(--background-color);padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.replies-title{font-size:.875rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin:0 0 1rem}.reply-item{display:flex;gap:1rem}.reply-item.my-reply{justify-content:flex-end}.reply-bubble{max-width:80%;border-radius:.5rem;padding:1rem;box-shadow:0 1px 2px #0000000d}.reply-item.my-reply .reply-bubble{background-color:var(--primary-color);color:#fff}.reply-item.other-reply .reply-bubble{background-color:var(--surface-color);color:var(--text-color);border:1px solid var(--border-color)}.reply-header{font-size:.75rem;font-weight:700;margin-bottom:.25rem;opacity:.9;display:flex;justify-content:space-between;gap:1rem}.reply-content p{margin:0}.mandatory-alert{background-color:#f973161a;border-left:4px solid #f97316;padding:1rem;margin:1.5rem;display:flex;align-items:center}.alert-icon{height:1.5rem;width:1.5rem;color:#f97316;margin-right:.75rem}.alert-title{font-weight:700;color:#f97316;margin:0}.alert-desc{font-size:.875rem;color:var(--text-color);margin:0}.reply-box{padding:1.5rem;background-color:var(--surface-color);border-top:1px solid var(--border-color)}.reply-box-title{font-size:1.125rem;font-weight:700;margin:0 0 .5rem;display:flex;align-items:center;gap:.5rem}.reply-actions{display:flex;justify-content:flex-end;margin-top:1rem}.landing-page{font-family:Inter,system-ui,-apple-system,sans-serif;color:#1f2937;background:radial-gradient(circle at 10% 10%,#dbeafe,#eff6ff 30%,#f3f4f6);min-height:100vh;display:flex;flex-direction:column;position:relative;overflow-x:hidden}.landing-nav{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;max-width:1280px;margin:0 auto;width:100%}.nav-brand{display:flex;align-items:center;gap:.75rem;font-size:1.5rem;font-weight:800;color:#111827}.brand-logo{height:32px;width:auto}.btn-login{background-color:transparent;color:#2563eb;border:2px solid #2563eb;padding:.6rem 1.5rem;border-radius:50px;font-weight:600;cursor:pointer;transition:all .3s ease;font-size:.95rem}.btn-login:hover{background-color:#2563eb;color:#fff;box-shadow:0 4px 12px #2563eb33}.hero-section{display:flex;align-items:center;justify-content:space-between;padding:4rem 2rem 6rem;max-width:1280px;margin:0 auto;width:100%;gap:4rem;flex:1}.hero-content{flex:1;max-width:600px}.hero-title{font-size:3.5rem;line-height:1.1;font-weight:900;margin-bottom:1.5rem;color:#111827;letter-spacing:-.02em}.hero-title .highlight{background:linear-gradient(135deg,#2563eb,#60a5fa);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.hero-subtitle{font-size:1.25rem;color:#4b5563;margin-bottom:2.5rem;line-height:1.6}.btn-cta{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border:none;padding:1rem 2.5rem;border-radius:50px;font-size:1.1rem;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:.75rem;transition:transform .2s,box-shadow .2s;box-shadow:0 10px 25px -5px #2563eb66}.btn-cta:hover{transform:translateY(-2px);box-shadow:0 15px 30px -5px #2563eb80}.hero-visual{flex:1;position:relative;height:400px;display:flex;align-items:center;justify-content:center}.visual-circle{width:400px;height:400px;background:radial-gradient(circle at center,#2563eb1a,#fff0 70%);border-radius:50%;position:absolute;z-index:0}.visual-card{position:absolute;background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:1rem 1.5rem;border-radius:16px;box-shadow:0 20px 40px -5px #0000001a;display:flex;align-items:center;gap:1rem;font-weight:600;color:#1f2937;border:1px solid rgba(255,255,255,.5);animation:float 6s ease-in-out infinite;z-index:1}.card-1{top:10%;left:10%;animation-delay:0s}.card-2{top:40%;right:5%;animation-delay:2s}.card-3{bottom:15%;left:20%;animation-delay:4s}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-15px)}}.icon-blue{color:#2563eb}.icon-green{color:#10b981}.icon-purple{color:#8b5cf6}.features-section{background:#ffffff80;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:6rem 2rem;border-top:1px solid rgba(255,255,255,.5);display:flex;flex-direction:column;gap:6rem;align-items:center}.section-title{text-align:center;font-size:2.5rem;font-weight:800;margin-bottom:2rem;color:#111827;width:100%;display:block}.feature-row{display:flex;align-items:center;gap:4rem;max-width:1280px;margin:0 auto;width:100%}.feature-row.reverse{flex-direction:row-reverse}.feature-text{flex:1;display:flex;flex-direction:column;justify-content:center;text-align:center;align-items:center}.feature-text h3{font-size:2rem;font-weight:800;margin-bottom:1rem;color:#111827}.feature-text p{font-size:1.1rem;color:#4b5563;line-height:1.7;margin-bottom:1.5rem;max-width:500px}.feature-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;align-items:center;gap:.75rem}.feature-list li{display:flex;align-items:center;gap:.75rem;color:#374151;font-weight:500}.feature-list li:before{content:"✓";display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;background-color:#d1fae5;color:#059669;border-radius:50%;font-size:.75rem;font-weight:700}.feature-image{flex:1;border-radius:16px;overflow:hidden;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;border:1px solid rgba(255,255,255,.5);background:#fff;transition:transform .3s ease}.feature-image:hover{transform:translateY(-5px);box-shadow:0 25px 30px -5px #00000026}.feature-image img{width:100%;height:auto;display:block;border-radius:12px}.feature-img-shadow{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.landing-footer{background-color:#111827;color:#fff;padding:3rem 2rem;margin-top:auto}.footer-content{max-width:1280px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:2rem}.footer-brand h3{font-size:1.5rem;font-weight:800;margin-bottom:.5rem}.footer-brand p{color:#9ca3af;font-size:.9rem}.footer-links{display:flex;gap:2rem}.footer-links a{color:#d1d5db;text-decoration:none;transition:color .2s}.footer-links a:hover{color:#fff}.smartglobe-link{color:#60a5fa;text-decoration:none;font-weight:600;transition:color .2s}.smartglobe-link:hover{color:#93c5fd;text-decoration:underline}@media(max-width:1024px){.feature-row{gap:2rem}.hero-title{font-size:3rem}}@media(max-width:768px){.hero-section{flex-direction:column;padding-top:2rem;text-align:center;gap:2rem}.hero-content{margin:0 auto}.hero-title{font-size:2.5rem}.hero-visual{display:none;width:100%;height:300px}.btn-cta{width:100%;justify-content:center}.features-section{gap:4rem;padding:4rem 1.5rem}.feature-row,.feature-row.reverse{flex-direction:column;gap:2rem;text-align:center}.feature-text{align-items:center}.feature-icon-wrapper{margin-bottom:1rem}.feature-list{display:none}.footer-content{flex-direction:column;text-align:center}.footer-links{flex-direction:column;gap:1rem}}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease-out}.modal-content{background:#fff;padding:2.5rem;border-radius:16px;width:90%;max-width:500px;position:relative;box-shadow:0 25px 50px -12px #00000040;animation:slideUp .3s ease-out}.modal-close{position:absolute;top:1.5rem;right:1.5rem;background:none;border:none;font-size:2rem;line-height:1;color:#9ca3af;cursor:pointer;transition:color .2s}.modal-close:hover{color:#111827}.contact-modal h2{font-size:1.8rem;font-weight:800;margin-bottom:.5rem;color:#111827}.contact-modal p{color:#6b7280;margin-bottom:2rem}.contact-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.5rem;text-align:left}.form-group label{font-size:.9rem;font-weight:600;color:#374151}.form-group input,.form-group textarea{padding:.75rem 1rem;border:1px solid #d1d5db;border-radius:8px;font-size:1rem;transition:border-color .2s,box-shadow .2s;font-family:inherit}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.btn-submit{background-color:#2563eb;color:#fff;border:none;padding:.875rem;border-radius:8px;font-weight:600;font-size:1rem;cursor:pointer;transition:background-color .2s;margin-top:.5rem}.btn-submit:hover{background-color:#1d4ed8}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.contact-modal{max-width:600px;width:90%}.form-row{display:flex;gap:1rem}.form-row .form-group{flex:1}.contact-success{text-align:center;padding:2rem;display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%}.success-icon{width:64px;height:64px;background-color:#10b981;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:700;margin-bottom:1.5rem;box-shadow:0 4px 6px -1px #10b9814d}.contact-success h3{font-size:1.5rem;font-weight:700;color:#111827;margin-bottom:.5rem}.contact-success p{color:#6b7280;margin-bottom:2rem}.btn-close-modal{background-color:#2563eb;color:#fff;border:none;padding:.75rem 2rem;border-radius:50px;font-weight:600;cursor:pointer;transition:all .2s}.btn-close-modal:hover{background-color:#1d4ed8;transform:translateY(-1px)}.timesheet-container{padding:1.5rem;height:calc(100vh - 64px);display:flex;flex-direction:column;box-sizing:border-box}.timesheet-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;gap:1rem;flex-wrap:wrap}.header-left{display:flex;align-items:center;gap:1rem}.back-btn{background:none;border:1px solid var(--border-color);border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-color)}.page-title{font-size:1.5rem;font-weight:700;color:var(--text-color);margin:0;line-height:1.2;text-transform:capitalize}.header-actions{display:flex;gap:.5rem}.btn-primary,.btn-secondary,.btn-success{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:6px;border:none;cursor:pointer;font-weight:500;font-size:.9rem}.btn-primary{background-color:#2563eb;color:#fff}.btn-success{background-color:#059669;color:#fff}.btn-secondary{background-color:var(--surface-color);border:1px solid var(--border-color);color:var(--text-color)}.status-badge{display:inline-block;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;margin-top:.25rem}.status-draft{background-color:#f3f4f6;color:#374151}.status-submitted{background-color:#fef3c7;color:#92400e}.status-approved{background-color:#d1fae5;color:#065f46}.timesheet-summary{display:flex;gap:1rem;margin-bottom:1rem}.summary-card{background:var(--surface-color);padding:1rem;border-radius:8px;border:1px solid var(--border-color);display:flex;align-items:center;gap:1rem;min-width:150px}.summary-card .label{font-size:.8rem;color:var(--text-secondary);text-transform:uppercase}.summary-card .value{font-size:1.25rem;font-weight:700;color:var(--text-color)}.timesheet-grid-container{flex:1;overflow:auto;background:var(--surface-color);border-radius:8px;border:1px solid var(--border-color);box-shadow:0 1px 3px #0000000d}.timesheet-table{width:100%;border-collapse:separate;border-spacing:0;min-width:600px;font-size:.8rem}.timesheet-table th{position:sticky;top:0;background:var(--background-color);padding:.4rem;font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;border-bottom:1px solid var(--border-color);z-index:10}.timesheet-table tbody tr:last-child td{border-bottom:none}.timesheet-table td{padding:.2rem;border-bottom:1px solid var(--border-color);vertical-align:middle}.col-date{width:110px;text-align:left;left:0;z-index:20!important}.col-date-cell{position:sticky;left:0;background:var(--surface-color);z-index:5;border-right:1px solid var(--border-color)}.day-number{font-weight:700;font-size:.95rem;color:var(--text-color);display:inline-block;width:20px}.day-name{font-size:.8rem;color:var(--text-secondary);display:inline-block}.holiday-label{font-size:.65rem;color:#dc2626;font-weight:600;margin-top:0;line-height:1}.time-input{width:100%;padding:0 .2rem;border-radius:4px;border:1px solid var(--border-color);background:var(--input-bg);color:var(--text-color);text-align:center;font-family:inherit;font-size:.85rem;height:24px}.time-input:disabled{background:transparent;border:none;color:var(--text-secondary)}.row-off,.row-off .col-date-cell{background-color:var(--background-color-secondary, #f9fafb)}.row-holiday .day-number,.row-holiday .day-name{color:#dc2626}.col-total-cell{text-align:center;font-weight:600}@media(max-width:768px){.hidden-mobile{display:none}.timesheet-container{padding:1rem}.page-title{font-size:1.2rem}.timesheet-table th:first-child,.timesheet-table td:first-child{position:sticky;left:0;z-index:15;border-right:1px solid var(--border-color);box-shadow:2px 0 5px #0000000d}}@media print{@page{size:A4;margin:.5cm}body{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}body *{visibility:hidden}.timesheet-container,.timesheet-container *{visibility:visible}.timesheet-container{position:absolute;left:0;top:0;width:100%;height:auto;padding:0;background:#fff;transform:scale(.85);transform-origin:top left;width:117%}.header-actions,.back-btn,.sidebar,.layout-header,.timesheet-grid-container::-webkit-scrollbar{display:none!important}.timesheet-header{margin-bottom:.5rem;justify-content:center;padding-bottom:.5rem;border-bottom:2px solid #000}.page-title{font-size:1.2rem;text-align:center;color:#000;margin-bottom:0}.status-badge{display:none}.timesheet-summary{margin-bottom:.5rem;justify-content:flex-start;border:1px solid #ddd;border-radius:4px;padding:.5rem;width:fit-content}.summary-card{padding:.2rem .5rem;min-width:auto;border:none;background:none}.summary-card .value{font-size:1rem}.timesheet-grid-container{border:none;box-shadow:none;overflow:visible;display:block}.timesheet-table{width:100%;min-width:0;font-size:8pt;table-layout:fixed}.timesheet-table th,.timesheet-table td{border:1px solid #000;padding:2px 4px;color:#000;height:20px}.timesheet-table th{background-color:#f0f0f0!important;font-weight:700}.time-input{border:none;background:transparent;color:#000;padding:0;text-align:center;width:100%;font-size:8pt;height:auto;-webkit-appearance:none}.row-off{background-color:#f9fafb!important}.col-date{width:12%}.col-total{width:8%}.day-number{font-size:8pt;margin-right:4px}.day-name{font-size:7pt}.print-footer{display:block!important;margin-top:1rem;width:100%}.print-employee-name{display:block!important;margin-bottom:.5rem;font-size:10pt;color:#000}}:root{--primary-color: #2563eb;--secondary-color: #1e40af;--background-color: #f3f4f6;--surface-color: #ffffff;--text-color: #1f2937;--text-secondary: #6b7280;--sidebar-bg: #1e3a8a;--sidebar-text: #ffffff;--border-color: #e5e7eb;--input-bg: #ffffff;--hover-bg: #e5e7eb;--danger-color: #ef4444;--danger-light: #fee2e2;--danger-text: #991b1b;--warning-color: #f59e0b;--warning-light-bg: #fffbeb;--warning-text: #92400e;--success-color: #10b981;--success-light: #d1fae5;--success-text: #065f46;--info-light-bg: #eff6ff;--primary-light: #bfdbfe;--primary-dark: #1e40af}[data-theme=dark]{--primary-color: #3b82f6;--secondary-color: #60a5fa;--background-color: #111827;--surface-color: #1f2937;--text-color: #f9fafb;--text-secondary: #9ca3af;--sidebar-bg: #0f172a;--sidebar-text: #e2e8f0;--border-color: #374151;--input-bg: #374151;--hover-bg: #374151;--danger-color: #f87171;--danger-light: rgba(239, 68, 68, .2);--danger-text: #fca5a5;--warning-color: #fbbf24;--warning-light-bg: rgba(245, 158, 11, .2);--warning-text: #fde68a;--success-color: #34d399;--success-light: rgba(16, 185, 129, .2);--success-text: #6ee7b7;--info-light-bg: rgba(59, 130, 246, .2);--primary-light: rgba(59, 130, 246, .2);--primary-dark: #60a5fa}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:Inter,system-ui,-apple-system,sans-serif;background-color:var(--background-color);color:var(--text-color);transition:background-color .3s,color .3s}input,select,textarea{background-color:var(--input-bg);color:var(--text-color);border:1px solid var(--border-color)}::placeholder{color:var(--text-secondary)}.app{height:100vh}.layout{display:flex;height:100vh;position:relative;overflow:hidden}.main-content-wrapper{flex:1;display:flex;flex-direction:column;background-color:var(--background-color);overflow:hidden;position:relative;z-index:1}.page-content{flex:1;overflow-y:auto;padding:0;-webkit-overflow-scrolling:touch}.mobile-header{display:none;height:60px;background-color:var(--sidebar-bg);color:#fff;align-items:center;justify-content:flex-start;padding:0 1rem;box-shadow:0 2px 4px #0000001a;position:relative;width:100%}.mobile-header .brand-text{font-size:1.25rem;font-weight:800}.mobile-menu-btn{background:none;border:none;color:#fff;cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center}.sidebar-overlay{display:none;position:fixed;inset:0;background-color:#00000080;z-index:90;opacity:0;transition:opacity .3s}.sidebar-overlay.open{display:block;opacity:1}.sidebar{width:260px;background-color:var(--sidebar-bg);color:var(--sidebar-text);display:flex;flex-direction:column;transition:width .3s cubic-bezier(.4,0,.2,1),background-color .3s;overflow:hidden;border-right:1px solid var(--border-color);white-space:nowrap;height:100dvh;position:sticky;top:0;z-index:50}.sidebar.collapsed{width:70px}.sidebar-header{height:64px;display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;border-bottom:1px solid var(--border-color)}.sidebar.collapsed .sidebar-header{justify-content:center;padding:0}.brand-text{font-size:1.25rem;font-weight:800;letter-spacing:.05em;opacity:1;transition:opacity .2s}.sidebar.collapsed .brand-text{display:none;opacity:0}.toggle-btn{background:none;border:none;color:#ffffffb3;cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:background .2s}.toggle-btn:hover{background:#ffffff1a;color:#fff}.sidebar-nav{flex:1;padding:1rem .75rem;overflow-y:auto;overflow-x:hidden}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;color:#fffc;text-decoration:none;border-radius:8px;transition:all .2s;margin-bottom:.25rem;height:24px}.nav-item:hover{background-color:#ffffff1a;color:#fff}.nav-item.active{background-color:#2563eb;color:#fff;box-shadow:0 1px 3px #0000001a}.sidebar.collapsed .nav-item{justify-content:center;padding:.75rem 0}.nav-text{opacity:1;transition:opacity .2s}.sidebar.collapsed .nav-text{display:none;opacity:0}.sidebar-footer{padding:1rem;border-top:1px solid rgba(255,255,255,.1)}.sidebar.collapsed .sidebar-footer{padding:1rem .5rem;display:flex;flex-direction:column;align-items:center}.user-profile{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;text-decoration:none;color:#fff;overflow:hidden}.sidebar.collapsed .user-profile{justify-content:center;margin-bottom:1.5rem}.user-avatar{width:36px;height:36px;border-radius:50%;background-color:#60a5fa;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0;border:2px solid rgba(255,255,255,.2);overflow:hidden}.user-info{flex:1;overflow:hidden;transition:opacity .2s}.sidebar.collapsed .user-info{display:none;opacity:0}.user-name{font-weight:600;white-space:nowrap;text-overflow:ellipsis;overflow:hidden;font-size:.9rem}.logout-btn-sidebar{width:100%;padding:.6rem;background-color:#ffffff0d;border:none;border-radius:6px;color:#fca5a5;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all .2s}.logout-btn-sidebar:hover{background-color:#dc262633;color:#f87171}.sidebar.collapsed .logout-btn-sidebar{padding:.6rem 0}.sidebar.collapsed .logout-text{display:none}.main-content{flex:1;padding:2rem;overflow-y:auto}.card{background:var(--surface-color);padding:1.5rem;border-radius:8px;box-shadow:0 1px 3px #0000001a;color:var(--text-color)}.data-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem}.data-item label{display:block;font-size:.875rem;color:#6b7280;margin-bottom:.25rem}.data-item p{margin:0;font-weight:500}.table-container{background-color:var(--surface-color);border-radius:8px;box-shadow:0 1px 3px #0000001a;width:100%;margin-bottom:2rem;overflow-x:auto;position:relative;border:1px solid var(--border-color)}.org-units-header{display:flex;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.movements-table,.requests-table,.users-table{width:100%;margin-bottom:2rem}.users-title{font-size:2rem;font-weight:700;color:var(--text-color);margin:0;line-height:1;margin-right:2rem}.users-client-select{padding:.5rem;border-radius:4px;border:1px solid var(--border-color);min-width:200px;background-color:var(--input-bg);color:var(--text-color)}.header-spacer{flex-grow:1}.users-new-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background-color:#2563eb;color:#fff;border:none;border-radius:4px;cursor:pointer}@media(max-width:768px){.users-header{gap:1rem}.users-title{width:100%;margin-right:0}.users-client-select{flex:1;min-width:0}.header-spacer{display:none}}.users-table .first-col{width:60px;min-width:60px;max-width:60px;left:0}.users-table .second-col{width:100px;min-width:100px;max-width:100px;left:60px}.sticky-col{position:sticky;background-color:var(--surface-color);z-index:10}thead th.sticky-col{background-color:var(--background-color)}@media(max-width:768px){.org-units-header{flex-direction:column;align-items:flex-start;gap:1rem}.org-units-header select{width:100%}}.expenses-table{width:100%;border-collapse:separate;border-spacing:0;min-width:800px}.movements-table th,.movements-table td,.requests-table th,.requests-table td,.expenses-table th,.expenses-table td{padding:.5rem;white-space:nowrap;border-bottom:1px solid var(--border-color);background-color:var(--surface-color);color:var(--text-color)}.movements-table thead th,.requests-table thead th,.expenses-table thead th{background-color:var(--background-color);border-bottom:1px solid var(--border-color);text-align:left;font-weight:600;color:var(--text-secondary);position:sticky;top:0;z-index:20}.capitalize{text-transform:capitalize}.text-right{text-align:right}.text-center{text-align:center}.font-bold{font-weight:700}.p-8{padding:2rem}.text-gray-500{color:#6b7280}.download-btn{background:none;border:none;cursor:pointer;color:#2563eb;padding:.5rem;display:inline-flex;align-items:center;justify-content:center}@media(max-width:768px){.sticky-col{position:sticky;z-index:10}.first-col{left:0;border-right:1px solid #e5e7eb;box-shadow:2px 0 5px -2px #0000001a}.last-col{right:0;border-left:1px solid #e5e7eb;box-shadow:-2px 0 5px -2px #0000001a}.movements-table thead th.first-col,.requests-table thead th.first-col,.expenses-table thead th.first-col,.users-table thead th.first-col,.users-table thead th.second-col,.movements-table thead th.last-col,.requests-table thead th.last-col,.expenses-table thead th.last-col,.users-table thead th.last-col{z-index:30}}.movements-table th,.movements-table td{padding:.2rem .5rem}.movements-table .download-btn{padding:.1rem}.movements-table thead th.text-right,.requests-table thead th.text-right{text-align:right}.movements-table thead th.text-center,.requests-table thead th.text-center{text-align:center}.action-btn{border:none!important;background-color:#f3f4f6;color:var(--text-secondary);padding:6px 10px;border-radius:6px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:6px;transition:all .2s ease;font-size:.85rem;font-weight:500}.action-btn:hover{background-color:#e5e7eb;color:var(--text-color)}.action-btn svg{stroke-width:2px}@media(max-width:768px){.layout{display:block;height:auto;min-height:100vh;overflow:visible}.main-content-wrapper{height:auto;overflow:visible;display:block;min-height:50vh}.movements-table .first-col{width:90px;min-width:90px;max-width:90px;overflow:hidden;text-overflow:ellipsis}.movements-table .last-col{width:50px;min-width:50px;max-width:50px;padding:.2rem!important}.requests-table .last-col{width:80px;min-width:80px;max-width:80px;padding:.2rem!important}.expenses-table .first-col{width:90px;min-width:90px;max-width:90px}.expenses-table .last-col{width:60px;min-width:60px;max-width:60px;padding:.2rem!important}.page-content{height:auto;overflow:visible;padding-bottom:2rem;min-height:50vh}.mobile-header{display:flex}.sidebar{position:fixed;top:0;left:0;bottom:0;height:100vh;z-index:100;transform:translate(-100%);width:260px!important;transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:2px 0 8px #0003;background-color:var(--sidebar-bg)}.sidebar.mobile-open{transform:translate(0)}.sidebar .sidebar-header .toggle-btn{display:none}}@media print{@page{size:landscape;margin:1cm}.sidebar,.mobile-header,.sidebar-overlay,.vacation-toolbar,.btn-vacation,.actions-group,.confirm-modal-overlay,.Toastify,.year-selector select,.year-selector button,button{display:none!important}body,.layout,.main-content-wrapper,.page-content{display:block!important;height:auto!important;min-height:0!important;overflow:visible!important;background-color:#fff!important;width:100%!important;margin:0!important;padding:0!important;position:static!important}.vacations-page-container{display:block!important;width:100%!important;height:auto!important;overflow:visible!important;visibility:visible!important}.vacation-summary{display:flex!important;box-shadow:none!important;border:1px solid #ddd!important;padding:1rem!important;margin-bottom:1rem!important;page-break-inside:avoid}h1{color:#000!important;margin-bottom:.5rem!important;font-size:1.5rem!important}.annual-calendar-container{display:block!important;height:auto!important;overflow:visible!important;padding:0!important}.months-grid{display:grid!important;grid-template-columns:repeat(4,1fr)!important;grid-template-rows:auto!important;gap:10px!important;height:auto!important;overflow:visible!important}.month-container{break-inside:avoid;page-break-inside:avoid;border:1px solid #eee!important;box-shadow:none!important;margin-bottom:10px}.day-cell{height:auto!important;min-height:1.2em!important;font-size:.7rem!important;padding:2px!important;color:#000!important;border:1px solid transparent}.year-display{display:inline-block!important;font-size:1.5rem;font-weight:700;color:#000!important}*{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important;color:#000!important;text-shadow:none!important;box-shadow:none!important}}.personal-data-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}@media(max-width:768px){.personal-data-grid{grid-template-columns:1fr!important}.personal-data-grid>div{grid-column:span 1!important}.mobile-hidden-text{display:none}}.expenses-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.expenses-header>div{display:flex;gap:1rem}@media(max-width:768px){.expenses-header{flex-direction:column;align-items:stretch;gap:1rem}.expenses-header>div{display:grid;grid-template-columns:1fr 1fr;width:100%;gap:.5rem}.expenses-header>div>label,.expenses-header>div>button{justify-content:center;width:100%}}
