.header{background-color:#2a2a2a;color:#fff;padding:0 20px;box-shadow:0 2px 4px #0003}.header-content{max-width:1400px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;height:60px}.header-brand h1{font-size:1.5rem;font-weight:600}.header-nav{display:flex;gap:10px}.nav-button{background:transparent;border:none;color:#ffffffb3;padding:8px 16px;font-size:1rem;cursor:pointer;border-radius:4px;transition:background-color .2s,color .2s}.nav-button:hover{background-color:#ffffff1a;color:#fff}.nav-button.active{background-color:#fff3;color:#fff}@media(max-width:768px){.header-content{flex-direction:column;height:auto;padding:10px 0}.header-brand h1{font-size:1.25rem}.header-nav{margin-top:10px}}.footer{background-color:#2a2a2a;color:#ffffffb3;padding:15px 20px;text-align:center;font-size:.875rem}.footer-content{max-width:1400px;margin:0 auto}.user-card{background:#fff;border-radius:8px;padding:15px;box-shadow:0 2px 4px #0000001a;border-left:4px solid #ccc;transition:transform .2s,box-shadow .2s}.user-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.user-card.recency-recent{border-left-color:#4caf50}.user-card.recency-moderate{border-left-color:#ff9800}.user-card.recency-old{border-left-color:#9e9e9e}.user-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.user-info{display:flex;flex-direction:column}.user-name{font-weight:600;font-size:1.1rem;color:#2a2a2a}.user-username{font-size:.8rem;color:#888;font-weight:400}.platform-badge{background-color:#e0e0e0;color:#666;padding:2px 8px;border-radius:4px;font-size:.75rem;font-weight:500}.user-card-details{display:flex;flex-direction:column;gap:5px}.detail-row{display:flex;justify-content:space-between;font-size:.875rem}.detail-label{color:#666}.detail-value{color:#333;font-weight:500}.presence-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:15px}.presence-grid-empty{text-align:center;padding:40px;color:#666;font-size:1.1rem;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}@media(max-width:640px){.presence-grid{grid-template-columns:1fr}}.dashboard-page{padding:20px 0}.dashboard-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:15px;margin-bottom:20px}.dashboard-title{display:flex;align-items:center;gap:15px}.dashboard-title h2{color:#2a2a2a;margin:0}.present-count{background-color:#4caf50;color:#fff;padding:4px 12px;border-radius:20px;font-size:.9rem;font-weight:500}.dashboard-controls{display:flex;gap:10px;flex-wrap:wrap}.search-input{padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:.9rem;min-width:280px}.search-input:focus{outline:none;border-color:#2a2a2a}.control-button{padding:8px 16px;background-color:#2a2a2a;color:#fff;border:none;border-radius:4px;font-size:.9rem;cursor:pointer;transition:background-color .2s}.control-button:hover{background-color:#444}.control-button:disabled{background-color:#999;cursor:not-allowed}.control-button.active{background-color:#1976d2}.dashboard-meta{display:flex;justify-content:space-between;margin-bottom:15px;font-size:.85rem;color:#666}.dashboard-error{background-color:#ffebee;color:#c62828;padding:15px;border-radius:4px;margin-bottom:15px;display:flex;justify-content:space-between;align-items:center}.dashboard-error button{background-color:#c62828;color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer}.dashboard-loading{text-align:center;padding:60px;font-size:1.1rem;color:#666}.department-groups{display:flex;flex-direction:column;gap:25px}.department-section{background:#fafafa;border-radius:8px;padding:15px}.department-title{color:#2a2a2a;margin:0 0 15px;padding-bottom:10px;border-bottom:2px solid #2a2a2a;display:flex;align-items:center;gap:10px}.department-count{background-color:#2a2a2a;color:#fff;padding:2px 10px;border-radius:12px;font-size:.85rem;font-weight:400}.emergency-department{margin-bottom:25px}.emergency-department:last-child{margin-bottom:0}.department-header{color:#2a2a2a;margin:0 0 10px;padding:8px 12px;background-color:#e0e0e0;border-radius:4px}.emergency-mode{background-color:#fff3e0;padding:20px;border-radius:8px}.emergency-list h3{color:#d32f2f;margin-bottom:15px}.emergency-table{width:100%;border-collapse:collapse;background:#fff}.emergency-table th,.emergency-table td{padding:10px 12px;text-align:left;border:1px solid #ddd}.emergency-table th{background-color:#2a2a2a;color:#fff}.emergency-table tr:nth-child(2n){background-color:#f5f5f5}@media print{.header,.footer,.dashboard-controls,.dashboard-meta{display:none!important}.dashboard-page{padding:0}.emergency-mode{background:none}.emergency-table{font-size:12px}.department-section,.emergency-department{break-inside:avoid;page-break-inside:avoid}}@media(max-width:768px){.dashboard-header{flex-direction:column;align-items:stretch}.dashboard-controls{flex-direction:column}.search-input{min-width:auto;width:100%}.dashboard-meta{flex-direction:column;gap:5px}}.emergency-summary{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:8px}.emergency-summary-right{display:flex;align-items:center;gap:12px}.emergency-total{font-weight:600;font-size:1.1rem}.reset-button{padding:8px 16px;border:1px solid #ccc;border-radius:6px;background:#fff;cursor:pointer;font-size:.9rem}.reset-button:hover{background:#f3f3f3}.emergency-instructions{color:#666;margin:0 0 16px;font-style:italic}.department-header.all-safe{color:#1e7e34}.dept-progress{margin-left:10px;font-size:.85rem;color:#888;font-weight:500}.emergency-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px;margin-bottom:20px}.emergency-card{display:flex;align-items:center;gap:12px;padding:12px 14px;border:2px solid #e0e0e0;border-radius:8px;background:#fff;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .12s,border-color .12s}.emergency-card:hover{border-color:#bbb}.emergency-card:active{transform:scale(.99)}.emergency-card.safe{background:#e7f6ec;border-color:#2ecc71}.card-check{width:26px;height:26px;flex:0 0 26px;border-radius:50%;border:2px solid #ccc;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700}.emergency-card.safe .card-check{background:#2ecc71;border-color:#2ecc71}.card-info{display:flex;flex-direction:column;min-width:0}.card-name{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-sub{font-size:.78rem;color:#888;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sync-indicator{display:inline-block;margin-left:10px;padding:2px 8px;font-size:.7rem;font-weight:700;letter-spacing:.5px;color:#fff;background:#2ecc71;border-radius:4px;vertical-align:middle}.history-page{padding:20px 0}.history-header h2{color:#2a2a2a;margin-bottom:20px}.history-filters{display:flex;gap:15px;align-items:flex-end;flex-wrap:wrap;margin-bottom:25px;padding:15px;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.filter-group{display:flex;flex-direction:column;gap:5px}.filter-group label{font-size:.85rem;color:#666;font-weight:500}.filter-group input{padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:.9rem}.filter-group input[type=text]{min-width:180px}.filter-group input:focus{outline:none;border-color:#2a2a2a}.filter-button{padding:8px 20px;background-color:#2a2a2a;color:#fff;border:none;border-radius:4px;font-size:.9rem;cursor:pointer;transition:background-color .2s}.filter-button:hover{background-color:#444}.filter-button:disabled{background-color:#999;cursor:not-allowed}.history-error{background-color:#ffebee;color:#c62828;padding:15px;border-radius:4px;margin-bottom:15px}.history-loading,.history-empty{text-align:center;padding:40px;color:#666;font-size:1.1rem;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.history-list{display:flex;flex-direction:column;gap:15px}.history-day{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden}.day-header{display:flex;justify-content:space-between;align-items:center;padding:12px 15px;background-color:#2a2a2a;color:#fff}.day-date{font-weight:600}.day-count{background-color:#fff3;padding:2px 10px;border-radius:12px;font-size:.85rem}.day-users{padding:10px 15px;display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:8px}.day-user{display:flex;justify-content:space-between;padding:6px 10px;background-color:#f5f5f5;border-radius:4px;font-size:.9rem}.day-user .user-name{color:#333}.user-times{display:flex;align-items:center;gap:4px;flex-shrink:0}.user-time-in{color:#2a7a2a;font-size:.85rem}.user-time-separator{color:#aaa;font-size:.8rem}.user-time-out{color:#b22222;font-size:.85rem}@media(max-width:768px){.history-filters{flex-direction:column;align-items:stretch}.filter-button{width:100%}.day-users{grid-template-columns:1fr}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Arial,sans-serif;background-color:#f5f5f5;color:#333;line-height:1.5}.app-container{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;padding:20px;max-width:1400px;margin:0 auto;width:100%}.text-center{text-align:center}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}@media(max-width:768px){.main-content{padding:10px}}
