@font-face { font-family: 'FuturaStdHeavy'; src: url('assets/FuturaStdHeavy.otf') format('opentype'); } @font-face { font-family: 'Quartz'; src: url('assets/quartz-ms-regular.ttf') format('truetype'); } body { font-family: 'FuturaStdHeavy', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif; background-color: #221f1f; background-image: url('assets/HaveBlueTransWh.png'); background-repeat: no-repeat; background-position: bottom 20px right 20px; background-attachment: fixed; background-size: 300px; color: #333; margin: 0; padding: 20px; display: flex; justify-content: center; } .container { width: 100%; max-width: 960px; } .header-logo { display: block; margin: 0 auto 20px auto; max-width: 60%; } .grid { display: grid; grid-template-columns: 1fr; gap: 20px; } .card { background: #c5ced6; border-radius: 8px; padding: 20px; box-shadow: 0 2px 4px rgba(0,0,0,0.1); } .card h2 { margin-top: 0; color: #1a7db6; } #ltc-timecode, #system-clock { font-family: 'Quartz', monospace; font-size: 2em; text-align: center; letter-spacing: 2px; } .card p, .card ul { margin: 10px 0; } .system-date-display { text-align: center; font-size: 1.5em; font-family: 'Quartz', monospace; letter-spacing: 2px; } #interfaces { text-align: center; white-space: nowrap; overflow-x: auto; padding-bottom: 5px; /* Add some space for the scrollbar if it appears */ } .full-width { grid-column: 1 / -1; } .control-group { margin-bottom: 15px; display: flex; align-items: center; gap: 10px; } input[type="number"], input[type="text"] { padding: 8px; border: 1px solid #9fb3c8; border-radius: 4px; background-color: #f0f4f8; font-family: inherit; font-size: 14px; color: #333; transition: border-color 0.2s, box-shadow 0.2s; } input[type="number"]:focus, input[type="text"]:focus { outline: none; border-color: #1a7db6; box-shadow: 0 0 0 2px rgba(26, 125, 182, 0.2); } input[type="number"] { width: 80px; } input[type="text"] { width: auto; } button { padding: 8px 15px; border: none; border-radius: 4px; background-color: #1a7db6; color: white; cursor: pointer; font-size: 14px; font-family: inherit; font-weight: bold; transition: background-color 0.2s; } button:hover { background-color: #166999; } .offset-controls-container { display: flex; flex-wrap: wrap; gap: 1.5rem; align-items: center; } .offset-control { display: flex; align-items: center; gap: 5px; } .offset-control input[type="number"] { width: 40px; text-align: center; } .offset-control label { font-size: 14px; color: #333; } #offset-ms { width: 60px; } #sync-message { font-style: italic; color: #555; } .icon-group { display: flex; justify-content: center; align-items: center; gap: 20px; margin: 10px 0; } #delta-text { text-align: center; } #ltc-status, #ntp-active, #sync-status, #jitter-status, #frame-rate, #lock-ratio, #delta-status { display: flex; justify-content: center; align-items: center; } .status-icon { width: 60px; height: 60px; } .collapsible-card { padding: 0; } .collapsible-card .toggle-header { display: flex; align-items: center; gap: 15px; padding: 20px; cursor: pointer; border-radius: 8px; } .collapsible-card .toggle-header.active { border-bottom-left-radius: 0; border-bottom-right-radius: 0; border-bottom: 1px solid #eee; } .collapsible-card .toggle-header:hover { background-color: #e9e9f3; } .toggle-icon { width: 40px; height: 40px; } .header-icon { width: 40px; height: 40px; } .card-header { display: flex; align-items: center; gap: 15px; } .log-box { white-space: pre-wrap; overflow-wrap: break-word; } .collapsible-content { display: none; padding: 20px; } .collapsible-content.active { display: block; } footer { text-align: center; margin-top: 40px; padding-top: 20px; border-top: 1px solid #444; color: #c5ced6; } footer p { margin: 0; } footer a { color: #1a7db6; text-decoration: none; } footer a:hover { text-decoration: underline; } /* Status-specific colors */ #sync-status.in-sync, #jitter-status.good { font-weight: bold; color: #28a745; } #sync-status.clock-ahead, #sync-status.clock-behind, #jitter-status.average { font-weight: bold; color: #ffc107; } #sync-status.timeturning { font-weight: bold; color: #17a2b8; } #jitter-status.bad { font-weight: bold; color: #dc3545; } #ntp-active.active { font-weight: bold; color: #28a745; } #ntp-active.inactive { font-weight: bold; color: #dc3545; } #ltc-status.lock { font-weight: bold; color: #28a745; } #ltc-status.free { font-weight: bold; color: #ffc107; }