*{margin:0;padding:0;box-sizing:border-box}:root{--umass-maroon: #881c1c;--umass-white: #ffffff;--umass-dark-gray: #212529;--umass-light-gray: #f8f9fa;--status-online: #28a745;--status-degraded: #ffc107;--status-offline: #dc3545;--status-maintenance: #17a2b8;--severity-info: #17a2b8;--severity-warning: #ffc107;--severity-critical: #dc3545;--spacing-xs: .5rem;--spacing-sm: 1rem;--spacing-md: 1.5rem;--spacing-lg: 2rem;--spacing-xl: 3rem;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Helvetica", "Arial", sans-serif}body{font-family:var(--font-family);color:var(--umass-dark-gray);background-color:var(--umass-light-gray);line-height:1.6}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.skip-link{position:absolute;top:-40px;left:0;background:var(--umass-maroon);color:var(--umass-white);padding:8px 16px;z-index:10001;font-size:.9rem;text-decoration:none;transition:top .2s}.skip-link:focus{top:0}:focus-visible{outline:3px solid var(--umass-maroon);outline-offset:2px}.map-marker:focus-visible{outline:3px solid var(--umass-maroon);outline-offset:2px;box-shadow:0 0 0 4px #881c1c4d,0 2px 6px #0000004d}.container{max-width:1400px;margin:0 auto;padding:0 var(--spacing-md)}.header{background-color:var(--umass-maroon);color:var(--umass-white);padding:.5rem 0;box-shadow:0 2px 4px #0000001a}.header .container{display:flex;align-items:center;gap:.75rem}.header-title{font-size:1.1rem;font-weight:600;margin-bottom:0;display:inline}.header-subtitle{font-size:.85rem;font-weight:400;opacity:.85;display:inline;margin-left:.75rem}.header .container>button:first-of-type{margin-left:auto}.demo-toggle-btn{background:#ffffff26;border:1px solid rgba(255,255,255,.3);color:#fff;padding:.35rem .75rem;border-radius:4px;font-size:.8rem;cursor:pointer;transition:all .2s}.demo-toggle-btn:hover{background:#ffffff40}.demo-toggle-btn.active{background:#ffffff4d;border-color:#ffffff80}.demo-active-indicator{background:#ffc107;color:#000;padding:.25rem .6rem;border-radius:4px;font-size:.7rem;font-weight:600;animation:pulse-warning 2s infinite}@keyframes pulse-warning{0%,to{opacity:1}50%{opacity:.7}}.status-summary{background-color:var(--umass-light-gray);padding:.75rem 0 .5rem}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.5rem;background-color:var(--umass-white);padding:.75rem;border-radius:8px;box-shadow:0 1px 3px #00000014}.summary-card{display:flex;flex-direction:column;align-items:center;padding:.5rem;background-color:var(--umass-white);border-radius:6px;transition:transform .2s}.summary-card:hover{transform:translateY(-2px)}.summary-count{font-size:1.5rem;font-weight:700;color:var(--umass-maroon);line-height:1}.summary-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--umass-dark-gray);margin-top:.25rem;line-height:1}.services-section{background-color:var(--umass-light-gray);padding:var(--spacing-sm) 0}#services-container:empty{display:none}.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--spacing-sm)}.service-card{background-color:var(--umass-white);padding:var(--spacing-md);border-radius:8px;border-left:4px solid;box-shadow:0 2px 4px #0000001a;transition:transform .2s}.service-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.service-card.service-healthy{border-color:var(--status-online)}.service-card.service-degraded{border-color:var(--status-degraded)}.service-card.service-critical{border-color:var(--status-offline)}.service-card.service-unknown{border-color:#6c757d}.service-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.service-name{font-size:1rem;font-weight:600;color:var(--umass-dark-gray);flex:1;min-width:0}.service-status-badge{flex-shrink:0;padding:4px 12px;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.service-status-badge.status-healthy{background:#28a7451a;color:#1a7431}.service-status-badge.status-degraded{background:#ffc1071a;color:#8a6d00}.service-status-badge.status-critical{background:#dc35451a;color:var(--status-offline)}.service-status-badge.status-unknown{background:#6c757d1a;color:#6c757d}.service-message{font-size:.9rem;color:#495057;margin-bottom:var(--spacing-xs)}.service-timestamp{font-size:.75rem;color:#6c757d}.outages-section{padding:var(--spacing-md) 0}.outages-section:has(#outages-container:empty){display:none}#outages-container:empty{display:none}.outage-banner{padding:var(--spacing-md);margin-bottom:var(--spacing-sm);border-radius:8px;border-left:4px solid;background-color:var(--umass-white);box-shadow:0 2px 4px #0000001a}.outage-banner.severity-info{border-color:var(--severity-info)}.outage-banner.severity-warning{border-color:var(--severity-warning)}.outage-banner.severity-critical{border-color:var(--severity-critical)}.outage-title{font-size:1.1rem;font-weight:600;margin-bottom:.5rem;color:var(--umass-dark-gray)}.outage-description{font-size:.95rem;color:#495057;margin-bottom:.5rem}.outage-time{font-size:.85rem;color:#6c757d}.status-details-section{background:var(--umass-light-gray);padding:var(--spacing-lg) 0}.status-details-section.success-only{padding:var(--spacing-md) 0}.status-details-section.success-only .status-alert{margin-bottom:0}.status-details-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.status-details-header h2{font-size:1.5rem;color:var(--umass-maroon);margin:0;display:flex;align-items:center;gap:.5rem}.polling-warning{display:inline-flex;align-items:center;justify-content:center;cursor:help}.polling-warning svg{width:20px;height:20px}.polling-warning-degraded{color:var(--status-degraded)}.polling-warning-critical{color:var(--status-offline)}.status-details-count{color:#666;font-size:.95rem}.status-details-table-container{overflow-x:auto;border-radius:8px;box-shadow:0 2px 8px #0000001a}.status-details-table{width:100%;border-collapse:collapse;background:#fff}.status-details-table thead{background:var(--umass-light-gray)}.status-details-table th{padding:var(--spacing-sm) var(--spacing-md);text-align:left;font-weight:600;color:var(--umass-dark-gray);border-bottom:2px solid #dee2e6}.status-details-table th:first-child{width:40px;text-align:center}.status-details-table th:last-child{text-align:right}.status-details-table tbody tr{border-bottom:1px solid #f0f0f0;transition:background .2s}.status-details-table tbody tr:hover{background:var(--umass-light-gray)}.status-details-table td{padding:var(--spacing-sm) var(--spacing-md)}.status-cell-indicator{width:40px;text-align:center}.status-dot{display:inline-block;width:12px;height:12px;border-radius:50%}.status-dot.status-online{background:var(--status-online)}.status-dot.status-degraded{background:var(--status-degraded)}.status-dot.status-offline{background:var(--status-offline)}.status-dot.status-maintenance{background:var(--status-maintenance)}.status-cell-name{font-weight:500;color:var(--umass-dark-gray)}.status-cell-status{text-align:right}.status-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-badge-online{background:#28a7451a;color:var(--status-online)}.status-badge-degraded{background:#ffc1071a;color:#8a6d00}.status-badge-offline{background:#dc35451a;color:var(--status-offline)}.status-badge-maintenance{background:#17a2b81a;color:var(--status-maintenance)}.status-alert{display:flex;align-items:center;gap:12px;padding:16px 20px;border-radius:8px;margin-bottom:var(--spacing-md);font-weight:600;font-size:1.1rem}.status-alert-warning{background:linear-gradient(135deg,#ffc10726,#ff980026);border:1px solid rgba(255,193,7,.4);color:#856404}.status-alert-danger{background:linear-gradient(135deg,#dc354526,#c8233326);border:1px solid rgba(220,53,69,.4);color:#721c24}.status-alert-success{background:linear-gradient(135deg,#28a74526,#20863726);border:1px solid rgba(40,167,69,.4);color:#155724}.status-alert-info{background:linear-gradient(135deg,#17a2b81f,#17a2b814);border:1px solid rgba(23,162,184,.35);color:#0c5460}.mist-outage-info{margin-top:var(--spacing-sm)}.status-alert-icon{display:flex;align-items:center;justify-content:center}.status-alert-icon svg{width:20px;height:20px}.status-alert-message{flex:1}.status-details-controls{display:flex;align-items:center;gap:16px}.status-search-container{position:relative}.status-search-input{padding:8px 12px;border:1px solid #ddd;border-radius:6px;font-size:.95rem;width:200px;transition:border-color .2s,box-shadow .2s}.status-search-input:focus-visible{border-color:var(--umass-maroon);box-shadow:0 0 0 3px #881c1c1a;outline:3px solid var(--umass-maroon);outline-offset:2px}.status-search-input::placeholder{color:#767676}.status-details-empty{padding:40px 20px;text-align:center;color:#666;font-size:1rem;background:var(--umass-light-gray);border-radius:8px}.status-pagination{display:flex;justify-content:space-between;align-items:center;margin-top:var(--spacing-md);padding:var(--spacing-sm) 0}.pagination-info{color:#666;font-size:.9rem}.pagination-controls{display:flex;align-items:center;gap:4px}.pagination-btn{padding:6px 12px;border:1px solid #ddd;background:#fff;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .2s;min-width:36px}.pagination-btn:hover:not(:disabled){background:var(--umass-light-gray);border-color:var(--umass-maroon)}.pagination-btn.active{background:var(--umass-maroon);color:#fff;border-color:var(--umass-maroon)}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-prev,.pagination-next{padding:6px 10px}.pagination-ellipsis{padding:0 8px;color:#999}.map-section{position:relative;margin:var(--spacing-lg) auto;max-width:1400px;padding:0 var(--spacing-md)}.map-heading{text-align:center;color:var(--umass-maroon);font-size:1.25rem;font-weight:600;margin-bottom:var(--spacing-sm)}.map-container{position:relative;width:100%;height:600px;border-radius:8px;box-shadow:0 4px 6px #0000001a;overflow:hidden}.map-legend{position:absolute;top:var(--spacing-md);right:var(--spacing-md);background-color:var(--umass-white);padding:var(--spacing-md);border-radius:8px;box-shadow:0 2px 8px #00000026;z-index:10}.map-legend h3{font-size:1rem;font-weight:600;margin-bottom:var(--spacing-sm);color:var(--umass-maroon)}.legend-item{display:flex;align-items:center;margin-bottom:var(--spacing-xs);font-size:.9rem}.legend-marker{width:16px;height:16px;border-radius:50%;margin-right:var(--spacing-xs);border:2px solid var(--umass-white);box-shadow:0 2px 4px #0003}.legend-marker.status-online{background-color:var(--status-online)}.legend-marker.status-degraded{background-color:var(--status-degraded)}.legend-marker.status-offline{background-color:var(--status-offline)}.legend-marker.status-maintenance{background-color:var(--status-maintenance)}.last-updated{position:absolute;bottom:var(--spacing-md);left:var(--spacing-md);background-color:var(--umass-white);padding:var(--spacing-xs) var(--spacing-md);border-radius:6px;box-shadow:0 2px 4px #0000001a;font-size:.85rem;color:#6c757d;z-index:10}.footer{background-color:var(--umass-maroon);color:var(--umass-white);text-align:center;padding:var(--spacing-lg) 0;margin-top:var(--spacing-xl)}.footer p{font-size:.875rem;opacity:.9}.mapbox-popup-content{padding:var(--spacing-sm);border-radius:6px;box-shadow:0 2px 8px #00000026}.popup-status{font-weight:600;text-transform:capitalize;margin-bottom:var(--spacing-xs)}.popup-updated{font-size:.85rem;color:#6c757d}.loading{opacity:.6;pointer-events:none}@media (max-width: 768px){.header-title{font-size:1.5rem}.summary-grid{grid-template-columns:repeat(2,1fr)}.services-grid{grid-template-columns:1fr}.map-container{height:400px}.map-legend{top:auto;bottom:var(--spacing-md);right:var(--spacing-md);font-size:.85rem;padding:var(--spacing-sm)}.last-updated{font-size:.75rem;padding:.25rem var(--spacing-sm)}.dev-controls-panel{width:100%!important;max-width:none;border-radius:0}.demo-toggle-btn{padding:.25rem .5rem;font-size:.75rem}.demo-active-indicator{font-size:.6rem;padding:.2rem .4rem}}@media (max-width: 480px){.summary-grid{grid-template-columns:1fr}}.dev-controls-panel{position:fixed;top:50px;right:0;width:320px;max-height:calc(100vh - 60px);overflow-y:auto;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:0 0 0 12px;box-shadow:-4px 4px 20px #0000004d;z-index:10000;color:#fff;font-family:var(--font-family);animation:slideDown .2s ease-out}@keyframes slideDown{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.dev-controls-header{background:#0003;padding:12px 16px;display:flex;justify-content:space-between;align-items:center;font-weight:600;font-size:14px;-webkit-user-select:none;user-select:none}.dev-close-btn{background:#fff3;border:none;color:#fff;width:24px;height:24px;border-radius:4px;cursor:pointer;font-weight:700;font-size:16px;line-height:1;transition:background .2s}.dev-close-btn:hover{background:#ffffff4d}.dev-controls-content{padding:16px}.dev-info{font-size:13px;opacity:.9;margin-bottom:16px;line-height:1.4}.dev-section-title{font-size:14px;font-weight:700;color:#fff;margin-top:12px;margin-bottom:8px;padding-bottom:6px;border-bottom:2px solid rgba(255,255,255,.3)}.dev-section-title:first-of-type{margin-top:0}.dev-buttons{display:flex;flex-direction:column;gap:8px}.dev-btn{padding:12px 16px;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;text-align:left;color:#fff}.dev-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003}.dev-btn:active{transform:translateY(0)}.dev-btn-success{background:linear-gradient(135deg,#28a745,#20c997)}.dev-btn-warning{background:linear-gradient(135deg,#ffc107,#ff9800)}.dev-btn-danger{background:linear-gradient(135deg,#dc3545,#c82333)}.dev-btn-critical{background:linear-gradient(135deg,#721c24,#d32f2f)}.dev-btn-maintenance{background:linear-gradient(135deg,#17a2b8,#138496)}.dev-btn-clear{background:linear-gradient(135deg,#6c757d,#5a6268);width:100%}.dev-status{margin-top:12px;padding:8px 12px;border-radius:6px;font-size:13px;text-align:center;min-height:20px}.dev-status-loading{background:#fff3;animation:pulse 1.5s infinite}.dev-status-success{background:#28a7454d}.dev-status-error{background:#dc35454d}.dev-btn-preview{background:linear-gradient(135deg,#6f42c1,#5a32a3);width:100%}.alert-preview-container{margin-bottom:var(--spacing-lg);padding:var(--spacing-md);background:var(--umass-light-gray);border-radius:8px;border:2px dashed #6f42c1}.alert-preview-title{font-size:1rem;color:#6f42c1;margin:0 0 var(--spacing-md) 0;font-weight:600}.alert-preview-container .status-alert{margin-bottom:8px}.alert-preview-container .status-alert:last-child{margin-bottom:0}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.embed-modal-btn{background:#ffffff26;border:1px solid rgba(255,255,255,.3);color:#fff;padding:.35rem .75rem;border-radius:4px;font-size:.8rem;cursor:pointer;transition:all .2s;white-space:nowrap}.embed-modal-btn:hover{background:#ffffff40}.embed-modal-btn:focus-visible{outline:2px solid white;outline-offset:2px}.embed-modal-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:1000;align-items:center;justify-content:center;padding:1rem}.embed-modal-overlay.visible{display:flex}body.modal-open{overflow:hidden}.embed-modal{background:#fff;border-radius:8px;width:100%;max-width:800px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column}.embed-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem .75rem;border-bottom:1px solid var(--border-color);position:sticky;top:0;background:#fff;z-index:1}.embed-modal-title{font-size:1.1rem;font-weight:600;margin:0;color:var(--text-primary)}.embed-modal-close{background:none;border:none;font-size:1.5rem;line-height:1;color:var(--text-secondary);cursor:pointer;padding:.25rem .4rem;border-radius:4px}.embed-modal-close:hover{color:var(--text-primary);background:var(--bg-secondary)}.embed-modal-close:focus-visible{outline:2px solid var(--umass-maroon);outline-offset:2px}.embed-modal-desc{margin:0;padding:.75rem 1.5rem 0;font-size:.875rem;color:var(--text-secondary)}.embed-tabs{display:flex;padding:.75rem 1.5rem 0;border-bottom:1px solid var(--border-color);gap:0;flex-shrink:0}.embed-tab{background:none;border:none;border-bottom:2px solid transparent;padding:.5rem .875rem;font-size:.8rem;font-weight:500;color:var(--text-secondary);cursor:pointer;white-space:nowrap;margin-bottom:-1px;transition:color .15s,border-color .15s}.embed-tab:hover{color:var(--text-primary)}.embed-tab.active{color:var(--umass-maroon);border-bottom-color:var(--umass-maroon)}.embed-tab:focus-visible{outline:2px solid var(--umass-maroon);outline-offset:-2px;border-radius:4px 4px 0 0}.embed-panel{padding:1.25rem 1.5rem 1.5rem}.embed-panel-note{font-size:.8rem;color:#854d0e;background:#fef9c3;border:1px solid #fde047;border-radius:4px;padding:.5rem .75rem;margin:0 0 .75rem}.embed-code-wrap{position:relative}.embed-code{background:#1e1e2e;color:#cdd6f4;border-radius:6px;padding:1rem;font-size:.78rem;line-height:1.6;overflow-x:auto;white-space:pre;margin:0;font-family:Courier New,Courier,monospace}.embed-copy-btn{position:absolute;top:.5rem;right:.5rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.25);color:#cdd6f4;font-size:.75rem;padding:.25rem .6rem;border-radius:4px;cursor:pointer;transition:background .15s}.embed-copy-btn:hover{background:#fff3}.embed-copy-btn.copied{background:#4ade8033;border-color:#4ade8066;color:#86efac}.embed-copy-btn:focus-visible{outline:2px solid white;outline-offset:2px}
