*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #3B82F6;--primary-dark: #2563EB;--primary-light: #60A5FA;--success: #10B981;--warning: #F59E0B;--danger: #EF4444;--gray-50: #F9FAFB;--gray-100: #F3F4F6;--gray-200: #E5E7EB;--gray-300: #D1D5DB;--gray-400: #9CA3AF;--gray-500: #6B7280;--gray-600: #4B5563;--gray-700: #374151;--gray-800: #1F2937;--gray-900: #111827;--sidebar-width: 260px;--header-height: 64px}html,body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;font-size:14px;line-height:1.5;color:var(--gray-900);background:var(--gray-100);min-height:100vh}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;font-family:inherit}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:1rem}.spinner{width:40px;height:40px;border:3px solid var(--gray-200);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.app-layout{display:flex;min-height:100vh}.main-content{flex:1;display:flex;flex-direction:column;min-width:0}.page-content{flex:1;padding:1.5rem;overflow-y:auto}.sidebar{width:var(--sidebar-width);background:var(--gray-900);color:#fff;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;transition:transform .3s ease}.sidebar-header{padding:1.5rem;border-bottom:1px solid var(--gray-700);display:flex;align-items:center;gap:.75rem}.sidebar-logo{width:36px;height:36px;background:var(--primary);border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:18px}.sidebar-workspace{flex:1;min-width:0}.sidebar-workspace h2{font-size:1rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-workspace span{font-size:.75rem;color:var(--gray-400)}.sidebar-nav{flex:1;padding:1rem 0;overflow-y:auto}.sidebar-nav a{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.5rem;color:var(--gray-300);transition:all .2s}.sidebar-nav a:hover{background:var(--gray-800);color:#fff;text-decoration:none}.sidebar-nav a.active{background:var(--primary);color:#fff}.sidebar-nav svg{width:20px;height:20px;flex-shrink:0}.sidebar-overlay{display:none}@media (max-width: 768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:99;opacity:0;pointer-events:none;transition:opacity .3s}.sidebar-overlay.visible{opacity:1;pointer-events:auto}.main-content{margin-left:0}}@media (min-width: 769px){.main-content{margin-left:var(--sidebar-width)}}.header{height:var(--header-height);background:#fff;border-bottom:1px solid var(--gray-200);display:flex;align-items:center;padding:0 1.5rem;gap:1rem;position:sticky;top:0;z-index:50}.header-menu-btn{display:none;background:none;border:none;padding:.5rem;color:var(--gray-600)}@media (max-width: 768px){.header-menu-btn{display:flex}}.header-title{flex:1;font-size:1.25rem;font-weight:600}.header-user{display:flex;align-items:center;gap:.75rem}.header-avatar{width:36px;height:36px;border-radius:50%;background:var(--gray-200);object-fit:cover}.header-dropdown{position:relative}.header-dropdown-menu{position:absolute;top:100%;right:0;margin-top:.5rem;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:180px;overflow:hidden;z-index:100}.header-dropdown-menu button{display:block;width:100%;padding:.75rem 1rem;text-align:left;border:none;background:none;color:var(--gray-700);transition:background .2s}.header-dropdown-menu button:hover{background:var(--gray-100)}.card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.card-header{padding:1rem 1.5rem;border-bottom:1px solid var(--gray-200);display:flex;align-items:center;justify-content:space-between}.card-header h3{font-size:1rem;font-weight:600}.card-body{padding:1.5rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.stat-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.stat-card-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:1rem;font-size:1.25rem}.stat-card-value{font-size:2rem;font-weight:700;line-height:1;margin-bottom:.25rem}.stat-card-label{color:var(--gray-500);font-size:.875rem}.table-container{overflow-x:auto}table{width:100%;border-collapse:collapse}th,td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--gray-200)}th{background:var(--gray-50);font-weight:600;color:var(--gray-600);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}tbody tr:hover{background:var(--gray-50)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1rem;border-radius:8px;font-weight:500;font-size:.875rem;border:none;transition:all .2s}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-secondary{background:var(--gray-100);color:var(--gray-700)}.btn-secondary:hover{background:var(--gray-200)}.btn-success{background:var(--success);color:#fff}.btn-danger{background:var(--danger);color:#fff}.form-label{display:block;margin-bottom:.375rem;font-weight:500;color:var(--gray-700)}.form-input,.form-select{width:100%;padding:.625rem .875rem;border:1px solid var(--gray-300);border-radius:8px;font-size:.875rem;transition:border-color .2s,box-shadow .2s}.form-input:focus,.form-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a}.badge{display:inline-flex;align-items:center;padding:.25rem .625rem;border-radius:9999px;font-size:.75rem;font-weight:500}.badge-pending{background:#fef3c7;color:#92400e}.badge-approved{background:#d1fae5;color:#065f46}.badge-rejected{background:#fee2e2;color:#991b1b}.avatar{width:32px;height:32px;border-radius:50%;background:var(--gray-200);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;color:var(--gray-600);overflow:hidden}.avatar img{width:100%;height:100%;object-fit:cover}.balance-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}.balance-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 1px 3px #0000001a;display:flex;align-items:flex-start;gap:1rem}.balance-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem}.balance-info{flex:1}.balance-type{font-weight:600;margin-bottom:.25rem}.balance-available{font-size:1.5rem;font-weight:700;color:var(--gray-900)}.balance-available span{font-size:.875rem;font-weight:400;color:var(--gray-500)}.balance-details{display:flex;gap:1rem;margin-top:.5rem;font-size:.8125rem;color:var(--gray-500)}.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.calendar-nav{display:flex;align-items:center;gap:.5rem}.calendar-nav button{padding:.5rem;border:1px solid var(--gray-300);border-radius:6px;background:#fff}.calendar-title{font-size:1.25rem;font-weight:600}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--gray-200);border:1px solid var(--gray-200);border-radius:8px;overflow:hidden}.calendar-day-header{background:var(--gray-50);padding:.75rem;text-align:center;font-weight:600;font-size:.75rem;color:var(--gray-600);text-transform:uppercase}.calendar-day{background:#fff;min-height:100px;padding:.5rem}.calendar-day.other-month{background:var(--gray-50);color:var(--gray-400)}.calendar-day.today{background:#eff6ff}.calendar-date{font-weight:600;font-size:.875rem;margin-bottom:.5rem}.calendar-event{font-size:.75rem;padding:.25rem .5rem;border-radius:4px;margin-bottom:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:linear-gradient(135deg,#667eea,#764ba2)}.login-card{background:#fff;border-radius:16px;padding:3rem;width:100%;max-width:400px;text-align:center;box-shadow:0 20px 40px #0003}.login-logo{width:64px;height:64px;background:var(--primary);border-radius:16px;margin:0 auto 1.5rem;display:flex;align-items:center;justify-content:center;color:#fff;font-size:2rem}.login-title{font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.login-subtitle{color:var(--gray-500);margin-bottom:2rem}.slack-btn{display:flex;align-items:center;justify-content:center;gap:.75rem;width:100%;padding:1rem;border:2px solid var(--gray-200);border-radius:8px;background:#fff;font-weight:600;font-size:1rem;color:var(--gray-800);transition:all .2s}.slack-btn:hover{border-color:var(--primary);background:var(--gray-50)}.slack-btn svg{width:24px;height:24px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;padding:1rem;z-index:200}.modal{background:#fff;border-radius:12px;width:100%;max-width:500px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.modal-header{padding:1rem 1.5rem;border-bottom:1px solid var(--gray-200);display:flex;align-items:center;justify-content:space-between}.modal-header h3{font-size:1.125rem;font-weight:600}.modal-close{background:none;border:none;padding:.5rem;color:var(--gray-500)}.modal-body{padding:1.5rem;overflow-y:auto}.modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--gray-200);display:flex;justify-content:flex-end;gap:.75rem}.empty-state{text-align:center;padding:3rem 1.5rem;color:var(--gray-500)}.empty-state-icon{font-size:3rem;margin-bottom:1rem}.empty-state h3{color:var(--gray-700);margin-bottom:.5rem}.month-chart{display:flex;gap:.5rem;margin-bottom:1rem}.chart-y-axis{display:flex;flex-direction:column;justify-content:space-between;padding-bottom:24px;min-width:20px}.chart-y-label{font-size:.75rem;color:var(--gray-400);text-align:right}.chart-bars{flex:1;display:flex;gap:2px;align-items:flex-end;height:120px;border-bottom:1px solid var(--gray-200);padding-bottom:4px}.chart-bar-container{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;position:relative}.chart-bar-container.weekend{background:var(--gray-50);border-radius:4px 4px 0 0}.chart-bar-container.today{background:#3b82f61a;border-radius:4px 4px 0 0}.chart-bar-stack{width:100%;max-width:20px;display:flex;flex-direction:column;justify-content:flex-end;margin-top:auto;border-radius:2px 2px 0 0;overflow:hidden}.bar-segment{min-height:4px}.bar-segment.sick{background:#ef4444}.bar-segment.vacation{background:#8b5cf6}.bar-segment.maternity{background:#ec4899}.bar-segment.other{background:#6b7280}.holiday-marker{position:absolute;bottom:20px;width:6px;height:6px;background:#10b981;border-radius:50%}.chart-day-label{font-size:.625rem;color:var(--gray-500);margin-top:4px}.chart-legend{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;padding-top:.5rem;border-top:1px solid var(--gray-100)}.legend-item{display:flex;align-items:center;gap:.375rem;font-size:.75rem;color:var(--gray-600)}.legend-dot{width:10px;height:10px;border-radius:2px}.legend-dot.sick{background:#ef4444}.legend-dot.vacation{background:#8b5cf6}.legend-dot.maternity{background:#ec4899}.legend-dot.holiday{background:#10b981;border-radius:50%}.legend-dot.today{background:#3b82f64d;border:1px solid var(--primary)}.legend-dot.non-working{background:var(--gray-200)}.tabs{display:flex;gap:0;border-bottom:2px solid var(--gray-200)}.tab{padding:.75rem 1.25rem;background:none;border:none;font-weight:500;color:var(--gray-500);position:relative;transition:color .2s}.tab:hover{color:var(--gray-700)}.tab.active{color:var(--primary)}.tab.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:2px;background:var(--primary)}.today-leave-item{display:flex;align-items:flex-start;gap:1rem;padding:1rem 0;border-bottom:1px solid var(--gray-100)}.today-leave-item:last-child{border-bottom:none}.today-leave-item .avatar{width:48px;height:48px;flex-shrink:0;font-size:1.25rem}.leave-info{flex:1;min-width:0}.leave-type-badge{display:inline-block;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500;color:#fff;margin-right:.5rem}.leave-type-badge.pending{background:#f59e0b}.user-name{font-weight:600;color:var(--gray-900)}.leave-description{margin-top:.25rem;color:var(--gray-600);font-size:.875rem}.leave-days{margin-top:.25rem;color:var(--gray-500);font-size:.8125rem}.leave-reason{margin-top:.5rem;color:var(--gray-600);font-size:.875rem;background:var(--gray-50);padding:.5rem;border-radius:4px}.leave-actions{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem;flex-shrink:0}.approved-by{font-size:.75rem;color:var(--gray-500)}.leave-list{display:flex;flex-direction:column}.leave-list-item{display:flex;align-items:center;gap:1rem;padding:.75rem 0;border-bottom:1px solid var(--gray-100)}.leave-list-item:last-child{border-bottom:none}.leave-list-item .avatar{flex-shrink:0}.leave-list-item .leave-info{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem}.leave-list-item .leave-info p{width:100%;margin:0;color:var(--gray-500);font-size:.8125rem}.leave-list-item .leave-actions{flex-direction:row;gap:.5rem}.btn-link{background:none;border:none;color:var(--primary);font-weight:500;padding:.5rem}.btn-link:hover{text-decoration:underline}.wallchart-page{display:flex;flex-direction:column;height:calc(100vh - var(--header-height) - 3rem)}.wallchart-controls{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;margin-bottom:1rem;background:#fff;padding:1rem;border-radius:12px;box-shadow:0 1px 3px #0000001a}.wallchart-nav{display:flex;align-items:center;gap:.75rem}.wallchart-period{font-weight:600;min-width:200px;text-align:center}.wallchart-filters{display:flex;align-items:center;gap:.75rem}.view-toggle{display:flex;border:1px solid var(--gray-300);border-radius:6px;overflow:hidden}.toggle-btn{padding:.375rem .75rem;background:#fff;border:none;font-size:.8125rem;font-weight:500;color:var(--gray-600);cursor:pointer;transition:all .2s}.toggle-btn:not(:last-child){border-right:1px solid var(--gray-300)}.toggle-btn.active{background:var(--primary);color:#fff}.toggle-btn:hover:not(.active){background:var(--gray-50)}.form-select-sm{padding:.375rem 2rem .375rem .75rem;font-size:.8125rem;border:1px solid var(--gray-300);border-radius:6px;background:#fff;cursor:pointer}.wallchart-legend{display:flex;gap:1rem;margin-bottom:1rem;padding:.5rem 1rem;background:#fff;border-radius:8px;flex-wrap:wrap}.wallchart-legend .legend-item{display:flex;align-items:center;gap:.375rem;font-size:.75rem;color:var(--gray-600)}.wallchart-legend .legend-dot.pending{background:repeating-linear-gradient(45deg,#f59e0b,#f59e0b 2px,#fcd34d 2px,#fcd34d 4px)}.wallchart-container{flex:1;overflow:auto;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a}.wallchart-grid{display:flex;flex-direction:column;min-width:fit-content}.wallchart-header{display:flex;position:sticky;top:0;background:var(--gray-50);z-index:10;border-bottom:2px solid var(--gray-200)}.wallchart-user-col{min-width:200px;max-width:200px;padding:.75rem;font-weight:600;font-size:.75rem;color:var(--gray-600);text-transform:uppercase;letter-spacing:.05em;position:sticky;left:0;background:inherit;z-index:5;border-right:1px solid var(--gray-200)}.wallchart-date-col{min-width:40px;padding:.5rem .25rem;text-align:center;border-right:1px solid var(--gray-100)}.wallchart-date-col.weekend{background:var(--gray-100)}.wallchart-date-col.today{background:#3b82f626}.wallchart-date-col.holiday{background:#10b98126}.date-weekday{font-size:.625rem;color:var(--gray-500);text-transform:uppercase}.date-day{font-size:.875rem;font-weight:600;color:var(--gray-700)}.wallchart-row{display:flex;border-bottom:1px solid var(--gray-100)}.wallchart-row:hover{background:var(--gray-50)}.wallchart-row .wallchart-user-col{font-weight:400;font-size:.875rem;text-transform:none;letter-spacing:normal;display:flex;align-items:center;background:#fff}.wallchart-row:hover .wallchart-user-col{background:var(--gray-50)}.wallchart-user{display:flex;align-items:center;gap:.75rem}.wallchart-user .avatar{width:32px;height:32px;flex-shrink:0}.user-details{min-width:0}.user-details .user-name{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-dept{font-size:.75rem;color:var(--gray-500);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wallchart-cell{min-width:40px;height:48px;border-right:1px solid var(--gray-100);display:flex;align-items:center;justify-content:center}.wallchart-cell.weekend{background:var(--gray-50)}.wallchart-cell.today{background:#3b82f61a}.wallchart-cell.holiday{background:#10b98126}.wallchart-cell.has-leave{position:relative}.wallchart-cell.pending-leave{background:repeating-linear-gradient(45deg,transparent,transparent 2px,rgba(255,255,255,.3) 2px,rgba(255,255,255,.3) 4px)}.leave-indicator{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.75rem;font-weight:500}.wallchart-empty{padding:3rem;text-align:center;color:var(--gray-500);grid-column:1 / -1}.calendar-page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.calendar-page-header h2{font-size:1.5rem;font-weight:600}.calendar-actions{display:flex;gap:.5rem}.filters-panel .card-body{padding:1rem}.filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}.filter-group{display:flex;flex-direction:column;gap:.25rem}.filter-label{font-size:.75rem;font-weight:500;color:var(--gray-600);text-transform:uppercase;letter-spacing:.05em}.calendar-legend-bar{display:flex;gap:1.5rem;margin-top:1rem;padding:.75rem 1rem;background:#fff;border-radius:8px;flex-wrap:wrap}.legend-dot.pending-stripe{background:repeating-linear-gradient(45deg,#f59e0b,#f59e0b 2px,#fcd34d 2px,#fcd34d 4px)}.day-view{padding:1rem 0}.day-holidays{margin-bottom:1rem}.holiday-banner{padding:.75rem 1rem;background:#fee2e2;color:#991b1b;border-radius:8px;font-weight:500;margin-bottom:.5rem}.day-leaves-list{display:flex;flex-direction:column;gap:.75rem}.day-leave-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--gray-50);border-radius:8px;border-left:4px solid}.day-leave-item.pending{background:#fffbeb}.leave-user-info{display:flex;align-items:center;gap:.75rem;flex:1}.leave-user-info .leave-type{font-size:.8125rem;font-weight:500}.leave-dates{font-size:.875rem;color:var(--gray-600)}.leave-status{text-transform:capitalize}.week-view{padding:1rem 0}.week-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--gray-200);border:1px solid var(--gray-200);border-radius:8px;overflow:hidden}.week-day{background:#fff;min-height:200px}.week-day.weekend{background:var(--gray-50)}.week-day.today{background:#eff6ff}.week-day-header{display:flex;flex-direction:column;align-items:center;padding:.5rem;border-bottom:1px solid var(--gray-200);background:var(--gray-50)}.week-day.today .week-day-header{background:#dbeafe}.week-day-name{font-size:.75rem;color:var(--gray-500);text-transform:uppercase}.week-day-date{font-size:1.25rem;font-weight:600}.week-day.today .week-day-date{color:var(--primary)}.week-day-content{padding:.5rem;display:flex;flex-direction:column;gap:.25rem}.week-event{padding:.25rem .5rem;border-radius:4px;font-size:.75rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.week-event.leave{color:#fff}.week-event.leave.pending{opacity:.7}.week-event.holiday{background:#fee2e2;color:#991b1b}.week-event.more{background:var(--gray-100);color:var(--gray-600);text-align:center}.calendar-day.weekend{background:var(--gray-50)}.calendar-event.pending{opacity:.8}.calendar-event.holiday{background:#fee2e2!important;color:#991b1b!important}.calendar-event.more{background:var(--gray-100);color:var(--gray-600);text-align:center}@media (max-width: 640px){.stats-grid,.balance-grid{grid-template-columns:1fr}.card-header{flex-direction:column;align-items:flex-start;gap:.75rem}.chart-bars{height:80px}.chart-legend{gap:.5rem}.legend-item{font-size:.625rem}.today-leave-item{flex-direction:column}.today-leave-item .leave-actions{flex-direction:row;width:100%;justify-content:flex-end}.leave-list-item{flex-wrap:wrap}.leave-list-item .leave-actions{width:100%;justify-content:flex-end;margin-top:.5rem}.tabs{overflow-x:auto}.tab{white-space:nowrap;padding:.5rem 1rem;font-size:.875rem}}.team-page{max-width:1400px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;gap:1rem}.page-header-content h1{font-size:1.5rem;font-weight:600;margin-bottom:.25rem}.page-subtitle{color:var(--gray-500);font-size:.875rem}.team-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;background:#fff;padding:.375rem;border-radius:.5rem;border:1px solid var(--gray-200)}.team-tab{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;border-radius:.375rem;background:transparent;border:none;font-size:.875rem;font-weight:500;color:var(--gray-600);transition:all .2s}.team-tab:hover{background:var(--gray-100);color:var(--gray-800)}.team-tab.active{background:var(--primary);color:#fff}.team-tab.active .tab-count{background:#fff3;color:#fff}.tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:1.5rem;height:1.25rem;padding:0 .375rem;border-radius:999px;background:var(--gray-200);font-size:.75rem;font-weight:600}.team-filters{display:flex;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.filter-search{flex:1;min-width:250px;position:relative}.filter-search .search-icon{position:absolute;left:.875rem;top:50%;transform:translateY(-50%);color:var(--gray-400);pointer-events:none}.filter-search .form-input{padding-left:2.5rem;width:100%}.filter-selects{display:flex;gap:.5rem;flex-wrap:wrap}.filter-selects .form-select{min-width:140px}.team-results-info{font-size:.8125rem;color:var(--gray-500);margin-bottom:1rem}.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1rem}.team-card{background:#fff;border-radius:.75rem;border:1px solid var(--gray-200);overflow:hidden;transition:box-shadow .2s}.team-card:hover{box-shadow:0 4px 12px #00000014}.team-card-header{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;background:var(--gray-50);border-bottom:1px solid var(--gray-200)}.team-card-avatar{position:relative;width:48px;height:48px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1.125rem;flex-shrink:0;overflow:hidden}.team-card-avatar img{width:100%;height:100%;object-fit:cover}.status-indicator{position:absolute;bottom:2px;right:2px;width:12px;height:12px;border-radius:50%;border:2px solid white}.status-indicator.online{background:var(--success)}.status-indicator.offline{background:var(--gray-400)}.team-card-info{flex:1;min-width:0}.team-card-name{font-size:1rem;font-weight:600;color:var(--gray-900);margin-bottom:.125rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.team-card-slack{font-size:.8125rem;color:var(--gray-500)}.team-card-menu{margin-left:auto}.team-card-body{padding:1rem;display:flex;flex-direction:column;gap:.625rem}.team-card-detail{display:flex;align-items:center;gap:.625rem;font-size:.8125rem;color:var(--gray-600)}.team-card-detail svg{color:var(--gray-400);flex-shrink:0}.team-card-footer{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-top:1px solid var(--gray-200);background:var(--gray-50)}.team-card-actions{display:flex;gap:.5rem}.team-empty{grid-column:1 / -1;text-align:center;padding:3rem;background:#fff;border-radius:.75rem;border:1px solid var(--gray-200)}.team-empty h3{font-size:1.125rem;margin-bottom:.5rem}.team-empty p{color:var(--gray-500);font-size:.875rem}.badge-owner{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.badge-admin{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff}.badge-approver{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.badge-user{background:var(--gray-200);color:var(--gray-700)}.btn-danger-outline{background:transparent;border:1px solid var(--danger);color:var(--danger)}.btn-danger-outline:hover{background:var(--danger);color:#fff}.btn-sm{padding:.375rem .75rem;font-size:.8125rem}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;border-radius:.375rem;color:var(--gray-500);transition:all .2s}.btn-icon:hover{background:var(--gray-200);color:var(--gray-700)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:1000}.modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:480px;background:#fff;border-radius:.75rem;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;z-index:1001;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid var(--gray-200)}.modal-header h2{font-size:1.125rem;font-weight:600}.modal-body{padding:1.5rem;overflow-y:auto;flex:1}.modal-footer{display:flex;gap:.75rem;justify-content:flex-end;padding:1rem 1.5rem;border-top:1px solid var(--gray-200);background:var(--gray-50)}.edit-user-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--gray-200)}.edit-user-header h3{font-size:1rem;font-weight:600;margin-bottom:.125rem}.edit-user-header p{font-size:.8125rem;color:var(--gray-500)}.avatar-lg{width:56px;height:56px;font-size:1.25rem}.form-group{margin-bottom:1rem}.form-group label{display:block;font-size:.8125rem;font-weight:500;color:var(--gray-700);margin-bottom:.375rem}@media (max-width: 768px){.page-header{flex-direction:column;align-items:stretch}.team-tabs{overflow-x:auto;flex-wrap:nowrap}.team-tab{flex-shrink:0}.team-filters{flex-direction:column}.filter-search{min-width:100%}.filter-selects{width:100%}.filter-selects .form-select{flex:1;min-width:0}.team-grid{grid-template-columns:1fr}.team-card-footer{flex-direction:column;gap:.75rem;align-items:stretch}.team-card-actions{justify-content:stretch}.team-card-actions .btn{flex:1;text-align:center}}.settings-page{max-width:1200px;margin:0 auto}.settings-tabs{display:flex;gap:.25rem;margin-bottom:1.5rem;background:#fff;padding:.375rem;border-radius:.75rem;border:1px solid var(--gray-200);overflow-x:auto}.settings-tab{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;border-radius:.5rem;background:transparent;border:none;font-size:.875rem;font-weight:500;color:var(--gray-600);white-space:nowrap;transition:all .2s}.settings-tab:hover{background:var(--gray-100);color:var(--gray-800)}.settings-tab.active{background:var(--primary);color:#fff}.tab-icon{font-size:1rem}.settings-section{background:#fff;border-radius:.75rem;border:1px solid var(--gray-200);padding:1.5rem}.settings-section-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;gap:1rem}.settings-section-header h2{font-size:1.25rem;font-weight:600;margin-bottom:.25rem}.settings-section-header p{font-size:.875rem;color:var(--gray-500)}.settings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.settings-card{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:.75rem;overflow:hidden;transition:all .2s}.settings-card:hover{border-color:var(--gray-300);box-shadow:0 2px 8px #0000000d}.settings-card.default{border-color:var(--primary);border-width:2px}.settings-card-header{display:flex;align-items:center;gap:.75rem;padding:1rem}.settings-card-title{flex:1;min-width:0}.settings-card-title h3{font-size:1rem;font-weight:600;margin-bottom:.25rem}.settings-card-badges{display:flex;flex-wrap:wrap;gap:.375rem}.settings-card-body{padding:0 1rem 1rem}.leave-type-icon{width:40px;height:40px;border-radius:.5rem;display:flex;align-items:center;justify-content:center;font-size:1.25rem}.leave-type-color-bar{height:4px}.location-icon{width:40px;height:40px;border-radius:.5rem;background:var(--primary-light);color:var(--primary);display:flex;align-items:center;justify-content:center}.mini-badge{display:inline-flex;align-items:center;padding:.125rem .5rem;font-size:.6875rem;font-weight:500;border-radius:999px;background:var(--gray-200);color:var(--gray-600)}.mini-badge.success{background:#10b9811a;color:var(--success)}.detail-row{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid var(--gray-200)}.detail-row:last-child{border-bottom:none}.detail-label{font-size:.8125rem;color:var(--gray-500)}.detail-value{font-size:.8125rem;color:var(--gray-900);font-weight:500}.empty-card{grid-column:1 / -1;text-align:center;padding:3rem 2rem;background:var(--gray-50);border:2px dashed var(--gray-200);border-radius:.75rem}.empty-card.full-width{grid-column:1 / -1}.empty-card h3{font-size:1.125rem;margin-bottom:.5rem}.empty-card p{color:var(--gray-500);margin-bottom:1rem}.departments-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1rem}.department-card{background:#fff;border:1px solid var(--gray-200);border-radius:.75rem;overflow:hidden}.department-card.default{border-color:var(--primary);border-width:2px}.department-card-header{display:flex;align-items:center;gap:.75rem;padding:1rem;background:var(--gray-50);border-bottom:1px solid var(--gray-200)}.department-icon{width:40px;height:40px;border-radius:.5rem;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center}.department-title{flex:1;display:flex;align-items:center;gap:.5rem}.department-title h3{font-size:1rem;font-weight:600}.department-menu{margin-left:auto}.department-stats{display:flex;gap:2rem;padding:1rem;border-bottom:1px solid var(--gray-200)}.stat-item{text-align:center}.stat-value{display:block;font-size:1.5rem;font-weight:600;color:var(--gray-900)}.stat-label{font-size:.75rem;color:var(--gray-500);text-transform:uppercase;letter-spacing:.05em}.department-members{padding:1rem;border-bottom:1px solid var(--gray-200)}.members-label,.approvers-label{display:block;font-size:.75rem;color:var(--gray-500);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.avatar-stack{display:flex;gap:-.5rem}.avatar-stack .avatar{border:2px solid white;margin-left:-.5rem}.avatar-stack .avatar:first-child{margin-left:0}.avatar.more-count{background:var(--gray-300);color:var(--gray-700);font-size:.75rem;font-weight:600}.avatar-sm{width:32px;height:32px;font-size:.75rem}.avatar-xs{width:24px;height:24px;font-size:.625rem}.department-approvers{padding:1rem;border-bottom:1px solid var(--gray-200)}.approvers-list{display:flex;flex-wrap:wrap;gap:.5rem}.approver-chip{display:flex;align-items:center;gap:.375rem;padding:.25rem .5rem .25rem .25rem;background:var(--gray-100);border-radius:999px;font-size:.8125rem}.department-actions{display:flex;gap:.5rem;padding:1rem;justify-content:flex-end}.approver-selector{max-height:200px;overflow-y:auto;border:1px solid var(--gray-200);border-radius:.5rem;padding:.5rem}.approver-option{display:flex;align-items:center;gap:.5rem;padding:.5rem;border-radius:.375rem;cursor:pointer;transition:background .2s}.approver-option:hover{background:var(--gray-100)}.approver-option input[type=checkbox]{width:16px;height:16px}.role-badge{margin-left:auto;font-size:.6875rem;padding:.125rem .5rem;background:var(--gray-200);border-radius:999px;color:var(--gray-600)}.holidays-list{display:flex;flex-direction:column;gap:1.5rem}.holiday-month-group{background:var(--gray-50);border-radius:.75rem;padding:1rem}.month-header{font-size:.875rem;font-weight:600;color:var(--gray-600);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.holiday-cards{display:flex;flex-direction:column;gap:.5rem}.holiday-card{display:flex;align-items:center;gap:1rem;padding:.75rem;background:#fff;border-radius:.5rem;border:1px solid var(--gray-200)}.holiday-date{text-align:center;min-width:48px}.holiday-date .day{display:block;font-size:1.25rem;font-weight:600;color:var(--primary)}.holiday-date .weekday{font-size:.75rem;color:var(--gray-500);text-transform:uppercase}.holiday-info{flex:1}.holiday-info h4{font-size:.9375rem;font-weight:500;margin-bottom:.125rem}.holiday-location{font-size:.8125rem;color:var(--gray-500);display:flex;align-items:center;gap:.5rem}.recurring-badge{font-size:.6875rem;padding:.125rem .375rem;background:var(--primary-light);color:var(--primary);border-radius:999px}.btn-icon.btn-danger{color:var(--danger)}.btn-icon.btn-danger:hover{background:#ef44441a}.notification-settings{display:flex;flex-direction:column;gap:1rem}.notification-settings .card{margin:0}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-color{height:40px;padding:.25rem;cursor:pointer}.form-hint{font-size:.75rem;color:var(--gray-500);margin-top:.25rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.875rem}.checkbox-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary)}.plan-display{display:flex;align-items:center;gap:1rem}.plan-name{font-weight:600;text-transform:capitalize}.upgrade-link{font-size:.8125rem;color:var(--primary)}@media (max-width: 768px){.settings-tabs{flex-wrap:nowrap}.settings-section-header{flex-direction:column}.settings-grid,.departments-grid,.form-row{grid-template-columns:1fr}}.alert{padding:.75rem 1rem;border-radius:var(--radius);margin-bottom:1rem;font-size:.875rem;display:flex;align-items:center;gap:.5rem}.alert-success{background:#10b9811a;color:#059669;border:1px solid rgba(16,185,129,.2)}.alert-error{background:#ef44441a;color:#dc2626;border:1px solid rgba(239,68,68,.2)}.alert-warning{background:#f59e0b1a;color:#d97706;border:1px solid rgba(245,158,11,.2)}.alert-info{background:#3b82f61a;color:#2563eb;border:1px solid rgba(59,130,246,.2)}
