*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f7fa;color:#1a1a1a;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--primary-blue:#0d4d7a;--primary-blue-dark:#0a3a5e;--primary-gradient:linear-gradient(135deg,#0f5a8f,#083258 50%,#061e36);--accent-gold:#ccad39;--accent-green:#10b981;--accent-green-dark:#059669;--success:#10b981;--warning:#f59e0b;--error:#ef4444;--info:#3b82f6;--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:#1a1a1a;--white:#fff;--shadow-sm:0 1px 2px 0 #0000000d;--shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;--radius-sm:4px;--radius:8px;--radius-lg:12px;--radius-xl:16px}@media (max-width:768px){input,select,textarea{font-size:16px!important}}.login-container{align-items:center;background-color:var(--gray-900);background-position:50%;background-repeat:no-repeat;background-size:cover;display:flex;justify-content:center;min-height:100vh;padding:20px}.login-card{background:#fff;border-radius:var(--radius-xl);box-shadow:0 20px 60px #0000004d;max-width:420px;padding:80px 40px;width:100%}.login-header{margin-bottom:64px;text-align:center}.login-logo{border-radius:var(--radius);height:auto;margin-bottom:16px;width:80px}.login-header h1{color:var(--gray-800);font-size:2rem;font-weight:700;letter-spacing:-.5px;margin-bottom:.5rem}.login-header p{color:var(--gray-600);font-size:1rem;margin:0}.oauth-section{margin-top:64px}.btn-microsoft{align-items:center;background:var(--gray-100);border:1px solid var(--gray-200);border-radius:var(--radius);color:var(--gray-800);cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:12px;justify-content:center;padding:14px 24px;transition:all .2s ease;width:100%}.btn-microsoft:hover:not(:disabled){background:var(--gray-200)}.btn-microsoft:disabled{cursor:not-allowed;opacity:.6}.btn-microsoft svg{flex-shrink:0}@media (max-width:480px){.login-card{padding:30px 24px}.login-header h1{font-size:1.5rem}.login-header p{font-size:.875rem}.btn-microsoft{min-height:48px}}.sync-logs-panel{display:flex;flex-direction:column;height:100%}.panel-header{align-items:center;border-bottom:1px solid var(--gray-100);display:flex;justify-content:space-between;padding:16px 20px}.panel-header h2{color:var(--gray-900);font-size:16px;font-weight:600}.log-count{color:var(--gray-500);font-size:12px}.logs-list{flex:1 1;max-height:540px;overflow-y:auto}.empty-logs{color:var(--gray-500);padding:40px 20px;text-align:center}.log-entry{border-bottom:1px solid var(--gray-100);display:flex;gap:12px;padding:12px 20px;transition:background-color .2s ease}.log-entry:last-child{border-bottom:none}.log-entry:hover{background-color:var(--gray-50)}.log-icon{align-items:center;border-radius:50%;display:flex;flex-shrink:0;height:32px;justify-content:center;width:32px}.log-entry.success .log-icon{background:#10b9811a;color:var(--accent-green)}.log-entry.info .log-icon{background:#3b82f61a;color:var(--info)}.log-entry.warning .log-icon{background:#f59e0b1a;color:var(--warning)}.log-entry.error .log-icon{background:#ef44441a;color:var(--error)}.log-entry.default .log-icon{background:var(--gray-100);color:var(--gray-500)}.log-content{flex:1 1;min-width:0}.log-message{color:var(--gray-700);font-size:13px;margin-bottom:4px;word-break:break-word}.log-time{color:var(--gray-500);font-size:11px}.loading-spinner-container{align-items:center;display:flex;justify-content:center}.spinner{animation:spin 1s linear infinite;border-radius:50%}.loading-spinner-container.small .spinner{border:2px solid;height:20px;width:20px}.loading-spinner-container.medium .spinner{border:3px solid;height:36px;width:36px}.loading-spinner-container.large .spinner{border:4px solid;height:48px;width:48px}.loading-spinner-container.primary .spinner{border-color:#0d4d7a33;border-top-color:var(--primary-blue)}.loading-spinner-container.white .spinner{border-color:#fff #ffffff4d #ffffff4d}.loading-spinner-container.gray .spinner{border-color:#6b728033;border-top-color:var(--gray-500)}.dashboard{margin:0 auto;max-width:1400px}.dashboard-loading{align-items:center;color:var(--gray-500);display:flex;flex-direction:column;justify-content:center;min-height:400px}.dashboard-loading p{margin-top:16px}.dashboard-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:24px}.header-content h1{margin-bottom:4px}.header-actions{display:flex;gap:12px}.sync-btn{align-items:center;display:flex;gap:8px}.btn-spinner{animation:spin 1s linear infinite;border:2px solid #ffffff4d;border-top-color:#fff;height:16px;width:16px}.stats-grid{grid-gap:12px;gap:12px}.stat-card{border:2px solid #0000;border-radius:var(--radius-lg);gap:12px;padding:14px 16px;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-card.clickable:hover{border-color:var(--gray-300)}.stat-card.active-filter{background:#3b82f60d;border-color:var(--primary)}.stat-icon{height:40px;width:40px}.stat-icon svg{height:20px;width:20px}.stat-icon.total{background:#3b82f61a;color:var(--info)}.stat-icon.active,.stat-icon.synced{background:#10b9811a;color:var(--accent-green)}.stat-icon.pending{background:#f59e0b1a;color:var(--warning)}.stat-icon.errors{background:#ef44441a;color:var(--error)}.stat-value{font-size:22px;line-height:1}.stat-label{font-size:12px;margin-top:3px}.last-sync-info{align-items:center;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-sm);display:flex;font-size:14px;gap:8px;margin-bottom:24px;padding:12px 16px}.last-sync-label{color:var(--gray-500)}.last-sync-time{color:var(--gray-700);font-weight:500}.last-sync-duration{color:var(--gray-500)}.last-sync-status{border-radius:20px;font-size:12px;font-weight:600;margin-left:auto;padding:4px 10px}.last-sync-status.success{background:#10b9811a;color:var(--accent-green)}.last-sync-status.error{background:#ef44441a;color:var(--error)}.dashboard-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 400px}.dashboard-section{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden}.section-header{align-items:center;border-bottom:1px solid var(--gray-100);display:flex;gap:16px;justify-content:space-between;padding:16px 20px}.section-header h2{color:var(--gray-900);font-size:16px;font-weight:600;white-space:nowrap}.section-count{color:var(--gray-500);font-size:13px}.search-container{flex:1 1;margin:0 16px;max-width:300px;position:relative}.search-input{font-size:13px;outline:none;padding:8px 32px 8px 12px;transition:border-color .2s ease,box-shadow .2s ease}.search-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a}.search-input::placeholder{color:var(--gray-400)}.search-clear{font-size:18px;line-height:1;right:8px}.groups-list{max-height:600px;overflow-y:auto}.empty-state{padding:40px 20px}.groups-table-container{overflow-x:auto}.groups-table{border-collapse:collapse;font-size:13px;width:100%}.groups-table td,.groups-table th{border-bottom:1px solid var(--gray-100);padding:12px 16px;text-align:left}.groups-table td:first-child,.groups-table th:first-child{padding-left:24px}.groups-table td:last-child,.groups-table th:last-child{padding-right:24px}.groups-table th{background:var(--gray-100);color:var(--gray-700);font-weight:600;white-space:nowrap}.groups-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.groups-table th.sortable:hover{background:var(--gray-100)}.sort-icon{margin-left:6px;opacity:.5}.groups-table th.sortable:hover .sort-icon{opacity:1}.groups-table tbody tr:hover{background:var(--gray-50)}.groups-table .group-name{color:var(--gray-900);font-weight:500;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.groups-table .asana-id,.groups-table .ccb-id{font-family:monospace;font-size:12px}.groups-table .asana-id a,.groups-table .ccb-id a{color:var(--info);text-decoration:none;transition:color .15s ease}.groups-table .asana-id a:hover,.groups-table .ccb-id a:hover{color:var(--primary-blue);text-decoration:underline}.groups-table .asana-id .no-link{color:var(--gray-400)}.status-badge{font-size:11px;padding:3px 8px;text-transform:capitalize}.status-badge.synced{background:#10b9811a;color:var(--accent-green)}.status-badge.pending{background:#f59e0b1a;color:var(--warning)}.status-badge.removed{background:#6b72801a;color:var(--gray-600)}.action-col{text-align:center;width:60px}.sync-row-btn{align-items:center;background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius);color:var(--gray-500);cursor:pointer;display:inline-flex;height:32px;justify-content:center;transition:all .2s ease;width:32px}.sync-row-btn:hover:not(:disabled){background:var(--accent-green);border-color:var(--accent-green);box-shadow:0 2px 8px #10b9814d;color:#fff}.sync-row-btn:hover:not(:disabled) svg{stroke:#fff}.sync-row-btn:disabled{cursor:not-allowed;opacity:.5}.btn-spinner-small{animation:spin 1s linear infinite;border:2px solid #0000001a;border-radius:50%;border-top:2px solid var(--primary);height:14px;width:14px}.pagination{align-items:center;background:#f8f9fb;border-bottom:1px solid var(--gray-200);display:flex;justify-content:space-between;padding:12px 24px}.groups-table-container+.pagination{border-bottom:none;border-top:1px solid var(--gray-200)}.pagination-info{color:var(--gray-600);font-size:13px}.pagination-info strong{color:var(--primary);font-weight:600}.pagination-controls{align-items:center;display:flex;gap:4px}.pagination-btn{align-items:center;background:#fff;border:1px solid var(--gray-200);border-radius:4px;color:var(--gray-600);cursor:pointer;display:inline-flex;font-size:13px;font-weight:500;gap:4px;justify-content:center;min-width:32px;padding:6px 12px;transition:all .15s ease}.pagination-btn:hover:not(:disabled):not(.active){background:var(--gray-50);border-color:var(--gray-300);color:var(--gray-700)}.pagination-btn:disabled{background:var(--gray-50);cursor:not-allowed;opacity:.4}.pagination-btn.pagination-nav{padding:6px 10px}.pagination-btn.pagination-num{min-width:36px;padding:6px 8px}.pagination-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.pagination-ellipsis{color:var(--gray-400);font-size:13px;padding:6px 4px}@media (max-width:1200px){.dashboard-grid{grid-template-columns:1fr}.logs-section{order:-1}}@media (max-width:1024px){.stats-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:768px){.dashboard-header{flex-direction:column;gap:16px}.header-actions{width:100%}.sync-btn{flex:1 1;justify-content:center}.stats-grid{grid-template-columns:repeat(2,1fr)}.last-sync-info{flex-wrap:wrap}.last-sync-status{margin-left:0;margin-top:8px;text-align:center;width:100%}.groups-table{font-size:12px}.groups-table td,.groups-table th{padding:8px}.groups-table td:nth-child(2),.groups-table td:nth-child(3),.groups-table th:nth-child(2),.groups-table th:nth-child(3){display:none}.sync-row-btn{height:40px;width:40px}.pagination{flex-wrap:wrap}}@media (max-width:480px){.stats-grid{grid-template-columns:1fr}.header-content h1{font-size:24px}.pagination{align-items:center;flex-direction:column;gap:8px}.pagination-controls{flex-wrap:wrap;justify-content:center}}.header{background:var(--primary-gradient);box-shadow:0 2px 8px #00000026;color:#fff;position:-webkit-sticky;position:sticky;top:0;z-index:1000}.header-container{height:64px;justify-content:space-between;margin:0 auto;max-width:1400px;padding:0 24px}.brand-link,.header-brand,.header-container{align-items:center;display:flex}.brand-link{color:#fff;gap:12px;text-decoration:none}.brand-icon{align-items:center;border-radius:50%;display:flex;height:36px;justify-content:center;overflow:hidden;width:36px}.brand-logo-img{border-radius:50%;height:100%;object-fit:cover;width:100%}.brand-text{font-size:18px;font-weight:700;letter-spacing:-.5px}.brand-version{align-self:flex-end;font-size:10px;font-weight:400;letter-spacing:0;margin-bottom:2px;margin-left:8px;opacity:.4}.header-greeting{align-items:center;display:flex;flex-direction:column;text-align:center}.greeting-text{font-size:14px;font-weight:500;opacity:.95}.greeting-time{font-size:12px;opacity:.7}.desktop-nav{align-items:center;display:flex;gap:8px}.nav-link{background:none;border:none;border-radius:var(--radius);color:#ffffffd9;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;text-decoration:none;transition:all .2s ease}.nav-link:hover{background:#ffffff1a;color:#fff}.nav-link.active{background:#fff3;color:#fff}.logout-btn{color:#ffffffb3}.logout-btn:hover{background:#ef44444d;color:#fff}.mobile-menu-btn{background:none;border:none;border-radius:var(--radius);color:#fff;cursor:pointer;display:none;padding:8px;transition:background .2s ease}.mobile-menu-btn:hover{background:#ffffff1a}.mobile-nav{background:#0a3a5efa;border-top:1px solid #ffffff1a;display:none;flex-direction:column;padding:16px 24px 24px}.mobile-greeting{border-bottom:1px solid #ffffff1a;font-size:14px;margin-bottom:8px;opacity:.8;padding:12px 0}.mobile-nav-link{background:none;border:none;color:#ffffffe6;cursor:pointer;display:block;font-size:15px;font-weight:500;padding:14px 0;text-align:left;text-decoration:none;transition:color .2s ease;width:100%}.mobile-nav-link.active,.mobile-nav-link:hover{color:#fff}.mobile-nav-link.logout-btn{border-bottom:none;color:#fca5a5;margin-top:8px}@media (max-width:768px){.header-container{padding:0 16px}.desktop-nav,.header-greeting{display:none}.mobile-menu-btn{display:block}.mobile-nav{display:flex}.brand-text{font-size:16px}}.layout{display:flex;flex-direction:column;height:100vh;overflow:hidden}.main-content{background-color:#f5f7fa;flex:1 1;overflow-y:auto;padding:24px}@media (max-width:768px){.main-content{padding:16px}}@media (max-width:480px){.main-content{padding:12px}}.admin-panel{margin:0 auto;max-width:800px}.admin-denied,.admin-loading{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:400px;text-align:center}.admin-denied h2{color:var(--gray-900);font-size:24px;margin-bottom:8px}.admin-denied p{color:var(--gray-500);margin-bottom:24px}.admin-header{margin-bottom:32px}.admin-header h1{color:var(--gray-900);font-size:28px;font-weight:700;margin-bottom:4px}.admin-header p{color:var(--gray-500);font-size:14px}.admin-cards{display:flex;flex-direction:column;gap:16px}.admin-card{align-items:center;background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow);display:flex;gap:20px;padding:24px;text-decoration:none;transition:all .2s ease}.admin-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.card-icon{align-items:center;background:#0d4d7a1a;border-radius:var(--radius);color:var(--primary-blue);display:flex;flex-shrink:0;height:56px;justify-content:center;width:56px}.card-content{flex:1 1}.card-content h3{color:var(--gray-900);font-size:16px;font-weight:600;margin-bottom:4px}.card-content p{color:var(--gray-500);font-size:14px}.card-arrow{color:var(--gray-400)}@media (max-width:480px){.admin-card{gap:16px;padding:16px}.card-icon{height:48px;width:48px}.card-icon svg{height:24px;width:24px}}.administration-container{margin:0 auto;max-width:1400px;padding:0 20px}.administration-header{margin-bottom:24px}.administration-header h1{color:var(--gray-900);font-size:28px;font-weight:700;margin:0 0 4px}.administration-header p{color:var(--gray-500);font-size:14px;margin:0}.admin-loading-page{align-items:center;color:var(--gray-500);display:flex;flex-direction:column;justify-content:center;min-height:400px}.admin-loading-page .spinner{animation:adminSpin 1s linear infinite;border:4px solid var(--gray-200);border-radius:50%;border-top-color:var(--primary-blue);height:48px;margin-bottom:16px;width:48px}@keyframes adminSpin{to{transform:rotate(1turn)}}.administration-container .admin-message{border-radius:var(--radius);font-size:14px;font-weight:500;margin-bottom:16px;max-width:100%;padding:12px 16px}.administration-container .admin-message.success{background-color:#f0fdf4;border:1px solid #bbf7d0;color:#16a34a}.administration-container .admin-message.error{background-color:#fef2f2;border:1px solid #fecaca;color:#dc2626}.administration-container .admin-tabs{border-bottom:1px solid var(--gray-200);display:flex;gap:0;margin-bottom:24px}.administration-container .admin-tab{background:none;border:none;border-bottom:2px solid #0000;color:var(--gray-500);cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .2s ease}.administration-container .admin-tab:hover{color:var(--gray-700)}.administration-container .admin-tab.active{border-bottom-color:var(--primary-blue);color:var(--primary-blue)}.administration-container .admin-content{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:24px}.administration-container .section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.administration-container .section-header h2{color:var(--gray-900);font-size:18px;font-weight:600;margin:0}.administration-container .btn-primary{align-items:center;background:var(--primary-blue);border:none;border-radius:var(--radius);color:#fff;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:6px;padding:10px 20px;transition:all .2s ease}.administration-container .btn-primary:hover:not(:disabled){background:var(--primary-blue-dark);box-shadow:var(--shadow-md)}.administration-container .btn-primary:disabled{cursor:not-allowed;opacity:.6}.administration-container .btn-secondary{align-items:center;background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius);color:var(--gray-700);cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s ease}.administration-container .btn-secondary:hover:not(:disabled){background:var(--gray-50);border-color:var(--gray-300)}.administration-container .btn-danger{align-items:center;background:var(--error);border:none;border-radius:var(--radius);color:#fff;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s ease}.administration-container .btn-danger:hover:not(:disabled){background:#dc2626;box-shadow:var(--shadow-md)}.administration-container .btn-danger:disabled{cursor:not-allowed;opacity:.6}.administration-container .users-table-wrapper{border:1px solid var(--gray-100);border-radius:var(--radius);margin-bottom:20px;overflow-x:auto}.administration-container .users-table{border-collapse:collapse;table-layout:fixed;width:100%}.administration-container .users-table thead{background:var(--gray-50)}.administration-container .users-table th{color:var(--gray-500);font-size:12px;font-weight:600;padding:10px 8px;text-align:left;text-transform:uppercase}.administration-container .users-table th:first-child{width:15%}.administration-container .users-table th:nth-child(2){width:20%}.administration-container .users-table th:nth-child(3){width:15%}.administration-container .users-table th:nth-child(4){width:12%}.administration-container .users-table th:nth-child(5){width:13%}.administration-container .users-table th:nth-child(6){width:15%}.administration-container .users-table th:nth-child(7){width:10%}.administration-container .users-table tbody tr{border-bottom:1px solid var(--gray-100);transition:background-color .15s ease}.administration-container .users-table tbody tr:last-child{border-bottom:none}.administration-container .users-table tbody tr:hover{background:var(--gray-50)}.administration-container .users-table tbody tr.disabled-user{background:#fffbeb;opacity:.6}.administration-container .users-table td{color:var(--gray-700);font-size:14px;overflow:hidden;padding:10px 8px;text-overflow:ellipsis;white-space:nowrap}.administration-container .user-info{align-items:center;display:flex;gap:8px;overflow:hidden}.administration-container .user-info strong{color:var(--gray-900);flex:1 1;font-weight:600;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.administration-container .badge{border-radius:12px;display:inline-block;flex-shrink:0;font-size:11px;font-weight:600;padding:2px 8px}.administration-container .admin-badge{background:#0d4d7a1a;color:var(--primary-blue)}.administration-container .role-select{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-sm);cursor:pointer;font-size:13px;font-weight:500;max-width:100%;padding:6px 8px;transition:all .2s ease;width:100%}.administration-container .role-select:hover{border-color:var(--gray-300)}.administration-container .role-select:focus{border-color:var(--primary-blue);box-shadow:0 0 0 3px #0d4d7a1a;outline:none}.administration-container .status-badge{border-radius:12px;display:inline-block;font-size:12px;font-weight:500;padding:4px 10px}.administration-container .status-active{background:#f0fdf4;color:#16a34a}.administration-container .status-pending{background:var(--gray-50);color:var(--gray-500)}.administration-container .status-disabled{background:#fef2f2;color:#dc2626}.administration-container .action-buttons{display:flex;gap:4px}.administration-container .btn-action{align-items:center;border:none;border-radius:var(--radius-sm);cursor:pointer;display:flex;flex-shrink:0;height:32px;justify-content:center;transition:all .2s ease;width:32px}.administration-container .btn-action:hover:not(:disabled){transform:scale(1.1)}.administration-container .btn-action:disabled{cursor:not-allowed;opacity:.5}.administration-container .btn-toggle{background:var(--primary-blue);color:#fff}.administration-container .btn-toggle:hover:not(:disabled){background:var(--primary-blue-dark)}.administration-container .btn-delete{background:var(--error);color:#fff}.administration-container .btn-delete:hover:not(:disabled){background:#dc2626}.administration-container .empty-state{color:var(--gray-500);padding:60px 20px;text-align:center}.administration-container .empty-state p{font-size:14px;margin-bottom:16px}.administration-container .roles-section h2{border-bottom:1px solid var(--gray-100);color:var(--gray-900);font-size:18px;font-weight:600;margin:0 0 20px;padding-bottom:12px}.administration-container .roles-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.administration-container .role-card{background:#fff;border:1px solid var(--gray-200);border-left-width:4px;border-radius:var(--radius);padding:20px;transition:all .2s ease}.administration-container .role-card:hover{box-shadow:var(--shadow-md)}.administration-container .role-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.administration-container .role-card-header h3{color:var(--gray-900);font-size:16px;font-weight:600;margin:0}.administration-container .role-badge{border-radius:12px;color:#fff;display:inline-block;font-size:12px;font-weight:500;padding:4px 10px}.administration-container .role-description{color:var(--gray-500);font-size:14px;line-height:1.5;margin-bottom:16px}.administration-container .role-permissions h4{color:var(--gray-500);font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.administration-container .role-permissions ul{list-style:none;margin:0;padding:0}.administration-container .role-permissions li{align-items:center;color:var(--gray-700);display:flex;font-size:13px;padding:4px 0}.administration-container .role-permissions li:before{align-items:center;background:#10b9811a;border-radius:50%;color:var(--accent-green);content:"\2713";display:inline-flex;flex-shrink:0;font-size:11px;font-weight:700;height:18px;justify-content:center;margin-right:8px;width:18px}.administration-container .modal-overlay{align-items:center;animation:adminFadeIn .2s ease-out;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}@keyframes adminFadeIn{0%{opacity:0}to{opacity:1}}.administration-container .modal-content{animation:adminSlideUp .2s ease-out;background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-height:90vh;max-width:560px;overflow-y:auto;width:90%}.administration-container .modal-content.modal-wide{max-width:640px}@keyframes adminSlideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.administration-container .modal-header{align-items:center;background:var(--primary-blue);border-radius:var(--radius-lg) var(--radius-lg) 0 0;display:flex;justify-content:center;padding:20px 24px;position:relative}.administration-container .modal-header h2{color:#fff;font-size:18px;font-weight:600;margin:0;text-align:center}.administration-container .modal-close{align-items:center;background:#fff3;border:none;border-radius:var(--radius-sm);color:#fff;cursor:pointer;display:flex;font-size:18px;height:32px;justify-content:center;position:absolute;right:20px;transition:all .2s ease;width:32px}.administration-container .modal-close:hover:not(:disabled){background:#ffffff4d}.administration-container .modal-body{padding:24px}.administration-container .form-group{margin-bottom:16px}.administration-container .form-group label{color:var(--gray-700);display:block;font-size:14px;font-weight:500;margin-bottom:6px}.administration-container .form-group input,.administration-container .form-group select,.administration-container .form-group textarea{border:1px solid var(--gray-200);border-radius:var(--radius);box-sizing:border-box;font-family:inherit;font-size:14px;padding:10px 14px;transition:all .2s ease;width:100%}.administration-container .form-group input:focus,.administration-container .form-group select:focus,.administration-container .form-group textarea:focus{border-color:var(--primary-blue);box-shadow:0 0 0 3px #0d4d7a1a;outline:none}.administration-container .form-group input::placeholder,.administration-container .form-group textarea::placeholder{color:var(--gray-300)}.administration-container .modal-actions{border-top:1px solid var(--gray-100);display:flex;gap:12px;justify-content:center;margin-top:20px;padding-top:16px}.administration-container .search-row{margin-bottom:16px;position:relative}.administration-container .search-spinner{animation:adminSpin .8s linear infinite;border:2px solid var(--gray-200);border-radius:50%;border-top-color:var(--primary-blue);height:18px;position:absolute;right:12px;top:50%;transform:translateY(-50%);width:18px}.administration-container .search-row input{border:1px solid var(--gray-200);border-radius:var(--radius);box-sizing:border-box;font-family:inherit;font-size:14px;padding:10px 36px 10px 14px;transition:all .2s ease;width:100%}.administration-container .search-row input:focus{border-color:var(--primary-blue);box-shadow:0 0 0 3px #0d4d7a1a;outline:none}.administration-container .search-row input::placeholder{color:var(--gray-300)}.administration-container .search-results{border:1px solid var(--gray-200);border-radius:var(--radius);margin-bottom:16px;max-height:240px;overflow-y:auto}.administration-container .search-result-item{border-bottom:1px solid var(--gray-100);cursor:pointer;padding:10px 14px;transition:background-color .15s ease}.administration-container .search-result-item:last-child{border-bottom:none}.administration-container .search-result-item:hover:not(.already-added){background:var(--gray-50)}.administration-container .search-result-item.selected{background:#0d4d7a14;border-left:3px solid var(--primary-blue)}.administration-container .search-result-item.already-added{cursor:default;opacity:.5}.administration-container .search-result-info{display:flex;flex-direction:column;gap:2px}.administration-container .search-result-info strong{color:var(--gray-900);font-size:14px}.administration-container .search-result-email{color:var(--gray-500);font-size:13px}.administration-container .search-result-title{color:var(--gray-400);font-size:12px}.administration-container .already-added-badge{background:var(--gray-100);border-radius:12px;color:var(--gray-500);float:right;font-size:11px;margin-top:4px;padding:2px 8px}.administration-container .selected-user-section{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius);margin-bottom:8px;padding:16px}.administration-container .selected-label{color:var(--gray-500);font-size:12px;font-weight:600;letter-spacing:.5px;margin:0 0 8px;text-transform:uppercase}.administration-container .selected-user-info{display:flex;flex-direction:column;gap:2px;margin-bottom:16px}.administration-container .selected-user-info strong{color:var(--gray-900);font-size:15px}.administration-container .selected-user-info span{color:var(--gray-500);font-size:13px}@media (max-width:768px){.administration-container{padding:0 12px}.administration-header h1{font-size:24px}.administration-container .admin-tabs{overflow-x:auto}.administration-container .admin-content{padding:16px}.administration-container .section-header{align-items:flex-start;flex-direction:column;gap:12px}.administration-container .users-table{table-layout:auto}.administration-container .users-table td,.administration-container .users-table th{white-space:normal}.administration-container .roles-grid{grid-template-columns:1fr}.administration-container .modal-content{max-height:95vh;width:95%}.administration-container .search-row input{font-size:16px}.administration-container .users-table td:nth-child(5),.administration-container .users-table td:nth-child(6),.administration-container .users-table th:nth-child(5),.administration-container .users-table th:nth-child(6){display:none}.administration-container .btn-action{height:40px;width:40px}.administration-container .admin-tab{padding:14px 20px}}.sync-settings{margin:0 auto;max-width:800px}.settings-loading{align-items:center;color:var(--gray-500);display:flex;flex-direction:column;justify-content:center;min-height:400px}.settings-loading p{margin-top:16px}.settings-header{margin-bottom:24px}.settings-header h1{color:var(--gray-900);font-size:28px;font-weight:700;margin-bottom:4px}.settings-header p{color:var(--gray-500);font-size:14px}.settings-form .card{margin-bottom:24px}.field-help{color:var(--gray-500);font-size:12px;margin-top:6px}.checkbox-field{margin-bottom:16px}.checkbox-label{align-items:flex-start;cursor:pointer;display:flex;gap:10px}.checkbox-label input[type=checkbox]{accent-color:var(--primary-blue);height:18px;margin-top:2px;width:18px}.checkbox-text{color:var(--gray-700);font-weight:500}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.alert{font-size:14px;margin-bottom:20px}.alert-error{background:#ef44441a;border:1px solid #ef444433;color:var(--error)}.alert-success{background:#10b9811a;border:1px solid #10b98133;color:var(--accent-green)}@media (max-width:480px){.settings-header h1{font-size:24px}.form-actions{flex-direction:column}.form-actions .btn{width:100%}}.sync-history{margin:0 auto;max-width:1200px}.history-loading{align-items:center;color:var(--gray-500);display:flex;flex-direction:column;justify-content:center;min-height:400px}.history-loading p{margin-top:16px}.history-header{margin-bottom:24px}.back-link{align-items:center;color:var(--primary-blue);display:inline-flex;font-size:14px;gap:4px;margin-bottom:16px;text-decoration:none}.back-link:hover{text-decoration:underline}.history-header h1{color:var(--gray-900);font-size:28px;font-weight:700;margin-bottom:4px}.history-header p{color:var(--gray-500);font-size:14px}.history-table-container{overflow-x:auto}.empty-history{color:var(--gray-500);padding:60px 20px;text-align:center}.history-table{border-collapse:collapse;width:100%}.history-table td,.history-table th{border-bottom:1px solid var(--gray-100);padding:14px 16px;text-align:left}.history-table th{background:var(--gray-50);color:var(--gray-500);font-size:12px;font-weight:600;text-transform:uppercase}.history-table td{color:var(--gray-700);font-size:14px}.history-table tbody tr:hover{background-color:var(--gray-50)}.date-cell{font-weight:500;white-space:nowrap}.trigger-cell{color:var(--gray-500)}.number-cell{font-weight:500;text-align:center}.number-cell.created{color:var(--accent-green)}.number-cell.updated{color:var(--info)}.number-cell.deleted{color:var(--warning)}.duration-cell{color:var(--gray-500);white-space:nowrap}@media (max-width:768px){.history-table td,.history-table th{font-size:12px;padding:10px 12px}.history-header h1{font-size:24px}}.events-dashboard{margin:0 auto;max-width:1400px;padding:0 20px}.page-loading{align-items:center;color:var(--gray-500);display:flex;flex-direction:column;justify-content:center;min-height:400px}.page-loading p{font-size:14px;margin-top:16px}.page-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:24px}.header-content h1{color:var(--gray-900);font-size:28px;font-weight:700;margin:0 0 4px}.header-content p{color:var(--gray-500);font-size:14px;margin:0}.alert{align-items:center;border-radius:var(--radius);display:flex;justify-content:space-between;margin-bottom:16px;padding:12px 16px}.alert-error{background-color:#fef2f2;border:1px solid #fecaca;color:#dc2626}.alert-success{background-color:#f0fdf4;border:1px solid #bbf7d0;color:#16a34a}.alert-close{background:none;border:none;color:inherit;cursor:pointer;font-size:20px;opacity:.7;padding:0 4px}.alert-close:hover{opacity:1}.stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(5,1fr);margin-bottom:24px}.stat-card{align-items:center;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);display:flex;gap:16px;padding:20px;transition:all .2s ease}.stat-card.clickable{cursor:pointer}.stat-card.clickable:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-card.active-filter{border:2px solid var(--primary-blue)}.stat-icon{align-items:center;border-radius:var(--radius);display:flex;height:48px;justify-content:center;width:48px}.stat-icon svg{height:24px;width:24px}.stat-icon.total{background-color:#eff6ff;color:var(--primary-blue)}.stat-icon.approved{background-color:#f0fdf4;color:#16a34a}.stat-icon.pending{background-color:#fffbeb;color:#d97706}.stat-icon.created{background-color:#f0f9ff;color:#0284c7}.stat-icon.canceled{background-color:#fef2f2;color:#dc2626}.stat-content{display:flex;flex-direction:column}.stat-value{color:var(--gray-900);font-size:24px;font-weight:700}.stat-label{color:var(--gray-500);font-size:13px}.search-bar{position:relative}.search-input{border:1px solid var(--gray-200);border-radius:var(--radius);font-size:14px;padding:12px 40px 12px 16px;transition:border-color .2s,box-shadow .2s;width:100%}.search-input:focus{border-color:var(--primary-blue);box-shadow:0 0 0 3px #0d4d7a1a;outline:none}.search-clear{background:none;border:none;color:var(--gray-400);cursor:pointer;font-size:20px;padding:0;position:absolute;right:12px;top:50%;transform:translateY(-50%)}.search-clear:hover{color:var(--gray-600)}.card{border-radius:var(--radius)}.card-header{align-items:center;display:flex;justify-content:space-between;padding:16px 20px}.card-header h2{font-size:16px;margin:0}.result-count{color:var(--gray-500);font-size:13px}.card-body{padding:0}.table-container{overflow-x:auto}.events-table{border-collapse:collapse;width:100%}.events-table td,.events-table th{border-bottom:1px solid var(--gray-100);padding:10px 8px;text-align:left}.events-table th{background:var(--gray-50);color:var(--gray-500);font-size:12px;font-weight:600;text-transform:uppercase}.events-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.events-table td,.events-table th.sortable:hover{color:var(--gray-700)}.events-table td{font-size:14px}.events-table tr:last-child td{border-bottom:none}.events-table tr:hover{background-color:var(--gray-50)}.events-table tr.created-row{background-color:#f0fdf4}.event-name{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.status-badge{border-radius:12px;display:inline-block;font-weight:500;padding:4px 10px}.status-badge.approved{background-color:#dcfce7;color:#166534}.status-badge.pending{background-color:#fef3c7;color:#92400e}.status-badge.rejected{background-color:#fee2e2;color:#991b1b}.status-badge.created{background-color:#dbeafe;color:#1e40af}.status-badge.unknown{background-color:var(--gray-100);color:var(--gray-600)}.group-id-badge{color:var(--gray-400);display:block;font-size:11px;margin-top:2px}.created-badge{background-color:#dcfce7;border-radius:12px;color:#166534;display:inline-block;font-size:12px;font-weight:500;padding:4px 10px}.no-group-warning{color:#dc2626;font-size:12px}.waiting-approval{color:var(--gray-400)}.actions-cell{white-space:nowrap}.action-buttons{align-items:center;display:flex;flex-wrap:nowrap;gap:4px}.btn-sm{font-size:13px;padding:6px 12px}.btn-info{background-color:#0ea5e9;border:none;color:#fff}.btn-info:hover:not(:disabled){background-color:#0284c7}.btn-danger{background-color:#dc2626;border:none}.btn-danger:hover:not(:disabled){background-color:#b91c1c}.btn-icon{align-items:center;border:none;border-radius:var(--radius-sm);cursor:pointer;display:inline-flex;height:32px;justify-content:center;padding:0;transition:all .2s;width:32px}.btn-icon svg{height:16px;width:16px}.btn-icon:disabled{cursor:not-allowed;opacity:.5}.btn-icon-primary{background-color:var(--primary-blue);color:#fff}.btn-icon-primary:hover:not(:disabled){background-color:var(--primary-dark)}.btn-icon-secondary{background-color:var(--gray-200);color:var(--gray-700)}.btn-icon-secondary:hover:not(:disabled){background-color:var(--gray-300)}.btn-icon-info{background-color:#0ea5e9;color:#fff}.btn-icon-info:hover:not(:disabled){background-color:#0284c7}.btn-icon-danger{background-color:#dc2626;color:#fff}.btn-icon-danger:hover:not(:disabled){background-color:#b91c1c}.confirm-delete-inline{display:flex;gap:4px}.confirm-delete{align-items:center;color:var(--gray-700);display:flex;font-size:12px;gap:6px}.confirm-delete span{font-weight:500}.ccb-status-cell{min-width:100px}.ccb-status-badge{border-radius:var(--radius-sm);display:flex;flex-direction:column;font-size:12px;gap:2px;padding:4px 8px}.ccb-status-badge .ccb-state{font-weight:500}.ccb-status-badge .ccb-timestamp{font-size:10px;opacity:.8}.ccb-status-badge.ccb-added{background-color:#dcfce7;color:#166534}.ccb-status-badge.ccb-updated{background-color:#dbeafe;color:#1e40af}.ccb-status-badge.ccb-deleted{background-color:#fee2e2;color:#991b1b}.ccb-status-badge.ccb-error{background-color:#fef3c7;color:#92400e}.ccb-status-badge.ccb-unchanged{background-color:var(--gray-100);color:var(--gray-600)}.ccb-status-badge.ccb-active{background-color:#dcfce7;color:#166534}.ccb-status-badge.ccb-pending{background-color:#fef3c7;color:#92400e}.ccb-status-none{color:var(--gray-400);font-size:12px;font-style:italic}.asana-id-cell,.ccb-id-cell{font-family:monospace;font-size:11px;white-space:nowrap}.asana-id-link,.ccb-id-link{color:var(--info);text-decoration:none;transition:color .15s ease}.asana-id-link:hover,.ccb-id-link:hover{color:var(--primary-blue);text-decoration:underline}.ccb-id-none{color:var(--gray-400)}.btn-spinner{animation:spin .8s linear infinite;border:2px solid #0000;border-radius:50%;border-top-color:initial;display:inline-block;height:12px;margin-right:6px;vertical-align:middle;width:12px}.empty-state{color:var(--gray-500);padding:60px 20px;text-align:center}.events-dashboard .pagination{align-items:center;background:#f8f9fb;border-bottom:1px solid var(--gray-200);display:flex;justify-content:space-between;padding:12px 24px}.events-dashboard .table-container+.pagination{border-bottom:none;border-top:1px solid var(--gray-200)}.events-dashboard .pagination-info{color:var(--gray-600);font-size:13px}.events-dashboard .pagination-info strong{color:var(--primary-blue);font-weight:600}.events-dashboard .pagination-controls{align-items:center;display:flex;gap:4px}.events-dashboard .pagination-btn{align-items:center;background:#fff;border:1px solid var(--gray-200);border-radius:4px;color:var(--gray-600);cursor:pointer;display:inline-flex;font-size:13px;font-weight:500;gap:4px;justify-content:center;min-width:32px;padding:6px 12px;transition:all .15s ease}.events-dashboard .pagination-btn:hover:not(:disabled):not(.active){background:var(--gray-50);border-color:var(--gray-300);color:var(--gray-700)}.events-dashboard .pagination-btn:disabled{background:var(--gray-50);cursor:not-allowed;opacity:.4}.events-dashboard .pagination-btn.pagination-nav{padding:6px 10px}.events-dashboard .pagination-btn.pagination-num{min-width:36px;padding:6px 8px}.events-dashboard .pagination-btn.active{background:var(--primary-blue);border-color:var(--primary-blue);color:#fff}.events-dashboard .pagination-ellipsis{color:var(--gray-400);font-size:13px;padding:6px 4px}.events-dashboard .activity-log-table-container+.activity-pagination{border-bottom:none;border-top:1px solid var(--gray-200)}.alert-room-assignment{align-items:flex-start;background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b;border-radius:var(--radius);box-shadow:0 4px 6px -1px #f59e0b33;display:flex;justify-content:space-between;margin-bottom:20px;padding:16px 20px}.room-assignment-content{align-items:flex-start;display:flex;gap:16px}.room-assignment-icon{align-items:center;background:#f59e0b;border-radius:50%;display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.room-assignment-icon svg{color:#fff;height:24px;width:24px}.room-assignment-details{flex:1 1}.room-assignment-details h4{color:#92400e;font-size:16px;font-weight:700;margin:0 0 8px}.room-assignment-details p{color:#78350f;font-size:14px;margin:4px 0}.room-assignment-details .room-match{background:#fff;border:1px solid #f59e0b;border-radius:var(--radius-sm);margin-top:12px;padding:10px 14px}.room-assignment-details .room-name{background:#dbeafe;border-radius:4px;color:#0d4d7a;font-size:16px;font-weight:700;margin-right:8px;padding:2px 8px}.room-assignment-details .room-id{color:var(--gray-500);font-size:12px}.room-assignment-details .room-warning{color:#dc2626;font-weight:500}.room-assignment-details .room-instructions{color:#78350f;font-size:13px;font-style:italic;margin-top:12px}.matched-room-cell{min-width:100px}.room-match-info{display:flex;flex-direction:column;gap:4px}.room-name-badge{background-color:#dbeafe;color:#1e40af;font-size:12px;font-weight:500;padding:4px 8px}.room-name-badge,.room-pending-badge{border-radius:var(--radius-sm);display:inline-block}.room-pending-badge{background-color:#fef3c7;color:#92400e;font-size:10px;font-weight:600;padding:2px 6px;text-transform:uppercase}.no-room-match{color:#dc2626;font-size:12px;font-style:italic}.no-location,.room-not-synced{color:var(--gray-400);font-size:12px}@media (max-width:1024px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.page-header{flex-direction:column;gap:16px}.header-content h1{font-size:24px}.stats-grid{grid-template-columns:1fr}.events-table td,.events-table th{padding:8px 6px}.event-name{max-width:120px}.activity-log-table td:nth-child(4),.activity-log-table th:nth-child(4),.events-table td:nth-child(5),.events-table td:nth-child(6),.events-table td:nth-child(8),.events-table td:nth-child(9),.events-table th:nth-child(5),.events-table th:nth-child(6),.events-table th:nth-child(8),.events-table th:nth-child(9){display:none}.activity-log-table td,.activity-log-table th{font-size:12px;padding:6px 8px}}@media (max-width:480px){.events-dashboard{padding:0 12px}.events-table td:nth-child(7),.events-table th:nth-child(7){display:none}.events-dashboard .pagination{align-items:center;flex-direction:column;gap:8px}.events-dashboard .pagination-controls{flex-wrap:wrap;justify-content:center}.action-buttons{flex-direction:column}.event-name{max-width:100px}}.activity-log-section{border-top:1px solid var(--gray-200);margin-top:24px;padding:16px}.activity-log-toggle{background:var(--gray-100);border:1px solid var(--gray-300);border-radius:6px;color:var(--gray-700);cursor:pointer;font-size:14px;padding:8px 16px;transition:all .2s}.activity-log-toggle:hover{background:var(--gray-200)}.activity-log-panel{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:8px;margin-top:16px;padding:16px}.activity-log-header{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:16px}.activity-log-header h3{color:var(--gray-800);font-size:16px;margin:0}.activity-filter{align-items:center;display:flex;gap:8px}.activity-filter label{color:var(--gray-600);font-size:14px}.activity-filter select{border:1px solid var(--gray-300);border-radius:4px;font-size:14px;padding:6px 10px}.btn-refresh{background:var(--primary);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:13px;padding:6px 12px}.btn-refresh:hover{background:var(--primary-dark)}.btn-refresh:disabled{background:var(--gray-400);cursor:not-allowed}.activity-empty,.activity-loading{color:var(--gray-500);font-style:italic;padding:24px;text-align:center}.activity-log-table-container{overflow-x:auto}.activity-log-table{border-collapse:collapse;font-size:13px;width:100%}.activity-log-table td,.activity-log-table th{border-bottom:1px solid var(--gray-200);padding:10px 12px;text-align:left}.activity-log-table th{color:var(--gray-700);font-weight:600}.activity-log-table tbody tr:hover,.activity-log-table th{background:var(--gray-100)}.activity-time{color:var(--gray-600);font-size:12px;white-space:nowrap}.activity-event-name{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.activity-ccb-id{font-family:monospace;font-size:12px}.activity-action-badge{border-radius:4px;display:inline-block;font-size:12px;font-weight:500;padding:3px 8px}.activity-created{background-color:#dcfce7;color:#166534}.activity-updated{background-color:#dbeafe;color:#1e40af}.activity-deleted-app{background-color:#fee2e2;color:#991b1b}.activity-deleted-ccb{background-color:#fef3c7;color:#92400e}.activity-unchanged{background-color:var(--gray-100);color:var(--gray-600)}.activity-pending{background-color:#fef3c7;color:#92400e}.activity-stale{background-color:#fce7f3;color:#9d174d}.activity-details{color:var(--gray-600);font-size:12px}.activity-details .changed-fields{display:block}.activity-details .error-message{color:#dc2626;display:block}.activity-details .detected-by{display:block;font-style:italic}.headcount-dashboard{margin:0 auto;max-width:1400px;padding:0 20px}.attendance-tabs{align-items:center;display:flex;flex-shrink:0;gap:0}.attendance-tab{background:#0000;border:none;color:var(--gray-500);cursor:pointer;font-size:14px;font-weight:600;padding:8px 14px;position:relative;transition:color .2s}.attendance-tab:not(:last-child):after{background:var(--gray-300);content:"";height:16px;position:absolute;right:0;top:50%;transform:translateY(-50%);width:1px}.attendance-tab:first-child{border-radius:0;border-right:none}.attendance-tab:last-child{border-radius:0}.attendance-tab:hover:not(.active){color:var(--gray-700)}.attendance-tab.active{background:#0000;color:var(--primary-blue)}.attendance-tab.active:before{background:var(--primary-blue);border-radius:1px;bottom:0;content:"";height:2px;left:50%;position:absolute;transform:translateX(-50%);width:calc(100% - 28px)}.attendance-tabs-wrapper{display:flex;flex-direction:column;flex-shrink:0;gap:6px}.sunday-metrics-grouped{display:flex;flex-direction:column;gap:24px;margin-bottom:20px;margin-top:28px}.service-time-section{grid-gap:24px;align-items:center;background:var(--gray-50);border-left:5px solid #0d9488;border-radius:var(--radius);display:grid;gap:24px;grid-template-columns:.5fr 1fr 1fr 1fr;padding:20px}.service-time-section:first-child{border-left-color:#0d9488}.service-time-section:nth-child(2){border-left-color:#2563eb}.service-time-section:nth-child(3){border-left-color:#d97706}.service-time-header-area{align-items:center;display:flex;justify-content:center}.service-time-header{align-items:center;background:var(--primary-blue);border-radius:var(--radius-lg);display:flex;flex-direction:column;padding:12px 18px}.service-time-label{color:#fff;font-size:19px;font-weight:700;white-space:nowrap}.service-time-divider{background:#fff6;border-radius:1px;height:2px;margin:6px 0;width:28px}.service-time-total{color:#fff;font-size:15px;font-weight:700;white-space:nowrap}.sunday-metrics-row{display:flex;gap:24px;grid-column:2/-1;justify-content:center}.sunday-metrics-row .metric-card{flex:1 1;max-width:calc(33.33333% - 16px)}.metric-card{background:#fff;border:2px solid #0000;border-radius:var(--radius);box-shadow:var(--shadow);cursor:pointer;display:flex;flex-direction:column;min-width:0;overflow:hidden;transition:transform .2s ease,border-color .2s,background-color .2s,box-shadow .2s ease}.metric-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.metric-card.selected{background-color:#eff6ff;border-color:var(--primary-blue)}.metric-banner{aspect-ratio:3/1;border-radius:var(--radius) var(--radius) 0 0;flex-shrink:0;overflow:hidden;width:100%}.metric-banner img{height:100%;object-fit:cover;object-position:center;width:100%}.metric-body{flex-shrink:0;padding:10px 8px;text-align:center;white-space:nowrap}.metric-value{color:var(--gray-800);font-size:28px;font-weight:700;line-height:1.1;margin-bottom:2px;white-space:nowrap}.metric-label{color:var(--gray-500);font-size:12px;font-weight:500;white-space:nowrap}.headcount-controls{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:16px;padding:12px 0}.attendance-summary-banner{border-radius:16px;box-shadow:0 2px 8px #0000001a;display:flex;margin-bottom:24px;overflow:hidden}.attendance-summary-stat{align-items:center;background:linear-gradient(90deg,#1e3a5f,#2c5282);color:#fff;display:flex;flex-direction:column;justify-content:center;min-width:200px;padding:28px 36px}.attendance-summary-label{color:#fff9;font-size:11px;font-weight:600;letter-spacing:.12em;margin-bottom:6px;text-transform:uppercase}.attendance-summary-row{align-items:center;display:flex;gap:12px}.attendance-summary-number{font-size:56px;font-weight:800;letter-spacing:-.03em;line-height:1}.attendance-summary-icon{color:#fff6;height:32px;width:32px}.attendance-summary-title{align-items:center;background:linear-gradient(90deg,#2c5282,#4a6a7a,#7a7560,#8b7355,#b8a088);display:flex;flex:1 1;justify-content:center}.attendance-summary-title-text{color:#fff9;font-size:18px;letter-spacing:.5px;padding:0 36px;text-align:center}.attendance-summary-title-text strong{color:#fff;font-size:20px;font-weight:800}.attendance-summary-title-text em{font-style:italic;font-weight:400}.design-toggle-wrap{flex-direction:column;gap:4px}.design-toggle-btn,.design-toggle-wrap{align-items:center;display:flex;flex-shrink:0}.design-toggle-btn{background:#fff;border:1px solid var(--gray-200);border-radius:8px;color:var(--gray-500);cursor:pointer;height:34px;justify-content:center;transition:all .2s;width:34px}.design-toggle-btn:hover{border-color:var(--primary-blue);color:var(--primary-blue)}.design-toggle-dots{display:flex;gap:4px}.design-toggle-dot{background:var(--gray-300);border-radius:50%;height:6px;transition:background .2s;width:6px}.design-toggle-dot.active{background:var(--primary-blue)}.modern-grand-total{align-items:center;background:var(--primary-gradient);border-radius:16px;display:flex;justify-content:space-between;margin-bottom:24px;overflow:hidden;padding:28px 36px;position:relative}.modern-grand-total-decor{background:radial-gradient(circle,#ffffff0f 0,#0000 70%);border-radius:50%;height:200px;position:absolute;right:-40px;top:-40px;width:200px}.modern-grand-total-left{align-items:center;display:flex;flex-direction:column;position:relative}.modern-grand-total-label{color:#fff9;font-size:11px;font-weight:600;letter-spacing:.12em;margin-bottom:6px;text-transform:uppercase}.modern-grand-total-row{align-items:center;display:flex;gap:12px}.modern-grand-total-number{color:#fff;font-size:56px;font-weight:800;letter-spacing:-.03em;line-height:1}.modern-grand-total-icon{color:#fff6;height:32px;width:32px}.modern-grand-total-right{color:#fff9;font-size:18px;font-style:italic;font-weight:400;position:relative}.modern-grand-total-right em{font-style:italic}.modern-service-cards{display:flex;flex-direction:column;gap:14px;margin-bottom:24px}.modern-service-card{background:#fff;border:1px solid var(--gray-200);border-radius:14px;overflow:hidden;transition:box-shadow .2s}.modern-service-card:hover{box-shadow:0 2px 12px #0000000f}.modern-service-header{align-items:center;display:flex;justify-content:space-between;padding:18px 24px}.modern-service-header-left{align-items:center;display:flex;gap:18px}.modern-service-badge{border-radius:10px;color:#fff;font-size:15px;font-weight:700;min-width:64px;padding:8px 18px;text-align:center}.modern-service-total-wrap{align-items:center;display:flex;flex-direction:column}.modern-service-total{color:var(--gray-900);font-size:30px;font-weight:800;letter-spacing:-.02em;line-height:1.1}.modern-service-total-sub{color:var(--gray-400);font-size:12px}.gallery-breakdown{border-top:1px solid var(--gray-100);display:flex;padding:0}.gallery-breakdown-item{align-items:center;border-left:1px solid var(--gray-100);cursor:pointer;display:flex;flex:1 1;flex-direction:column;gap:10px;padding:16px 12px;text-align:center;transition:background .15s}.gallery-breakdown-item:first-child{border-left:none}.gallery-breakdown-item:hover{background:var(--gray-50)}.gallery-breakdown-item.selected{background:var(--gray-50);box-shadow:inset 0 -3px 0 var(--primary-blue)}.gallery-breakdown-img{aspect-ratio:16/9;border-radius:10px;flex-shrink:0;max-width:160px;overflow:hidden;width:100%}.gallery-breakdown-img img{height:100%;object-fit:cover;width:100%}.gallery-breakdown-info{align-items:center;display:flex;flex-direction:column}.gallery-breakdown-value{color:var(--gray-900);font-size:24px;font-weight:700;letter-spacing:-.02em;line-height:1.2}.gallery-breakdown-label{color:var(--gray-400);font-size:12px;font-weight:500;margin-top:2px}.modern-service-header-total{color:var(--gray-800);font-size:20px;font-weight:700;letter-spacing:-.02em}.gallery-sunday-total{align-items:center;background:var(--gray-50);border:1px solid var(--gray-200);border-radius:12px;display:flex;justify-content:space-between;padding:14px 20px}.gallery-sunday-total-label{color:var(--gray-600);font-size:14px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.gallery-sunday-total-value{color:var(--gray-900);font-size:24px;font-weight:800;letter-spacing:-.02em}.headcount-controls-left{gap:12px}.headcount-controls-left,.headcount-dropdowns{align-items:center;display:flex;flex-shrink:1;min-width:0}.headcount-dropdowns{flex-wrap:wrap;gap:8px}.headcount-dropdown{display:flex;flex-direction:column}.headcount-dropdown select{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius);color:var(--gray-700);cursor:pointer;font-size:14px;max-width:200px;min-width:0;padding:8px 12px}.headcount-dropdown select:focus{border-color:var(--primary-blue);box-shadow:0 0 0 2px #2563eb1a;outline:none}.groups-loading-hint{color:var(--gray-400);font-size:12px;font-style:italic}.headcount-controls-right{align-items:center;display:flex;flex-shrink:0;gap:16px}.view-toggle{align-items:center;display:flex;gap:0}.view-toggle-btn{background:#0000;border:none;color:var(--gray-500);cursor:pointer;font-size:14px;font-weight:500;padding:8px 14px;position:relative;transition:color .2s}.view-toggle-btn:not(:last-child):after{background:var(--gray-300);content:"";height:16px;position:absolute;right:0;top:50%;transform:translateY(-50%);width:1px}.view-toggle-btn:hover:not(.active){color:var(--gray-700)}.view-toggle-btn.active{color:var(--primary-blue);font-weight:600}.view-toggle-btn.active:before{background:var(--primary-blue);border-radius:1px;bottom:0;content:"";height:2px;left:50%;position:absolute;transform:translateX(-50%);width:calc(100% - 28px)}.date-navigator{align-items:center;display:flex;gap:12px}.date-nav-btn{align-items:center;background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius);color:var(--gray-600);cursor:pointer;display:inline-flex;height:32px;justify-content:center;padding:0;transition:all .2s;width:32px}.date-nav-btn:hover:not(:disabled){background:var(--gray-50);border-color:var(--gray-300)}.date-nav-btn:disabled{cursor:not-allowed;opacity:.4}.date-label{background:#fef9c3;border-radius:var(--radius);color:var(--gray-800);font-size:15px;font-weight:600;min-width:220px;padding:5px 14px;text-align:center}.headcount-dashboard .page-header{align-items:center}.headcount-dashboard .header-content{align-items:center;display:flex;flex:1 1;gap:24px;min-width:0}.headcount-dashboard .header-content h1{flex-shrink:0}.event-search-container{flex:1 1;margin:0 16px;position:relative}.event-search-box{align-items:center;background:#fff;border:2px solid var(--gray-200);border-radius:10px;cursor:text;display:flex;flex-wrap:wrap;gap:6px;min-height:38px;padding:6px 14px;transition:border-color .2s,box-shadow .2s}.event-search-box:focus-within{box-shadow:0 0 0 3px #3b82f61f}.event-search-box.has-selections,.event-search-box:focus-within{border-color:var(--primary-blue)}.event-search-input{background:#0000;border:none;color:var(--gray-800);flex:1 1;font-size:14px;min-width:120px;outline:none;padding:2px 0}.event-search-input::placeholder{color:var(--gray-400)}.event-search-tag{align-items:center;animation:tagSlideIn .2s ease-out;background:var(--primary-blue);border-radius:6px;color:#fff;display:inline-flex;font-size:12px;font-weight:500;gap:4px;max-width:200px;padding:3px 8px;white-space:nowrap}@keyframes tagSlideIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.event-search-tag-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.event-search-tag-remove{background:none;border:none;color:#ffffffb3;cursor:pointer;font-size:14px;line-height:1;padding:0 1px;transition:color .15s}.event-search-tag-remove:hover{color:#fff}.event-search-clear{align-items:center;background:none;border:none;color:var(--gray-400);cursor:pointer;display:flex;flex-shrink:0;padding:2px;transition:color .15s}.event-search-clear:hover{color:var(--gray-600)}.event-search-dropdown{animation:dropdownFadeIn .15s ease-out;background:#fff;border:1px solid var(--gray-200);border-radius:10px;box-shadow:0 8px 24px #0000001f;left:0;max-height:260px;overflow-y:auto;position:absolute;right:0;top:calc(100% + 4px);z-index:100}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.event-search-option{border-bottom:1px solid var(--gray-50);color:var(--gray-700);cursor:pointer;font-size:13px;padding:9px 14px;transition:background .1s}.event-search-option:last-child{border-bottom:none}.event-search-option:hover{background:var(--gray-50);color:var(--primary-blue)}.event-search-more{color:var(--gray-400);font-size:12px;font-style:italic;padding:8px 14px;text-align:center}.page-header-actions{align-items:center;display:flex;flex-shrink:0;gap:8px}.btn-reset{align-items:center!important;background:#f59e0b!important;border:none!important;border-radius:8px!important;box-shadow:none!important;color:#fff!important;cursor:pointer;display:inline-flex!important;font-size:13px!important;font-weight:600!important;justify-content:center!important;letter-spacing:.3px!important;padding:8px 14px!important;transition:background .25s ease,transform .15s ease,box-shadow .25s ease!important}.btn-reset:hover:not(:disabled){background:#d97706!important;box-shadow:0 2px 8px #f59e0b59!important}.btn-reset:active:not(:disabled){transform:scale(.96)}.headcount-dashboard .card-header-right{align-items:center;display:flex;gap:16px}.toggle-switch{align-items:center;cursor:pointer;display:flex;gap:8px;-webkit-user-select:none;user-select:none}.toggle-switch input{display:none}.toggle-slider{background:var(--gray-300);border-radius:10px;flex-shrink:0;height:20px;position:relative;transition:background .2s;width:36px}.toggle-slider:after{background:#fff;border-radius:50%;content:"";height:16px;left:2px;position:absolute;top:2px;transition:transform .2s;width:16px}.toggle-switch input:checked+.toggle-slider{background:var(--primary-blue)}.toggle-switch input:checked+.toggle-slider:after{transform:translateX(16px)}.toggle-label{color:var(--gray-500);font-size:13px;font-weight:500}.attendance-total{color:var(--gray-600);font-size:18px}.attendance-total strong{color:var(--gray-800);font-size:40px}.chart-comparison{display:flex;gap:20px}.chart-comparison-panel{flex:1 1;min-width:0}.chart-comparison-label{color:var(--gray-600);font-size:14px;font-weight:600;margin-bottom:4px;text-align:center}.chart-comparison-empty{align-items:center;color:var(--gray-400);display:flex;font-size:14px;height:120px;justify-content:center}.comparison-total{display:block;margin-bottom:8px;text-align:center}.headcount-dashboard .card+.card{margin-top:24px}.search-bar{align-items:center;display:flex;gap:12px;margin-bottom:16px}.search-bar .search-input{flex:1 1}.headcount-table{border-collapse:collapse;width:100%}.headcount-table td,.headcount-table th{border-bottom:1px solid var(--gray-100);padding:10px 12px;text-align:left}.headcount-table th{background:var(--gray-50);color:var(--gray-500);font-size:12px;font-weight:600;text-transform:uppercase}.headcount-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.headcount-table td,.headcount-table th.sortable:hover{color:var(--gray-700)}.headcount-table td{font-size:14px}.headcount-table tr:last-child td{border-bottom:none}.headcount-table tr:hover{background-color:var(--gray-50)}.headcount-cell,.headcount-value{text-align:center}.headcount-value{border-radius:12px;display:inline-block;font-size:14px;font-weight:600;min-width:40px;padding:4px 12px}.headcount-value.has-count{background-color:#dcfce7;color:#166534}.headcount-value.no-count{background-color:var(--gray-100);color:var(--gray-400)}.total-cell .headcount-value.has-count{background-color:#dbeafe;color:#1e40af}.headcount-dashboard .pagination{align-items:center;background:#f8f9fb;border-bottom:1px solid var(--gray-200);display:flex;justify-content:space-between;padding:12px 24px}.headcount-dashboard .table-container+.pagination{border-bottom:none;border-top:1px solid var(--gray-200)}.headcount-dashboard .pagination-info{color:var(--gray-600);font-size:13px}.headcount-dashboard .pagination-info strong{color:var(--primary-blue);font-weight:600}.headcount-dashboard .pagination-controls{align-items:center;display:flex;gap:4px}.headcount-dashboard .pagination-btn{align-items:center;background:#fff;border:1px solid var(--gray-200);border-radius:4px;color:var(--gray-600);cursor:pointer;display:inline-flex;font-size:13px;font-weight:500;gap:4px;justify-content:center;min-width:32px;padding:6px 12px;transition:all .15s ease}.headcount-dashboard .pagination-btn:hover:not(:disabled):not(.active){background:var(--gray-50);border-color:var(--gray-300);color:var(--gray-700)}.headcount-dashboard .pagination-btn:disabled{background:var(--gray-50);cursor:not-allowed;opacity:.4}.headcount-dashboard .pagination-btn.pagination-nav{padding:6px 10px}.headcount-dashboard .pagination-btn.pagination-num{min-width:36px;padding:6px 8px}.headcount-dashboard .pagination-btn.active{background:var(--primary-blue);border-color:var(--primary-blue);color:#fff}.headcount-dashboard .pagination-ellipsis{color:var(--gray-400);font-size:13px;padding:6px 4px}.export-btn{align-items:center;background:#dc2626;border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-size:13px;font-weight:600;gap:6px;justify-content:center;letter-spacing:.3px;padding:8px 14px;transition:background .25s ease,transform .15s ease,box-shadow .25s ease}.export-btn:hover{background:#b91c1c;box-shadow:0 2px 8px #dc262659}.export-btn:active{transform:scale(.96)}.insights-row{grid-gap:24px;align-items:stretch;display:grid;gap:24px;grid-template-columns:1fr;margin-bottom:24px}.insights-row .insights-card{min-width:0}.insights-row .card+.card{margin-top:0}.print-only{display:none}.print-report-header{margin-bottom:20px;text-align:center}.print-report-header h1{color:var(--gray-900);font-size:22px;font-weight:700;margin:0 0 4px}.print-report-header p{color:var(--gray-500);font-size:14px;margin:0}@media print{@page{size:landscape;margin:1cm}.app-header,.btn-reset,.design-toggle-btn,.design-toggle-wrap,.event-search-container,.headcount-controls,.headcount-dashboard .pagination,.header,.page-header,.screen-only,.scroll-to-top,.search-bar,.sidebar-nav,.toggle-switch,nav{display:none!important}.print-only{display:block!important}.headcount-dashboard{max-width:none;padding:0}.main-content{padding:0!important}.headcount-dashboard .card{border:1px solid #ddd;box-shadow:none}.sunday-metrics-grouped{margin-bottom:16px}.attendance-summary-banner,.modern-grand-total{print-color-adjust:exact;-webkit-print-color-adjust:exact}.modern-grand-total,.modern-service-cards{margin-bottom:16px}.modern-service-card{break-inside:avoid;page-break-inside:avoid}.gallery-breakdown-img img{print-color-adjust:exact;-webkit-print-color-adjust:exact}.vertical-service-cards{margin-bottom:16px}.vertical-service-card{break-inside:avoid;page-break-inside:avoid}.vertical-service-header{print-color-adjust:exact;-webkit-print-color-adjust:exact}.insights-row{margin-bottom:0}.insights-row .card{break-inside:avoid;page-break-inside:avoid}.headcount-dashboard .print-only{break-before:page;page-break-before:always}.print-only .headcount-table td,.print-only .headcount-table th{font-size:11px;padding:4px 8px}.print-only .headcount-table th{background:#f3f4f6!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.print-only .headcount-cell{text-align:center}}.scroll-to-top{align-items:center;background:#fff;border:1px solid var(--gray-200);border-radius:50%;bottom:24px;box-shadow:0 2px 8px #00000014;color:var(--gray-500);cursor:pointer;display:flex;height:36px;justify-content:center;opacity:.7;position:fixed;right:24px;transition:opacity .2s,background .2s,color .2s;width:36px;z-index:50}.scroll-to-top:hover{background:var(--gray-50);color:var(--gray-700);opacity:1}.vertical-service-cards{display:flex;gap:16px;margin-bottom:28px}.vertical-service-card{background:#fff;border:1px solid var(--gray-200);border-radius:14px;display:flex;flex:1 1;flex-direction:column;overflow:hidden}.vertical-service-header{padding:14px 12px;text-align:center}.vertical-service-time{color:#fff;font-size:16px;font-weight:700}.vertical-service-total-area{border-bottom:1px solid var(--gray-100);padding:20px 12px 14px;text-align:center}.vertical-service-total-number{color:var(--gray-900);font-size:40px;font-weight:800;letter-spacing:-.03em;line-height:1}.vertical-service-total-number.zero{color:var(--gray-300)}.vertical-service-total-sub{color:var(--gray-400);font-size:11px;font-weight:500;letter-spacing:.04em;margin-top:6px;text-transform:uppercase}.vertical-breakdown{display:flex;flex:1 1;flex-direction:column;justify-content:center;padding:4px 0}.vertical-breakdown-item{cursor:pointer;padding:12px 16px;text-align:center;transition:background .15s}.vertical-breakdown-item.has-border{border-bottom:1px solid var(--gray-50)}.vertical-breakdown-item:hover{background:var(--gray-50)}.vertical-breakdown-item.selected{background:#eff6ff;border-radius:4px;box-shadow:inset 0 0 0 2px var(--primary-blue)}.vertical-breakdown-value{color:var(--gray-900);font-size:24px;font-weight:700;letter-spacing:-.02em;margin-bottom:4px}.vertical-breakdown-value.zero{color:var(--gray-300)}.vertical-breakdown-label{color:var(--gray-400);font-size:12px;font-weight:500;line-height:1.3}@media (max-width:768px){.headcount-dashboard .header-content{align-items:flex-start;flex-direction:column;gap:10px}.event-search-container{margin:0;max-width:100%;width:100%}.chart-comparison{flex-direction:column}.sunday-metrics-grouped{gap:32px}.service-time-section{gap:12px;grid-template-columns:1fr;padding:16px}.sunday-metrics-row{grid-column:1}.service-time-header{flex-direction:row;gap:12px;padding:10px 20px}.service-time-divider{height:16px;margin:0;width:2px}.sunday-metrics-row{flex-wrap:wrap;gap:10px}.sunday-metrics-row .metric-card{flex-basis:calc(50% - 5px);flex-grow:1;flex-shrink:1}.metric-banner{aspect-ratio:3/1;height:auto}.attendance-summary-stat{min-width:140px;padding:20px 24px}.attendance-summary-number{font-size:40px}.attendance-summary-label{font-size:10px}.attendance-summary-title-text{font-size:15px;padding:0 16px}.attendance-summary-title-text strong{font-size:17px}.modern-grand-total{flex-direction:column;gap:12px;padding:20px 24px;text-align:center}.modern-grand-total-number{font-size:40px}.modern-grand-total-right{font-size:15px}.modern-service-header{padding:14px 16px}.gallery-breakdown{flex-direction:column}.gallery-breakdown-item{border-left:none;border-top:1px solid var(--gray-100);flex-direction:row;text-align:left}.gallery-breakdown-item:first-child{border-top:none}.gallery-breakdown-img{max-width:80px;width:80px}.gallery-breakdown-info{align-items:flex-start}.vertical-service-cards{flex-direction:column;gap:12px}.vertical-service-header{padding:10px 8px}.vertical-service-time{font-size:14px}.vertical-service-total-area{padding:14px 8px 10px}.vertical-service-total-number{font-size:28px}.vertical-breakdown-item{padding:8px 10px}.vertical-breakdown-value{font-size:18px}.vertical-breakdown-label{font-size:10px}.headcount-controls{align-items:flex-start;flex-direction:column}.headcount-controls-left,.headcount-dropdowns{align-items:flex-start;flex-direction:column;width:100%}.headcount-dropdown select{max-width:none;min-width:auto;width:100%}.headcount-controls-right{align-items:flex-start;flex-direction:column;width:100%}.headcount-summary{margin-left:0}.view-toggle-btn{padding:6px 12px}.date-navigator{justify-content:center;width:100%}.date-label{font-size:16px;min-width:auto}.headcount-table td:first-child,.headcount-table th:first-child{display:none}.headcount-table td,.headcount-table th{padding:8px 6px}.headcount-dashboard .pagination{align-items:center;flex-direction:column;gap:8px}.headcount-dashboard .pagination-controls{flex-wrap:wrap;justify-content:center}.headcount-dashboard .pagination-btn{min-height:36px}}@media (max-width:480px){.headcount-dashboard{padding:0 12px}.sunday-metrics-grouped{gap:24px}.sunday-metrics-row .metric-card{flex:1 1 100%}.metric-value{font-size:22px}}.App{background-color:#f5f7fa;min-height:100vh}.app-loading{align-items:center;background:var(--primary-gradient);color:#fff;display:flex;flex-direction:column;justify-content:center;min-height:100vh}.app-loading p{font-size:16px;margin-top:16px;opacity:.9}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:48px;width:48px}@keyframes spin{to{transform:rotate(1turn)}}.btn{align-items:center;border:none;border-radius:var(--radius);cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:8px;justify-content:center;padding:12px 24px;text-decoration:none;transition:all .2s ease}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-primary{background:linear-gradient(135deg,var(--accent-green) 0,var(--accent-green-dark) 100%);box-shadow:0 2px 8px #10b9814d;color:#fff}.btn-primary:hover:not(:disabled){box-shadow:0 6px 20px #10b98180;filter:brightness(1.08)}.btn-secondary{background:#fff;border:1px solid var(--gray-200);color:var(--gray-700)}.btn-secondary:hover:not(:disabled){background:var(--gray-50);border-color:var(--gray-300)}.btn-danger{background:linear-gradient(135deg,var(--error) 0,#dc2626 100%);box-shadow:0 2px 8px #ef44444d;color:#fff}.btn-danger:hover:not(:disabled){box-shadow:0 4px 16px #ef444466;transform:translateY(-2px)}.card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden}.card-header{border-bottom:1px solid var(--gray-100);padding:20px 24px}.card-header h2{color:var(--gray-900);font-size:18px;font-weight:600}.card-body{padding:24px}.form-field{margin-bottom:20px}.form-field label{color:var(--gray-700);display:block;font-size:14px;font-weight:500;margin-bottom:8px}.form-control{border:1px solid var(--gray-200);border-radius:var(--radius);font-size:14px;padding:12px 16px;transition:all .2s ease;width:100%}.form-control:focus{border-color:var(--primary-blue);box-shadow:0 0 0 3px #0d4d7a1a;outline:none}.status-badge{align-items:center;border-radius:20px;display:inline-flex;font-size:12px;font-weight:600;gap:6px;padding:4px 12px}.status-badge.success{background:#10b9811a;color:var(--accent-green)}.status-badge.warning{background:#f59e0b1a;color:var(--warning)}.status-badge.error{background:#ef44441a;color:var(--error)}.status-badge.info{background:#3b82f61a;color:var(--info)}@media (max-width:768px){.btn{font-size:13px;min-height:44px;padding:10px 16px}.card-body{padding:16px}}@media (max-width:480px){.card-header{padding:12px 16px}.card-header h2{font-size:16px}.btn{width:100%}}
/*# sourceMappingURL=main.54c4a159.css.map*/