@import url(https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500&display=swap);:root{--font-main:"Plus Jakarta Sans",sans-serif;--font-mono:"JetBrains Mono",monospace;--brand-primary:#1a1f36;--brand-accent:#635bff;--brand-accent-light:#ebe9ff;--sidebar-bg:#0f1117;--sidebar-width:240px;--sidebar-collapsed:64px;--sidebar-text:#a0aec0;--sidebar-active-bg:#635bff26;--sidebar-active-text:#635bff;--sidebar-hover-bg:#ffffff0d;--sidebar-border:#ffffff0f;--bg-page:#f5f6fa;--bg-card:#fff;--bg-input:#f8f9fc;--border:#e8eaed;--border-focus:#635bff;--text-primary:#1a1f36;--text-secondary:#6b7280;--text-muted:#9ca3af;--green:#10b981;--green-bg:#ecfdf5;--green-text:#065f46;--red:#ef4444;--red-bg:#fef2f2;--red-text:#991b1b;--blue:#3b82f6;--blue-bg:#eff6ff;--blue-text:#1e40af;--amber:#f59e0b;--amber-bg:#fffbeb;--amber-text:#92400e;--purple:#8b5cf6;--purple-bg:#f5f3ff;--purple-text:#5b21b6;--gray:#6b7280;--gray-bg:#f3f4f6;--gray-text:#374151;--radius-sm:6px;--radius:10px;--radius-lg:14px;--shadow-sm:0 1px 3px #0000000f,0 1px 2px #0000000a;--shadow:0 4px 12px #00000014;--shadow-lg:0 8px 24px #0000001f}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;font-size:16px}body{background:#f5f6fa;background:var(--bg-page);color:#1a1f36;color:var(--text-primary);font-family:Plus Jakarta Sans,sans-serif;font-family:var(--font-main);min-height:100vh}a{color:inherit;text-decoration:none}button{border:none;cursor:pointer}button,input,select,textarea{font-family:inherit;outline:none}.hrms-loading-screen{align-items:center;background:#f5f6fa;background:var(--bg-page);display:flex;flex-direction:column;gap:1rem;justify-content:center;min-height:100vh}.hrms-spinner{animation:spin .7s linear infinite;border:3px solid #e8eaed;border-top-color:#635bff;border:3px solid var(--border);border-radius:50%;border-top-color:var(--brand-accent);height:36px;width:36px}@keyframes spin{to{transform:rotate(1turn)}}.layout,.sidebar{display:flex;min-height:100vh}.sidebar{background:#0f1117;background:var(--sidebar-bg);border-right:1px solid #ffffff0f;border-right:1px solid var(--sidebar-border);bottom:0;flex-direction:column;left:0;position:fixed;top:0;transition:width .2s ease;width:240px;width:var(--sidebar-width);z-index:100}.layout--collapsed .sidebar{width:64px;width:var(--sidebar-collapsed)}.sidebar-brand{border-bottom:1px solid #ffffff0f;border-bottom:1px solid var(--sidebar-border);gap:.625rem;min-height:64px;padding:1.25rem 1rem}.sidebar-brand,.sidebar-logo{align-items:center;display:flex}.sidebar-logo{background:#635bff;background:var(--brand-accent);border-radius:8px;color:#fff;flex-shrink:0;font-size:.75rem;font-weight:800;height:32px;justify-content:center;width:32px}.sidebar-brand-text{display:flex;flex:1 1;flex-direction:column;overflow:hidden}.sidebar-brand-name{color:#fff;font-size:.875rem;font-weight:700;white-space:nowrap}.sidebar-brand-sub{color:#a0aec0;color:var(--sidebar-text);font-size:.7rem;white-space:nowrap}.sidebar-collapse-btn{background:none;border-radius:4px;color:#a0aec0;color:var(--sidebar-text);flex-shrink:0;font-size:.625rem;padding:.25rem;transition:background .15s}.sidebar-collapse-btn:hover{background:#ffffff0d;background:var(--sidebar-hover-bg)}.sidebar-panel-label{color:#a0aec0;color:var(--sidebar-text);font-size:.65rem;font-weight:700;letter-spacing:.08em;padding:.875rem 1rem .375rem;text-transform:uppercase}.sidebar-nav{flex:1 1;overflow-y:auto;padding:.5rem 0}.sidebar-section{margin-bottom:.5rem}.sidebar-section-label{color:#4a5568;display:block;font-size:.65rem;font-weight:600;letter-spacing:.06em;padding:.5rem 1rem .25rem;text-transform:uppercase}.sidebar-nav-item{align-items:center;border-radius:0;color:#a0aec0;color:var(--sidebar-text);display:flex;font-size:.825rem;font-weight:500;gap:.75rem;padding:.5rem 1rem;position:relative;transition:all .15s;white-space:nowrap}.sidebar-nav-item:hover{background:#ffffff0d;background:var(--sidebar-hover-bg);color:#fff}.sidebar-nav-item--active{background:#635bff26!important;background:var(--sidebar-active-bg)!important;color:#635bff!important;color:var(--sidebar-active-text)!important}.sidebar-nav-item--active:before{background:#635bff;background:var(--brand-accent);border-radius:0 2px 2px 0;bottom:0;content:"";left:0;position:absolute;top:0;width:3px}.sidebar-nav-icon{flex-shrink:0;font-size:1rem;text-align:center;width:20px}.sidebar-nav-label{flex:1 1}.sidebar-badge{background:#635bff;background:var(--brand-accent);border-radius:99px;color:#fff;font-size:.65rem;font-weight:700;padding:.1rem .375rem}.sidebar-user{border-top:1px solid #ffffff0f;border-top:1px solid var(--sidebar-border);gap:.625rem;padding:.875rem 1rem}.sidebar-avatar,.sidebar-user{align-items:center;display:flex}.sidebar-avatar{border-radius:50%;color:#fff;flex-shrink:0;font-size:.75rem;font-weight:700;height:32px;justify-content:center;width:32px}.sidebar-user-info{flex:1 1;overflow:hidden}.sidebar-user-name{color:#e2e8f0;display:block;font-size:.8rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-user-id{display:block;font-size:.7rem}.sidebar-logout-btn,.sidebar-user-id{color:#a0aec0;color:var(--sidebar-text)}.sidebar-logout-btn{background:none;border-radius:4px;font-size:1rem;padding:.25rem;transition:color .15s}.sidebar-logout-btn:hover{color:#ef4444;color:var(--red)}.layout-main{display:flex;flex:1 1;flex-direction:column;margin-left:240px;margin-left:var(--sidebar-width);min-height:100vh;transition:margin-left .2s ease}.layout--collapsed .layout-main{margin-left:64px;margin-left:var(--sidebar-collapsed)}.layout-topbar{align-items:center;background:#fff;background:var(--bg-card);border-bottom:1px solid #e8eaed;border-bottom:1px solid var(--border);display:none;gap:1rem;padding:.875rem 1.25rem;position:sticky;top:0;z-index:50}.topbar-menu-btn{background:none;color:#1a1f36;color:var(--text-primary);font-size:1.25rem}.topbar-title{flex:1 1;font-size:.9rem;font-weight:700}.topbar-avatar{align-items:center;border-radius:50%;color:#fff;display:flex;font-size:.7rem;font-weight:700;height:32px;justify-content:center;width:32px}.layout-content{flex:1 1;padding:1.75rem}@media (max-width:768px){.sidebar{transform:translateX(-100%);transition:transform .25s ease}.sidebar--open{transform:translateX(0)}.layout-overlay{background:#00000080;inset:0;position:fixed;z-index:99}.layout-main{margin-left:0!important}.layout-topbar{display:flex}.layout-content{padding:1rem}}.page-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:.75rem;justify-content:space-between;margin-bottom:1.5rem}.page-title{color:#1a1f36;color:var(--text-primary);font-size:1.5rem;font-weight:800;line-height:1.2}.page-subtitle{font-size:.85rem;margin-top:.25rem}.page-subtitle,.user-greeting{color:#6b7280;color:var(--text-secondary)}.user-greeting{align-self:center;font-size:.875rem;font-weight:500}.kpi-grid{grid-gap:1rem;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-bottom:1.5rem}.kpi-card{align-items:flex-start;gap:.875rem;transition:box-shadow .15s}.kpi-card:hover{box-shadow:0 4px 12px #00000014;box-shadow:var(--shadow)}.kpi-icon{line-height:1}.kpi-label{color:#6b7280;color:var(--text-secondary);font-size:.8rem}.kpi-sub{font-size:.72rem}.kpi-card--blue .kpi-value{color:#3b82f6;color:var(--blue)}.kpi-card--green .kpi-value{color:#10b981;color:var(--green)}.kpi-card--red .kpi-value{color:#ef4444;color:var(--red)}.kpi-card--amber .kpi-value{color:#f59e0b;color:var(--amber)}.kpi-card--purple .kpi-value{color:#8b5cf6;color:var(--purple)}.dashboard-grid{grid-gap:1.25rem;gap:1.25rem;grid-template-columns:repeat(auto-fit,minmax(340px,1fr))}.dashboard-card{padding:1.25rem}.card-title{font-size:.9rem}.card-badge{background:#ebe9ff;background:var(--brand-accent-light);border-radius:99px;color:#635bff;color:var(--brand-accent);font-size:.7rem;font-weight:700;padding:.2rem .5rem}.card-loading{font-size:.85rem;padding:1rem 0;text-align:center}.card-empty{font-size:.85rem;padding:1.5rem 0}.two-col-layout{grid-gap:1.25rem;align-items:flex-start;gap:1.25rem;grid-template-columns:minmax(320px,420px) 1fr}@media (max-width:900px){.two-col-layout{grid-template-columns:1fr}}.status-pill{border-radius:99px;letter-spacing:.02em;padding:.2rem .55rem;white-space:nowrap}.attendance-list{gap:.625rem}.attendance-row{gap:.75rem}.attendance-avatar{background:#ebe9ff;background:var(--brand-accent-light);color:#635bff;color:var(--brand-accent);font-size:.7rem;height:32px;width:32px}.attendance-dept{font-size:.72rem}.attendance-time{gap:.2rem}.attendance-checkin{color:#6b7280;color:var(--text-secondary);font-family:JetBrains Mono,monospace;font-family:var(--font-mono);font-size:.75rem}.attendance-summary-row{gap:.875rem;margin-bottom:1.25rem}.summary-chip{flex-direction:column;min-width:90px;padding:.75rem 1.25rem}.summary-chip-count{font-size:1.5rem}.summary-chip--green .summary-chip-count{color:#10b981;color:var(--green)}.summary-chip--red .summary-chip-count{color:#ef4444;color:var(--red)}.summary-chip--blue .summary-chip-count{color:#3b82f6;color:var(--blue)}.summary-chip--amber .summary-chip-count{color:#f59e0b;color:var(--amber)}.summary-chip-label{color:#6b7280;color:var(--text-secondary);font-size:.72rem;font-weight:600}.attendance-widget .mode-toggle{display:flex;gap:.5rem;margin-bottom:1rem}.mode-btn{background:#f8f9fc;background:var(--bg-input);border:1.5px solid #e8eaed;border:1.5px solid var(--border);border-radius:6px;border-radius:var(--radius-sm);color:#6b7280;color:var(--text-secondary);flex:1 1;font-size:.8rem;font-weight:600;padding:.5rem;transition:all .15s}.mode-btn--active{background:#ebe9ff;background:var(--brand-accent-light);border-color:#635bff;border-color:var(--brand-accent);color:#635bff;color:var(--brand-accent)}.attendance-status-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:1fr 1fr;margin-bottom:1rem}.att-stat{display:flex;flex-direction:column;gap:.2rem}.att-stat-label{color:#9ca3af;color:var(--text-muted);font-size:.72rem;font-weight:500}.att-stat-value{font-family:JetBrains Mono,monospace;font-family:var(--font-mono);font-size:1rem;font-weight:700}.hours-progress{background:#f8f9fc;background:var(--bg-input);border-radius:99px;height:8px;margin-bottom:1rem;overflow:hidden;position:relative}.hours-progress-bar{background:#635bff;background:var(--brand-accent);border-radius:99px;bottom:0;left:0;position:absolute;top:0;transition:width .3s ease}.hours-progress-label{color:#9ca3af;color:var(--text-muted);display:block;font-size:.72rem;margin-top:.375rem;text-align:center}.live-clock{color:#6b7280;color:var(--text-secondary);font-family:JetBrains Mono,monospace;font-family:var(--font-mono);font-size:.875rem}.att-actions{display:flex;justify-content:center}.btn-checkin,.btn-checkout{border:none;border-radius:10px;border-radius:var(--radius);cursor:pointer;font-size:.875rem;font-weight:700;padding:.625rem 1.5rem;transition:all .15s}.btn-checkin{background:#10b981;background:var(--green);color:#fff}.btn-checkin:hover{background:#059669;box-shadow:0 4px 12px #00000014;box-shadow:var(--shadow)}.btn-checkout{background:#ef4444;background:var(--red);color:#fff}.btn-checkout:hover{background:#dc2626;box-shadow:0 4px 12px #00000014;box-shadow:var(--shadow)}.btn-checkin:disabled,.btn-checkout:disabled{cursor:not-allowed;opacity:.6}.att-done{align-items:center;color:#10b981;color:var(--green);display:flex;flex-wrap:wrap;font-size:.85rem;font-weight:600;gap:.5rem}.late-badge{background:#fffbeb;background:var(--amber-bg);border-radius:4px;color:#92400e;color:var(--amber-text);font-size:.72rem;font-weight:600;padding:.15rem .4rem}.meetings-list{display:flex;flex-direction:column;gap:.625rem}.meeting-row{align-items:center;display:flex;gap:.75rem}.meeting-dot{background:#635bff;background:var(--brand-accent);border-radius:50%;flex-shrink:0;height:8px;width:8px}.meeting-info{display:flex;flex:1 1;flex-direction:column}.meeting-title{font-size:.825rem;font-weight:600}.meeting-time{color:#9ca3af;color:var(--text-muted);font-size:.72rem}.meeting-join-btn{background:#ebe9ff;background:var(--brand-accent-light);border-radius:6px;border-radius:var(--radius-sm);color:#635bff;color:var(--brand-accent);font-size:.75rem;font-weight:700;padding:.25rem .625rem;transition:background .15s}.meeting-join-btn:hover{background:#d4cfff}.meetings-full-list{display:flex;flex-direction:column;gap:.875rem}.meeting-card{background:#f8f9fc;background:var(--bg-input);border:1px solid #e8eaed;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius);padding:1rem}.meeting-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.meeting-card-title{font-size:.9rem;font-weight:700}.meeting-card-meta{color:#9ca3af;color:var(--text-muted);display:flex;font-size:.775rem;justify-content:space-between;margin-bottom:.5rem}.meeting-card-agenda{color:#6b7280;color:var(--text-secondary);font-size:.8rem;line-height:1.5;margin-bottom:.625rem}.announcements-list{gap:.75rem}.announcement-priority-dot{margin-top:4px}.announcement-audience{color:#9ca3af;color:var(--text-muted);font-size:.7rem}.announcements-full-list{display:flex;flex-direction:column;gap:.875rem}.announcement-card{border-left:3px solid;border-radius:10px;border-radius:var(--radius);padding:1rem}.announcement-card.priority-high{background:#fef2f2;background:var(--red-bg);border-color:#ef4444;border-color:var(--red)}.announcement-card.priority-medium{background:#fffbeb;background:var(--amber-bg);border-color:#f59e0b;border-color:var(--amber)}.announcement-card.priority-low{background:#ecfdf5;background:var(--green-bg);border-color:#10b981;border-color:var(--green)}.announcement-card-header{align-items:center;display:flex;font-size:.875rem;font-weight:700;justify-content:space-between;margin-bottom:.5rem}.announcement-card-msg{font-size:.8rem;line-height:1.5;margin-bottom:.5rem}.announcement-card-meta{color:#9ca3af;color:var(--text-muted);display:flex;font-size:.72rem;justify-content:space-between}.task-list{gap:.5rem}.task-row{align-items:center;gap:.75rem}.task-row-info{display:flex;flex-direction:column;gap:.15rem}.task-row-meta{font-size:.72rem}.task-card{background:#f8f9fc;background:var(--bg-input);border:1px solid #e8eaed;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius);padding:.875rem}.task-card-header{align-items:flex-start;display:flex;gap:.5rem;justify-content:space-between;margin-bottom:.5rem}.task-title{font-size:.875rem;font-weight:700}.task-card-meta{color:#9ca3af;color:var(--text-muted);display:flex;font-size:.75rem;gap:1rem}.task-cards-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.task-detail-card{background:#fff;background:var(--bg-card);border:1px solid #e8eaed;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius-lg);box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a;box-shadow:var(--shadow-sm);padding:1.125rem}.priority-border-high{border-left:3px solid #ef4444;border-left:3px solid var(--red)}.priority-border-medium{border-left:3px solid #f59e0b;border-left:3px solid var(--amber)}.priority-border-low{border-left:3px solid #10b981;border-left:3px solid var(--green)}.task-detail-header{align-items:flex-start;display:flex;gap:.5rem;justify-content:space-between;margin-bottom:.625rem}.task-detail-title{flex:1 1;font-size:.9rem;font-weight:700}.task-detail-desc{color:#6b7280;color:var(--text-secondary);font-size:.8rem;line-height:1.5;margin-bottom:.625rem}.task-detail-meta{color:#9ca3af;color:var(--text-muted);display:flex;flex-direction:column;font-size:.775rem;gap:.2rem;margin-bottom:.75rem}.task-detail-actions{align-items:center;display:flex;gap:.625rem}.status-select{border:1.5px solid #0000;border-radius:6px;border-radius:var(--radius-sm);cursor:pointer;font-size:.78rem;font-weight:600;padding:.3rem .625rem}.status-select--green{background:#ecfdf5;background:var(--green-bg);border-color:#10b981;border-color:var(--green);color:#065f46;color:var(--green-text)}.status-select--blue{background:#eff6ff;background:var(--blue-bg);border-color:#3b82f6;border-color:var(--blue);color:#1e40af;color:var(--blue-text)}.status-select--gray{background:#f3f4f6;background:var(--gray-bg);border-color:#6b7280;border-color:var(--gray);color:#374151;color:var(--gray-text)}.leave-balance-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(3,1fr)}.leave-card{border-radius:10px;border-radius:var(--radius);display:flex;flex-direction:column;gap:.25rem;padding:.875rem}.leave-card--blue{background:#eff6ff;background:var(--blue-bg)}.leave-card--green{background:#ecfdf5;background:var(--green-bg)}.leave-card--amber{background:#fffbeb;background:var(--amber-bg)}.leave-card-type{color:#9ca3af;color:var(--text-muted);font-size:.72rem;font-weight:600}.leave-card-balance{font-size:1.5rem;font-weight:800}.leave-card--blue .leave-card-balance{color:#3b82f6;color:var(--blue)}.leave-card--green .leave-card-balance{color:#10b981;color:var(--green)}.leave-card--amber .leave-card-balance{color:#f59e0b;color:var(--amber)}.leave-card-sub{color:#9ca3af;color:var(--text-muted);font-size:.7rem}.leave-card-bar{background:#00000014;border-radius:99px;height:4px;margin-top:.25rem;overflow:hidden}.leave-card-fill{border-radius:99px;height:100%}.leave-card--blue .leave-card-fill{background:#3b82f6;background:var(--blue)}.leave-card--green .leave-card-fill{background:#10b981;background:var(--green)}.leave-card--amber .leave-card-fill{background:#f59e0b;background:var(--amber)}.leave-balance-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-bottom:1.5rem}.leave-balance-card{background:#fff;background:var(--bg-card);border:1px solid #e8eaed;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius-lg);box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:.3rem;padding:1.125rem}.lbc-label{color:#6b7280;color:var(--text-secondary);font-size:.75rem;font-weight:600}.lbc-balance{font-size:2rem;font-weight:800}.leave-balance-card--blue .lbc-balance{color:#3b82f6;color:var(--blue)}.leave-balance-card--green .lbc-balance{color:#10b981;color:var(--green)}.leave-balance-card--amber .lbc-balance{color:#f59e0b;color:var(--amber)}.lbc-sub{color:#9ca3af;color:var(--text-muted);font-size:.72rem}.lbc-bar{background:#e8eaed;background:var(--border);border-radius:99px;height:5px;margin-top:.25rem;overflow:hidden}.lbc-fill{border-radius:99px;height:100%}.leave-balance-card--blue .lbc-fill{background:#3b82f6;background:var(--blue)}.leave-balance-card--green .lbc-fill{background:#10b981;background:var(--green)}.leave-balance-card--amber .lbc-fill{background:#f59e0b;background:var(--amber)}.leave-history-list{display:flex;flex-direction:column;gap:.75rem}.leave-history-item{border:1px solid #e8eaed;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius);padding:.875rem}.leave-history-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.375rem}.leave-history-type{font-size:.825rem;font-weight:700}.leave-history-dates{color:#9ca3af;color:var(--text-muted);font-size:.775rem;margin-bottom:.25rem}.leave-history-reason{color:#6b7280;color:var(--text-secondary);font-size:.775rem}.leave-requests-list{display:flex;flex-direction:column;gap:.75rem}.leave-request-item{border:1px solid #e8eaed;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius);padding:.875rem}.leave-request-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.375rem}.leave-request-name{font-size:.825rem;font-weight:700}.leave-request-type{color:#6b7280;color:var(--text-secondary);font-size:.775rem;margin-bottom:.25rem}.leave-request-dates{color:#9ca3af;color:var(--text-muted);font-size:.775rem;margin-bottom:.25rem}.leave-request-reason{color:#6b7280;color:var(--text-secondary);font-size:.775rem;margin-bottom:.5rem}.leave-request-actions{display:flex;gap:.5rem}.dept-breakdown{display:flex;flex-direction:column;gap:.625rem}.dept-row{align-items:center;display:flex;gap:.75rem}.dept-name{flex-shrink:0;font-size:.8rem;font-weight:500;width:90px}.dept-bar-wrap{background:#f8f9fc;background:var(--bg-input);border-radius:99px;flex:1 1;height:6px;overflow:hidden}.dept-bar{background:#635bff;background:var(--brand-accent);border-radius:99px;height:100%;transition:width .4s ease}.dept-count{font-size:.78rem;font-weight:700;text-align:right;width:24px}.form-card{background:#fff;background:var(--bg-card);border:1px solid #e8eaed;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius-lg);box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a;box-shadow:var(--shadow-sm);padding:1.5rem}.form-card-title{font-size:1rem;font-weight:700;margin-bottom:1.25rem}.form-group{display:flex;flex-direction:column;gap:.375rem;margin-bottom:1rem}.form-group label{color:#6b7280;color:var(--text-secondary);font-size:.8rem;font-weight:600}.form-group input,.form-group select,.form-group textarea{background:#f8f9fc;background:var(--bg-input);border:1.5px solid #e8eaed;border:1.5px solid var(--border);border-radius:6px;border-radius:var(--radius-sm);color:#1a1f36;color:var(--text-primary);font-size:.875rem;padding:.5625rem .75rem;transition:border-color .15s;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{background:#fff;border-color:#635bff;border-color:var(--brand-accent)}.form-group textarea{min-height:80px;resize:vertical}.form-row{display:grid;grid-template-columns:1fr 1fr}.form-grid,.form-row{grid-gap:.75rem;gap:.75rem}.form-group--full{grid-column:1/-1}.form-error{background:#fef2f2;background:var(--red-bg);color:#991b1b;color:var(--red-text)}.form-error,.form-success{border-radius:6px;border-radius:var(--radius-sm);font-size:.825rem;margin-bottom:.875rem;padding:.625rem .875rem}.form-success{background:#ecfdf5;background:var(--green-bg);color:#065f46;color:var(--green-text)}.btn-primary{align-items:center;background:#635bff;background:var(--brand-accent);border:none;border-radius:6px;border-radius:var(--radius-sm);color:#fff;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:700;gap:.375rem;padding:.5625rem 1.25rem;transition:all .15s}.btn-primary:hover:not(:disabled){background:#5147e6;box-shadow:0 4px 12px #00000014;box-shadow:var(--shadow)}.btn-primary:disabled{cursor:not-allowed;opacity:.6}.btn-ghost-sm{background:none;border:1.5px solid #e8eaed;border:1.5px solid var(--border);border-radius:6px;border-radius:var(--radius-sm);color:#6b7280;color:var(--text-secondary);font-size:.775rem;font-weight:600;padding:.3rem .75rem;transition:all .15s}.btn-ghost-sm:hover{border-color:#635bff;border-color:var(--brand-accent);color:#635bff;color:var(--brand-accent)}.btn-ghost-sm:disabled{cursor:not-allowed;opacity:.5}.btn-success-sm{background:#10b981;background:var(--green);border:none;color:#fff;cursor:pointer;font-weight:600}.btn-success-sm:hover:not(:disabled){background:#059669}.btn-success-sm:disabled{opacity:.6}.btn-danger-sm{background:#ef4444;background:var(--red);border:none;color:#fff;cursor:pointer;font-weight:600}.btn-danger-sm:hover:not(:disabled){background:#dc2626}.btn-danger-sm:disabled{opacity:.6}.btn-success-sm{background:#ecfdf5;background:var(--green-bg);border:1.5px solid #10b981;border:1.5px solid var(--green);border-radius:6px;border-radius:var(--radius-sm);color:#065f46;color:var(--green-text);font-size:.775rem;font-weight:700;padding:.3rem .75rem;transition:all .15s}.btn-success-sm:hover:not(:disabled){background:#10b981;background:var(--green);color:#fff}.btn-success-sm:disabled{cursor:not-allowed;opacity:.5}.btn-danger-sm{background:#fef2f2;background:var(--red-bg);border:1.5px solid #ef4444;border:1.5px solid var(--red);border-radius:6px;border-radius:var(--radius-sm);color:#991b1b;color:var(--red-text);font-size:.775rem;font-weight:700;padding:.3rem .75rem;transition:all .15s}.btn-danger-sm:hover:not(:disabled){background:#ef4444;background:var(--red);color:#fff}.btn-danger-sm:disabled{cursor:not-allowed;opacity:.5}.action-btns{display:flex;gap:.375rem}.table-filters{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1rem}.filter-search{background:#fff;background:var(--bg-card);border:1.5px solid #e8eaed;border:1.5px solid var(--border);border-radius:6px;border-radius:var(--radius-sm);font-size:.85rem;min-width:220px;padding:.5rem .875rem}.filter-search:focus{border-color:#635bff;border-color:var(--brand-accent);outline:none}.filter-select{background:#fff;background:var(--bg-card);border:1.5px solid #e8eaed;border:1.5px solid var(--border);border-radius:6px;border-radius:var(--radius-sm);cursor:pointer;font-size:.85rem;padding:.5rem .875rem}.filter-select:focus{border-color:#635bff;border-color:var(--brand-accent);outline:none}.filter-select-sm{border:1.5px solid #e8eaed;border:1.5px solid var(--border);border-radius:6px;border-radius:var(--radius-sm);cursor:pointer;font-size:.775rem;padding:.25rem .5rem}.data-table-wrap{border:1px solid #e8eaed;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius-lg);overflow-x:auto}.data-table{background:#fff;background:var(--bg-card);border-collapse:collapse;width:100%}.data-table thead tr{background:#f8f9fc;background:var(--bg-input)}.data-table th{color:#6b7280;color:var(--text-secondary);font-size:.75rem;font-weight:700;letter-spacing:.04em;padding:.75rem 1rem;text-align:left;text-transform:uppercase;white-space:nowrap}.data-table td{border-top:1px solid #e8eaed;border-top:1px solid var(--border);font-size:.825rem;padding:.75rem 1rem;vertical-align:middle}.data-table tbody tr:hover{background:#f8f9fc;background:var(--bg-input)}.table-user-cell{gap:.625rem}.table-avatar,.table-user-cell{align-items:center;display:flex}.table-avatar{background:#ebe9ff;background:var(--brand-accent-light);border-radius:50%;color:#635bff;color:var(--brand-accent);flex-shrink:0;font-size:.65rem;font-weight:700;height:28px;justify-content:center;width:28px}.table-empty{color:#9ca3af;color:var(--text-muted);padding:2rem!important;text-align:center}.login-page{display:flex;min-height:100vh}.login-brand{align-items:center;background:linear-gradient(135deg,#0f1117,#1a1f36 50%,#1e2a4a);display:flex;justify-content:center;overflow:hidden;padding:2rem;position:relative;width:42%}.login-brand:before{background:radial-gradient(circle,#635bff26 0,#0000 70%);border-radius:50%;content:"";height:500px;position:absolute;right:-30%;top:-50%;width:500px}.login-brand-inner{max-width:340px;z-index:1}.login-logo{align-items:center;background:#635bff;background:var(--brand-accent);border-radius:16px;box-shadow:0 8px 24px #635bff66;color:#fff;display:flex;font-size:1.25rem;font-weight:800;height:56px;justify-content:center;margin-bottom:1.5rem;width:56px}.login-logo-text{letter-spacing:-.5px}.login-brand-name{color:#fff;font-size:2rem;font-weight:800;line-height:1.1;margin-bottom:.5rem}.login-brand-tagline{color:#a0aec0;font-size:.9rem;margin-bottom:2.5rem}.login-brand-features{display:flex;flex-direction:column;gap:.875rem}.login-feature-item{align-items:center;color:#cbd5e0;display:flex;font-size:.875rem;gap:.75rem}.login-feature-icon{font-size:1.1rem}.login-form-panel{align-items:center;background:#f5f6fa;background:var(--bg-page);display:flex;flex:1 1;justify-content:center;padding:2rem}.login-form-card{background:#fff;background:var(--bg-card);border:1px solid #e8eaed;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius-lg);box-shadow:0 8px 24px #0000001f;box-shadow:var(--shadow-lg);max-width:420px;padding:2.5rem 2rem;width:100%}.login-form-title{font-size:1.625rem;font-weight:800;margin-bottom:.375rem}.login-form-subtitle{color:#6b7280;color:var(--text-secondary);font-size:.85rem;margin-bottom:1.75rem}.login-error{background:#fef2f2;background:var(--red-bg);color:#991b1b;color:var(--red-text)}.login-error,.login-success{border-radius:6px;border-radius:var(--radius-sm);font-size:.825rem;margin-bottom:1rem;padding:.625rem .875rem}.login-success{background:#ecfdf5;background:var(--green-bg);color:#065f46;color:var(--green-text)}.login-form .form-group{margin-bottom:1.125rem}.login-form .form-group label{color:#1a1f36;color:var(--text-primary);font-size:.825rem;font-weight:600;margin-bottom:.4rem}.login-form .form-group input{background:#f8f9fc;background:var(--bg-input);border:1.5px solid #e8eaed;border:1.5px solid var(--border);border-radius:6px;border-radius:var(--radius-sm);font-size:.9rem;padding:.625rem .875rem;transition:border-color .15s;width:100%}.login-form .form-group input:focus{background:#fff;border-color:#635bff;border-color:var(--brand-accent)}.input-with-icon{position:relative}.input-with-icon input{padding-right:2.5rem}.input-icon-btn{background:none;color:#9ca3af;color:var(--text-muted);font-size:.9rem;padding:.2rem;position:absolute;right:.625rem;top:50%;transform:translateY(-50%)}.login-btn-primary{background:#635bff;background:var(--brand-accent);border:none;border-radius:6px;border-radius:var(--radius-sm);color:#fff;cursor:pointer;font-size:.9rem;font-weight:700;margin-top:.25rem;padding:.75rem;transition:all .15s;width:100%}.login-btn-primary:hover:not(:disabled){background:#5147e6;box-shadow:0 4px 12px #00000014;box-shadow:var(--shadow)}.login-btn-primary:disabled{cursor:not-allowed;opacity:.6}.login-form-footer{margin-top:1rem;text-align:center}.login-link-btn{background:none;border:none;color:#635bff;color:var(--brand-accent);cursor:pointer;font-size:.85rem;font-weight:600;padding:0}.login-link-btn:hover{text-decoration:underline}.login-note{color:#9ca3af;color:var(--text-muted);font-size:.775rem;margin-top:1.25rem;text-align:center}@media (max-width:768px){.login-brand{display:none}.login-form-panel{padding:1rem}}.kpi-card{align-items:center;background:#fff;background:var(--bg-card);border:1px solid #e8eaed;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius-lg);box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a;box-shadow:var(--shadow-sm);display:flex;gap:1rem;min-height:80px;padding:1.25rem}.kpi-card--blue{border-left:3px solid #3b82f6;border-left:3px solid var(--blue)}.kpi-card--green{border-left:3px solid #10b981;border-left:3px solid var(--green)}.kpi-card--red{border-left:3px solid #ef4444;border-left:3px solid var(--red)}.kpi-card--amber{border-left:3px solid #f59e0b;border-left:3px solid var(--amber)}.kpi-card--purple{border-left:3px solid #8b5cf6;border-left:3px solid var(--purple)}.kpi-card--clickable{cursor:pointer;transition:all .15s}.kpi-card--clickable:hover{box-shadow:0 4px 12px #00000014;box-shadow:var(--shadow);transform:translateY(-2px)}.kpi-icon{flex-shrink:0;font-size:1.5rem}.kpi-body{display:flex;flex:1 1;flex-direction:column;gap:.125rem}.kpi-value{font-size:1.75rem;font-weight:800;line-height:1}.kpi-label{color:#1a1f36;color:var(--text-primary);font-size:.875rem;font-weight:600}.kpi-sub{color:#9ca3af;color:var(--text-muted);font-size:.75rem}.status-pill{align-items:center;border-radius:6px;border-radius:var(--radius-sm);display:inline-flex;font-size:.7rem;font-weight:600;letter-spacing:.025em;padding:.25rem .5rem;text-transform:uppercase}.status-pill--green{background:#ecfdf5;background:var(--green-bg);color:#065f46;color:var(--green-text)}.status-pill--red{background:#fef2f2;background:var(--red-bg);color:#991b1b;color:var(--red-text)}.status-pill--blue{background:#eff6ff;background:var(--blue-bg);color:#1e40af;color:var(--blue-text)}.status-pill--amber{background:#fffbeb;background:var(--amber-bg);color:#92400e;color:var(--amber-text)}.status-pill--gray{background:#f3f4f6;background:var(--gray-bg);color:#374151;color:var(--gray-text)}.kpi-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.kpi-grid--3{grid-template-columns:repeat(3,1fr)}@media (max-width:768px){.kpi-grid--3{grid-template-columns:1fr}}.dashboard-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.dashboard-card{background:#fff;background:var(--bg-card);border:1px solid #e8eaed;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius-lg);box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a;box-shadow:var(--shadow-sm);min-height:120px;padding:1.5rem}.card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.card-title{color:#1a1f36;color:var(--text-primary);font-size:1rem;font-weight:700}.card-badge{background:#eff6ff;background:var(--blue-bg);border-radius:6px;border-radius:var(--radius-sm);color:#1e40af;color:var(--blue-text);font-size:.75rem;font-weight:600;padding:.25rem .5rem}.card-link{color:#635bff;color:var(--brand-accent);font-size:.8rem;font-weight:600;text-decoration:none}.card-link:hover{text-decoration:underline}.card-empty,.card-loading{align-items:center;color:#9ca3af;color:var(--text-muted);display:flex;font-size:.9rem;justify-content:center;padding:2rem}.card-empty{text-align:center}.two-col-layout{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}@media (max-width:1024px){.two-col-layout{grid-template-columns:1fr}}.leave-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(2,1fr)}@media (max-width:600px){.leave-grid{grid-template-columns:1fr}}.form-row{align-items:end;display:flex;gap:15px}@media (max-width:600px){.form-row{flex-direction:column;gap:10px}}.team-row{align-items:center;display:flex;justify-content:space-between}.attendance-list{display:flex;flex-direction:column;gap:.75rem}.attendance-row{align-items:center;background:#f8f9fc;background:var(--bg-input);border-radius:10px;border-radius:var(--radius);display:flex;gap:.875rem;padding:.75rem;transition:background .15s}.attendance-row:hover{background:#635bff0d}.attendance-avatar{align-items:center;background:#635bff;background:var(--brand-accent);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:.75rem;font-weight:700;height:36px;justify-content:center;width:36px}.attendance-info{flex:1 1}.attendance-name{font-size:.825rem;font-weight:600}.attendance-dept{color:#9ca3af;color:var(--text-muted);font-size:.75rem}.attendance-time{align-items:flex-end;display:flex;flex-direction:column;gap:.25rem}.attendance-checkin{color:#1a1f36;color:var(--text-primary);font-size:.775rem;font-weight:600}.task-list{display:flex;flex-direction:column;gap:.75rem}.task-row{align-items:flex-start;background:#f8f9fc;background:var(--bg-input);border-radius:10px;border-radius:var(--radius);display:flex;justify-content:space-between;padding:.75rem;transition:background .15s}.task-row:hover{background:#635bff0d}.task-row-info{flex:1 1}.task-row-title{font-size:.825rem;font-weight:600;margin-bottom:.25rem}.task-row-meta{color:#9ca3af;color:var(--text-muted);font-size:.75rem}.attendance-summary-row{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.summary-chip{align-items:center;border-radius:10px;border-radius:var(--radius);display:flex;font-size:.875rem;font-weight:600;gap:.5rem;padding:.5rem .875rem}.summary-chip--green{background:#ecfdf5;background:var(--green-bg);color:#065f46;color:var(--green-text)}.summary-chip--amber{background:#fffbeb;background:var(--amber-bg);color:#92400e;color:var(--amber-text)}.summary-chip--red{background:#fef2f2;background:var(--red-bg);color:#991b1b;color:var(--red-text)}.summary-chip--blue{background:#eff6ff;background:var(--blue-bg);color:#1e40af;color:var(--blue-text)}.summary-chip-count{font-size:1.125rem;font-weight:800}.summary-chip-label{font-size:.8rem}.attendance-status-row{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.status-display{align-items:center;display:flex;gap:1rem}.live-time{color:#635bff;color:var(--brand-accent);font-family:JetBrains Mono,monospace;font-family:var(--font-mono);font-size:1.25rem;font-weight:700}.attendance-info{display:flex;flex-direction:column;gap:.25rem}.check-times{color:#6b7280;color:var(--text-secondary);display:flex;font-size:.875rem;gap:1rem}.hours-worked{color:#1a1f36;color:var(--text-primary);font-size:.875rem;font-weight:600}.break-timer{color:#f59e0b;color:var(--amber);font-size:.8rem;font-weight:600}.no-attendance{color:#9ca3af;color:var(--text-muted);font-size:.875rem;font-style:italic}.btn-break{background:#fffbeb;background:var(--amber-bg);border:1px solid #f59e0b;border:1px solid var(--amber);border-radius:6px;border-radius:var(--radius-sm);color:#92400e;color:var(--amber-text);cursor:pointer;font-size:.8rem;font-weight:600;padding:.5rem 1rem;transition:all .15s}.btn-break:hover:not(:disabled){background:#f59e0b;background:var(--amber);color:#fff}.btn-break:disabled{cursor:not-allowed;opacity:.6}.btn-end-break{background:#10b981;background:var(--green);border:none;border-radius:6px;border-radius:var(--radius-sm);color:#fff;cursor:pointer;font-size:.875rem;font-weight:700;margin-top:1rem;padding:.625rem 1.25rem;transition:all .15s;width:100%}.btn-end-break:hover:not(:disabled){background:#059669}.btn-end-break:disabled{cursor:not-allowed;opacity:.6}.hrms-loading-msg{color:#6b7280;color:var(--text-secondary);font-size:.9rem;font-weight:600;margin-top:.5rem}.hrms-loading-sub{color:#9ca3af;color:var(--text-muted);font-size:.8rem;line-height:1.5;margin-top:.375rem;max-width:320px;text-align:center}.form-grid{grid-gap:0 .75rem;display:grid;gap:0 .75rem;grid-template-columns:1fr 1fr}@media (max-width:600px){.form-grid,.form-row{grid-template-columns:1fr}}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.text-muted{color:#9ca3af;color:var(--text-muted);font-size:.8rem}.sidebar-avatar-wrap{flex-shrink:0;position:relative}.sidebar-meeting-dot{animation:meeting-dot-pulse 1.8s ease-in-out infinite;background:#22c55e;border:2px solid #0f1117;border:2px solid var(--sidebar-bg);border-radius:50%;bottom:1px;height:10px;position:absolute;right:1px;width:10px}.topbar-avatar-wrap{position:relative}.topbar-meeting-dot{animation:meeting-dot-pulse 1.8s ease-in-out infinite;background:#22c55e;border:2px solid #fff;border-radius:50%;bottom:1px;height:9px;position:absolute;right:1px;width:9px}@keyframes meeting-dot-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.3)}}.sidebar-inmeet-label{animation:meeting-dot-pulse 1.8s ease-in-out infinite;color:#22c55e;font-size:.68rem;font-weight:700;letter-spacing:.02em}.sidebar-meeting-banner{align-items:center;background:#22c55e1a;border-bottom:1px solid #22c55e33;border-top:1px solid #22c55e33;display:flex;gap:.5rem;padding:.5rem 1rem}.sidebar-meeting-banner--collapsed{justify-content:center;padding:.5rem}.sidebar-meeting-pulse{animation:meeting-dot-pulse 1.8s ease-in-out infinite;background:#22c55e;border-radius:50%;flex-shrink:0;height:8px;width:8px}.sidebar-meeting-text{color:#22c55e;flex:1 1;font-size:.75rem;font-weight:700}.sidebar-meeting-leave{background:none;border:none;border-radius:3px;color:#22c55e;cursor:pointer;font-size:.7rem;opacity:.7;padding:.1rem .3rem;transition:opacity .15s}.sidebar-meeting-leave:hover{opacity:1}.meeting-card--active{background:#f0fdf4!important;border-color:#22c55e!important}.meeting-card-actions{margin-top:.75rem}.btn-join-meeting{align-items:center;background:#635bff;background:var(--brand-accent);border:none;border-radius:6px;border-radius:var(--radius-sm);color:#fff;cursor:pointer;display:inline-flex;font-size:.825rem;font-weight:700;gap:.375rem;padding:.45rem 1rem;transition:all .15s}.btn-join-meeting:hover:not(:disabled){background:#5147e6;box-shadow:0 4px 12px #00000014;box-shadow:var(--shadow)}.btn-join-meeting:disabled{cursor:not-allowed;opacity:.45}.btn-leave-meeting{align-items:center;background:#fef2f2;border:1.5px solid #ef4444;border-radius:6px;border-radius:var(--radius-sm);color:#991b1b;cursor:pointer;display:inline-flex;font-size:.825rem;font-weight:700;gap:.375rem;padding:.45rem 1rem;transition:all .15s}.btn-leave-meeting:hover{background:#ef4444;color:#fff}.meeting-active-row{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem;justify-content:space-between}.meeting-active-indicator{align-items:center;color:#15803d;display:flex;font-size:.825rem;font-weight:600;gap:.5rem}.meeting-active-pulse{animation:meeting-dot-pulse 1.8s ease-in-out infinite;background:#22c55e;border-radius:50%;flex-shrink:0;height:8px;width:8px}.recurrence-tabs{display:flex;flex-wrap:wrap;gap:.375rem}.recurrence-tab{background:#f8f9fc;background:var(--bg-input);border:1.5px solid #e8eaed;border:1.5px solid var(--border);border-radius:6px;border-radius:var(--radius-sm);color:#6b7280;color:var(--text-secondary);cursor:pointer;font-size:.8rem;font-weight:600;padding:.375rem .75rem;transition:all .15s;white-space:nowrap}.recurrence-tab--active,.recurrence-tab:hover{border-color:#635bff;border-color:var(--brand-accent);color:#635bff;color:var(--brand-accent)}.recurrence-tab--active{background:#ebe9ff;background:var(--brand-accent-light)}.day-picker{display:flex;flex-wrap:wrap;gap:.375rem}.day-btn{align-items:center;background:#f8f9fc;background:var(--bg-input);border:1.5px solid #e8eaed;border:1.5px solid var(--border);border-radius:50%;color:#6b7280;color:var(--text-secondary);cursor:pointer;display:flex;font-size:.72rem;font-weight:700;height:40px;justify-content:center;transition:all .15s;width:40px}.day-btn:hover{color:#635bff;color:var(--brand-accent)}.day-btn--active,.day-btn:hover{border-color:#635bff;border-color:var(--brand-accent)}.day-btn--active{background:#635bff;background:var(--brand-accent);color:#fff}.recurrence-preview{background:#eff6ff;background:var(--blue-bg);border:1px solid #3b82f6;border:1px solid var(--blue);border-radius:6px;border-radius:var(--radius-sm);color:#1e40af;color:var(--blue-text);font-size:.8rem;margin-bottom:.875rem;padding:.5rem .75rem}.recurrence-preview strong{font-weight:800}.meeting-recurrence-badge{align-items:center;background:#ebe9ff;background:var(--brand-accent-light);border-radius:99px;color:#635bff;color:var(--brand-accent);display:inline-flex;font-size:.72rem;font-weight:600;gap:.3rem;margin-bottom:.375rem;padding:.2rem .5rem}.meeting-card--expired{background:#f3f4f6!important;background:var(--gray-bg)!important;border-color:#e8eaed!important;border-color:var(--border)!important;opacity:.75}.meeting-link-expired{align-items:center;background:#f3f4f6;background:var(--gray-bg);border:1px solid #e8eaed;border:1px solid var(--border);border-radius:6px;border-radius:var(--radius-sm);color:#9ca3af;color:var(--text-muted);display:inline-flex;font-size:.8rem;font-weight:600;gap:.375rem;padding:.35rem .75rem}.meetings-tab-toggle{background:#f8f9fc;background:var(--bg-input);border-radius:6px;border-radius:var(--radius-sm);display:flex;gap:.25rem;padding:.2rem}.meetings-tab-btn{background:none;border:none;border-radius:4px;color:#9ca3af;color:var(--text-muted);cursor:pointer;font-size:.75rem;font-weight:600;padding:.25rem .625rem;transition:all .15s;white-space:nowrap}.meetings-tab-btn--active{box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a;box-shadow:var(--shadow-sm);color:#1a1f36;color:var(--text-primary)}.att-tab-bar,.meetings-tab-btn--active{background:#fff;background:var(--bg-card)}.att-tab-bar{border:1px solid #e8eaed;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius);display:flex;gap:.375rem;margin-bottom:1.25rem;padding:.3rem;width:fit-content}.att-tab-btn{background:none;border:none;border-radius:7px;color:#6b7280;color:var(--text-secondary);cursor:pointer;font-size:.825rem;font-weight:600;padding:.45rem 1rem;transition:all .15s;white-space:nowrap}.att-tab-btn:hover{background:#f8f9fc;background:var(--bg-input);color:#1a1f36;color:var(--text-primary)}.att-tab-btn--active{background:#635bff;background:var(--brand-accent);box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a;box-shadow:var(--shadow-sm);color:#fff}.report-controls{align-items:flex-end;background:#fff;background:var(--bg-card);border:1px solid #e8eaed;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius);display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:.25rem;padding:1rem 1.25rem}.report-controls-left{align-items:center;display:flex;flex-wrap:wrap;gap:.625rem}.report-label{color:#6b7280;color:var(--text-secondary);font-size:.8rem;font-weight:600}.report-date-input,.report-select{background:#f8f9fc;background:var(--bg-input);border:1.5px solid #e8eaed;border:1.5px solid var(--border);border-radius:6px;border-radius:var(--radius-sm);color:#1a1f36;color:var(--text-primary);cursor:pointer;font-family:Plus Jakarta Sans,sans-serif;font-family:var(--font-main);font-size:.875rem;padding:.5rem .75rem;transition:border-color .15s}.report-date-input:focus,.report-select:focus{border-color:#635bff;border-color:var(--brand-accent);outline:none}.btn-download{align-items:center;background:#ecfdf5;background:var(--green-bg);border:1.5px solid #10b981;border:1.5px solid var(--green);border-radius:6px;border-radius:var(--radius-sm);color:#065f46;color:var(--green-text);cursor:pointer;display:inline-flex;font-family:Plus Jakarta Sans,sans-serif;font-family:var(--font-main);font-size:.825rem;font-weight:700;gap:.375rem;padding:.5rem 1.125rem;transition:all .15s;white-space:nowrap}.btn-download:hover:not(:disabled){background:#10b981;background:var(--green);box-shadow:0 4px 12px #00000014;box-shadow:var(--shadow);color:#fff}.btn-download:disabled{cursor:not-allowed;opacity:.45}.month-att-bar{background:#f8f9fc;background:var(--bg-input);border-radius:99px;flex-shrink:0;height:6px;overflow:hidden;width:72px}.month-att-fill{border-radius:99px;height:100%;transition:width .4s ease}.modal-overlay{align-items:center;background:#00000073;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:1000}.modal-box{background:#fff;background:var(--surface,#fff);border-radius:14px;border-radius:var(--radius-lg,12px);box-shadow:0 20px 60px #0003;max-height:90vh;max-width:520px;overflow-y:auto;padding:1.75rem;width:100%}.modal-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.25rem}.modal-title{color:#1a1f36;color:var(--text-primary);font-size:1.1rem;font-weight:700;margin:0}.modal-close{background:none;border:none;border-radius:6px;border-radius:var(--radius-sm);color:#9ca3af;color:var(--text-muted);cursor:pointer;font-size:1.1rem;padding:.25rem;transition:color .15s}.modal-close:hover{color:#1a1f36;color:var(--text-primary)}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem}.form-label{color:#6b7280;color:var(--text-secondary);display:block;font-size:.8rem;font-weight:600;margin-bottom:.35rem}.form-input{background:#f8f9fc;background:var(--bg-input,#f9fafb);border:1.5px solid #e8eaed;border:1.5px solid var(--border);border-radius:10px;border-radius:var(--radius);box-sizing:border-box;color:#1a1f36;color:var(--text-primary);font-size:.875rem;padding:.55rem .75rem;transition:border-color .15s;width:100%}.form-input:focus{background:#fff;border-color:#635bff;border-color:var(--brand-accent,#6c63ff);outline:none}.form-select{background:#f8f9fc;background:var(--bg-input,#f9fafb);border:1.5px solid #e8eaed;border:1.5px solid var(--border);border-radius:10px;border-radius:var(--radius);box-sizing:border-box;color:#1a1f36;color:var(--text-primary);cursor:pointer;font-size:.875rem;padding:.55rem .75rem;width:100%}.form-select:focus{border-color:#635bff;border-color:var(--brand-accent,#6c63ff);outline:none}.form-group .form-label{margin-bottom:0}.btn-secondary{background:var(--surface);border:1.5px solid #e8eaed;border:1.5px solid var(--border);border-radius:10px;border-radius:var(--radius);color:#1a1f36;color:var(--text-primary);cursor:pointer;font-size:.875rem;font-weight:600;padding:.55rem 1.25rem;transition:background .15s}.btn-secondary:hover{background:#f8f9fc;background:var(--bg-input)}.btn-secondary-sm{background:var(--surface);border:1.5px solid #e8eaed;border:1.5px solid var(--border);border-radius:6px;border-radius:var(--radius-sm);color:#1a1f36;color:var(--text-primary);cursor:pointer;font-size:.75rem;font-weight:600;padding:.3rem .65rem;transition:background .15s;white-space:nowrap}.btn-secondary-sm:hover{background:#f8f9fc;background:var(--bg-input)}.primary-muted-box{background:#ede9fe;background:var(--primary-muted,#ede9fe);border-radius:10px;border-radius:var(--radius);color:#6c63ff;color:var(--primary,#6c63ff);font-size:.82rem;padding:.5rem .75rem}.status-pill--purple{background:#f5f3ff;background:var(--purple-bg);color:#5b21b6;color:var(--purple-text)}.shift-card-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));margin-top:1rem}.holiday-banner{background:#f5f3ff;background:var(--purple-bg);border-radius:10px;border-radius:var(--radius);color:#5b21b6;color:var(--purple-text);font-size:.85rem;font-weight:700;padding:.5rem 1rem}.attachment-drop-zone,.holiday-banner{align-items:center;display:flex;gap:.5rem}.attachment-drop-zone{background:#f8f9fc;background:var(--bg-input);border:2px dashed #e8eaed;border:2px dashed var(--border);border-radius:10px;border-radius:var(--radius);color:#9ca3af;color:var(--text-muted);cursor:pointer;font-size:.82rem;justify-content:center;padding:.75rem 1rem;transition:border-color .15s,background .15s;-webkit-user-select:none;user-select:none}.attachment-drop-zone:hover{background:#ebe9ff;background:var(--brand-accent-light);border-color:#635bff;border-color:var(--brand-accent);color:#635bff;color:var(--brand-accent)}.attachment-preview-list{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.5rem}.attachment-chip{align-items:center;background:#eff6ff;background:var(--blue-bg);border:1px solid #3b82f6;border:1px solid var(--blue);border-radius:99px;color:#1e40af;color:var(--blue-text);display:inline-flex;font-size:.75rem;font-weight:600;gap:.3rem;max-width:200px;padding:.2rem .6rem}.attachment-chip-name{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attachment-chip-remove{background:none;border:none;color:#1e40af;color:var(--blue-text);cursor:pointer;flex-shrink:0;font-size:.7rem;line-height:1;padding:0}.attachment-chip-remove:hover{color:#ef4444;color:var(--red)}.attachment-list{display:flex;flex-wrap:wrap;gap:.5rem;margin:.5rem 0}.attachment-thumb{border:1px solid #e8eaed;border:1px solid var(--border);border-radius:6px;border-radius:var(--radius-sm);cursor:pointer;height:80px;object-fit:cover;transition:opacity .15s;width:80px}.attachment-thumb:hover{opacity:.85}.attachment-doc-chip{align-items:center;background:#f3f4f6;background:var(--gray-bg);border:1px solid #e8eaed;border:1px solid var(--border);border-radius:6px;border-radius:var(--radius-sm);color:#374151;color:var(--gray-text);display:inline-flex;font-size:.78rem;font-weight:600;gap:.3rem;padding:.3rem .65rem;text-decoration:none;transition:background .15s}.attachment-doc-chip:hover{background:#eff6ff;background:var(--blue-bg);border-color:#3b82f6;border-color:var(--blue);color:#1e40af;color:var(--blue-text)}.ann-icon-btn{background:none;border:none;border-radius:6px;border-radius:var(--radius-sm);cursor:pointer;font-size:.9rem;line-height:1;padding:.15rem .3rem;transition:background .15s}.ann-icon-btn:hover{background:#0000000f}.ann-icon-btn--danger:hover{background:#fef2f2;background:var(--red-bg)}.ann-icon-btn:disabled{cursor:not-allowed;opacity:.4}.ann-read-toggle{align-items:center;background:none;border:1px solid #e8eaed;border:1px solid var(--border);border-radius:99px;color:#6b7280;color:var(--text-secondary);cursor:pointer;display:flex;font-size:.73rem;font-weight:600;gap:.25rem;margin-top:.625rem;padding:.3rem .625rem;transition:all .15s;width:fit-content}.ann-read-toggle:hover{background:#f8f9fc;background:var(--bg-input);border-color:#635bff;border-color:var(--brand-accent);color:#635bff;color:var(--brand-accent)}.ann-read-panel{background:#f5f6fa;background:var(--bg-page);border:1px solid #e8eaed;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius);margin-top:.625rem;padding:.75rem}.ann-read-section-title{color:#9ca3af;color:var(--text-muted);font-size:.72rem;font-weight:700;letter-spacing:.05em;margin-bottom:.4rem;text-transform:uppercase}.ann-read-empty{color:#9ca3af;color:var(--text-muted);font-size:.78rem;font-style:italic}.ann-read-row{align-items:center;border-bottom:1px solid #e8eaed;border-bottom:1px solid var(--border);display:flex;gap:.5rem;padding:.3rem 0}.ann-read-row:last-child{border-bottom:none}.ann-read-row--seen{opacity:1}.ann-read-row--unseen{opacity:.7}.ann-read-avatar{align-items:center;background:#ebe9ff;background:var(--brand-accent-light);border-radius:50%;color:#635bff;color:var(--brand-accent);display:flex;flex-shrink:0;font-size:.6rem;font-weight:700;height:24px;justify-content:center;width:24px}.ann-read-name{flex:1 1;font-size:.8rem;font-weight:500}.ann-eye-icon{flex-shrink:0;font-size:.85rem}.announcements-list{display:flex;flex-direction:column;gap:.875rem}.announcement-row{align-items:flex-start;background:#f8f9fc;background:var(--bg-input);border-radius:10px;border-radius:var(--radius);display:flex;gap:.75rem;padding:.75rem;transition:background .15s}.announcement-row:hover{background:#635bff0d}.announcement-priority-dot{border-radius:50%;flex-shrink:0;height:8px;margin-top:.375rem;width:8px}.priority-high .announcement-priority-dot{background:#ef4444;background:var(--red)}.priority-medium .announcement-priority-dot{background:#f59e0b;background:var(--amber)}.priority-low .announcement-priority-dot{background:#10b981;background:var(--green)}.announcement-content{display:flex;flex-direction:column;gap:.2rem}.announcement-title{font-size:.825rem;font-weight:600}.announcement-msg{color:#6b7280;color:var(--text-secondary);font-size:.775rem;line-height:1.4}
/*# sourceMappingURL=main.c387e39e.css.map*/