@import "https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@100;300;700&display=swap";body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-color);color:var(--text-color);margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;transition:background .25s,color .25s}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}div{box-sizing:border-box}.thumbnails{--card-height:max(calc(var(--site-info-width) * 9 / 16), 220px);flex-wrap:wrap;justify-content:center;gap:20px;padding:10px;display:flex}.summary{width:var(--site-info-width);height:var(--card-height);min-height:var(--card-height);max-height:var(--card-height);--shadow-color:#0032004d;--shadow-color-change:#00320080;--shadow-size:1px;border-radius:5px;flex-direction:column;align-items:center;animation:2s ease-in-out infinite blink;display:flex}.monitor-table-card{cursor:pointer;background:var(--surface-color);box-shadow:var(--shadow-soft);width:calc(var(--site-info-width) * 2 + 20px);min-width:var(--site-info-width);max-width:95vw;height:var(--dynamic-card-height,var(--card-height));min-height:var(--dynamic-card-height,var(--card-height));max-height:var(--dynamic-card-height,var(--card-height));box-sizing:border-box;border-radius:10px;flex-direction:column;align-items:stretch;padding:10px;transition:transform .12s,box-shadow .12s;display:flex;position:relative;overflow:hidden}.monitor-table-card:hover{box-shadow:var(--shadow-strong);transform:translateY(-2px)}.summary img{object-fit:fill;cursor:pointer;border-radius:5px;width:100%;height:100%;transition:transform .1s ease-in-out}.summary img:hover{border-radius:10px 10px 0 0;transform:scaleX(1.015)scaleY(1.015)}.modal{z-index:1000;background-color:#00000080;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:fixed;top:0;left:0}.modal img{max-width:90%;max-height:90%}.monitor-modal-content{background:var(--surface-color);border:1px solid var(--border-color);width:auto;max-width:95vw;max-height:90vh;box-shadow:var(--shadow-strong);border-radius:12px;padding:12px;display:inline-block;overflow:hidden}.monitor-table{width:100%;height:100%;color:var(--text-color);--monitor-title-size:1rem;--monitor-meta-size:1rem;--monitor-cell-size:.8rem;flex-direction:column;gap:8px;font-family:Noto Sans KR,monospace;display:flex}.monitor-table-title{font-weight:800;font-size:var(--monitor-title-size);justify-content:space-between;align-items:center;gap:8px;display:flex}.monitor-table-meta{color:var(--muted-text-color);font-size:var(--monitor-meta-size);align-items:center;gap:6px;display:flex}.monitor-table-wrapper{border:1px solid var(--border-color);background:var(--surface-alt-color);box-sizing:border-box;border-radius:8px;flex:auto;width:100%;max-width:100%;height:100%;min-height:0;max-height:100%;padding:6px 6px 40px;display:block;overflow:auto}.monitor-view-all-btn{color:#fff;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);cursor:pointer;z-index:2;background:linear-gradient(#0000 0%,#00000073 100%);border:none;border-radius:0 0 10px 10px;padding:10px;font-size:.75rem;font-weight:800;transition:background .15s,transform .12s;position:absolute;bottom:0;left:0;right:0}.monitor-view-all-btn:hover{background:#0000008c;transform:translateY(-1px)}.monitor-view-all-btn:active{transform:translateY(0)}.monitor-table.compact .monitor-table-wrapper{max-height:calc(var(--site-info-width) * 1.2)}.monitor-table-columns{align-items:flex-start;gap:10px;width:100%;display:flex}.monitor-table-columns.single{display:block}.monitor-table-section{flex:1;min-width:max-content}.monitor-table table{border-collapse:collapse;width:100%;font-size:var(--monitor-cell-size);min-width:max-content;font-weight:700}.monitor-table th,.monitor-table td{border-bottom:1px solid var(--border-color);text-align:center;white-space:nowrap;padding:2px 6px}.monitor-table th{background:var(--surface-color);z-index:1;position:sticky;top:0}.monitor-table tbody tr:nth-child(2n) td{background:#ffffff05}.monitor-table tbody tr.status-red td{background:#ef44442e}.monitor-table tbody tr.status-orange td{background:#f59e0b33}.monitor-table tbody tr.status-green td{background:#22c55e1f}.monitor-table tbody tr.status-gray td{background:#94a3b81f}.monitor-table-card .monitor-table{--monitor-title-size:clamp(14px, calc(var(--site-info-width) / 30), 30px);--monitor-meta-size:clamp(13px, calc(var(--site-info-width) / 35), 25px);--monitor-cell-size:clamp(12px, calc(var(--site-info-width) / 40), 20px)}.monitor-modal-content .monitor-table{--monitor-title-size:1.1rem;--monitor-meta-size:1.05rem;--monitor-cell-size:.9rem}.monitor-table .site-name{text-align:left;text-overflow:ellipsis;max-width:180px;overflow:hidden}.monitor-empty{text-align:center;color:var(--muted-text-color);padding:20px}.status-light{border:1px solid var(--border-color);aspect-ratio:1;border-radius:50%;justify-content:center;align-items:center;width:14px;height:14px;display:inline-flex;box-shadow:inset 0 0 0 1px #ffffff40}.status-light.status-red{background:#ef4444}.status-light.status-orange{background:#f59e0b}.status-light.status-green{box-shadow:none;background:url(data:image/svg+xml,%3Csvg%20viewBox%3D%220%200%2048%2048%22%20fill%3D%22none%22%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%3E%0A%3Cpath%20d%3D%22M8%2018C16%2010%2032%2010%2040%2018%22%20stroke%3D%22%2322c55e%22%20stroke-width%3D%224%22%20stroke-linecap%3D%22round%22/%3E%0A%3Cpath%20d%3D%22M12%2023C18%2017%2030%2017%2036%2023%22%20stroke%3D%22%2322c55e%22%20stroke-width%3D%224%22%20stroke-linecap%3D%22round%22/%3E%0A%3Cpath%20d%3D%22M16%2028C20%2024%2028%2024%2032%2028%22%20stroke%3D%22%2322c55e%22%20stroke-width%3D%224%22%20stroke-linecap%3D%22round%22/%3E%0A%3Ccircle%20cx%3D%2224%22%20cy%3D%2234%22%20r%3D%223%22%20fill%3D%22%2322c55e%22/%3E%0A%3C/svg%3E) 50%/contain no-repeat;border:none}.status-light.status-gray{background:#94a3b8}.status-light.status-unplugged{box-shadow:none;color:#ef4444;background:url(data:image/svg+xml,%3Csvg%20viewBox%3D%220%200%2048%2048%22%20fill%3D%22none%22%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%3E%0A%3Cpath%20d%3D%22M8%2018C16%2010%2032%2010%2040%2018%22%20stroke%3D%22%23ef4444%22%20stroke-width%3D%224%22%20stroke-linecap%3D%22round%22/%3E%0A%3Cpath%20d%3D%22M12%2023C18%2017%2030%2017%2036%2023%22%20stroke%3D%22%23ef4444%22%20stroke-width%3D%224%22%20stroke-linecap%3D%22round%22/%3E%0A%3Cpath%20d%3D%22M16%2028C20%2024%2028%2024%2032%2028%22%20stroke%3D%22%23ef4444%22%20stroke-width%3D%224%22%20stroke-linecap%3D%22round%22/%3E%0A%3Ccircle%20cx%3D%2224%22%20cy%3D%2234%22%20r%3D%223%22%20fill%3D%22%23ef4444%22/%3E%0A%3Cpath%20d%3D%22M30%2026l12%2012M42%2026l-12%2012%22%20stroke%3D%22%23ef4444%22%20stroke-width%3D%224%22%20stroke-linecap%3D%22round%22/%3E%0A%3C/svg%3E) 50%/contain no-repeat;border:none;width:18px;height:18px;font-size:15px;line-height:1}.remote-pill-table{border:1px solid var(--border-color);border-radius:8px;justify-content:center;align-items:center;min-width:36px;padding:3px 8px;font-size:1rem;font-weight:700;display:inline-flex}.remote-pill-table.remote-on{color:#15803d;background:#22c55e1f;border-color:#22c55e4d}.remote-pill-table.remote-off{color:#b91c1c;background:#ef44441f;border-color:#ef444459}.remote-pill-table.remote-unknown{color:#475569;background:#94a3b824;border-color:#94a3b84d}@media (width<=750px){.thumbnails{justify-content:center}.summary,.monitor-table-card{width:95%;min-width:min(350px,95%);max-width:95%}}@keyframes blink{0%{box-shadow:0px 0px 0px var(--shadow-size) var(--shadow-color)}50%{box-shadow:0px 0px 0px calc(var(--shadow-size) - .5px) var(--shadow-color-change)}to{box-shadow:0px 0px 0px var(--shadow-size) var(--shadow-color)}}.not-operational-time{filter:grayscale(50%);opacity:.5;border-radius:10px}br{content:"";border-top:0;margin-top:0;display:block}.width-current-value{font-size:medium;font-weight:900}.thumbnails-individual.keyboard-focused{outline:3px solid var(--accent-color,#3b82f6);outline-offset:3px;z-index:10;transition:transform .15s,box-shadow .15s,outline .15s;position:relative;transform:scale(1.02);box-shadow:0 0 0 6px #3b82f633}.thumbnails-individual.keyboard-focused .thumb-wrapper{transform:none}@media (prefers-contrast:high){.thumbnails-individual.keyboard-focused{outline-offset:4px;outline:4px solid highlighttext}}*{box-sizing:border-box;letter-spacing:-.02em;margin:0;padding:0;font-family:Noto Sans KR,sans-serif}.app-shell{background:var(--bg-color);min-height:100vh;color:var(--text-color);transition:background .25s,color .25s}.pill-button{border:1px solid var(--border-color);background:var(--surface-alt-color);height:44px;color:var(--text-color);cursor:pointer;box-shadow:var(--shadow-soft);border-radius:999px;align-items:center;gap:10px;padding:10px 14px;font-size:.95rem;font-weight:700;transition:transform .2s,box-shadow .3s,border-color .2s,background-color .25s;display:inline-flex}.pill-button:hover{box-shadow:var(--shadow-strong);border-color:var(--accent-color);transform:translateY(-1px)}.pill-button:active{transform:translateY(0)}.theme-toggle{text-align:left;background:var(--surface-color);justify-content:flex-start;position:static}.mode-indicator{width:auto;height:auto;box-shadow:none;background:0 0;justify-content:center;align-items:center;font-size:1.05rem;line-height:1;display:inline-flex}.mode-copy{flex-direction:column;align-items:flex-start;line-height:1.2;display:flex}.mode-label{font-size:.95rem;font-weight:700}.mode-hint{color:var(--muted-text-color);font-size:.78rem}.ci-background{background-color:var(--header-bg);cursor:pointer;background-image:url(/assets/CI-JsDExnlO.png);background-repeat:no-repeat;background-size:84px 48px;border:none;width:84px;height:48px}.user{background-color:var(--header-bg);min-height:75px;color:var(--header-text);box-shadow:var(--shadow-soft);border-bottom:1px solid var(--border-color);z-index:110;grid-template-columns:auto 1fr auto;align-items:center;column-gap:16px;padding:12px;display:grid;position:sticky;top:0}.header-center{justify-content:center;align-items:center;min-height:44px;display:flex}.control-btns{justify-self:end;gap:12px;margin-right:10px;display:flex}.control-btns .pill-button{background:var(--surface-alt-color);color:var(--text-color)}.control-btns .pill-button:hover{background:var(--surface-color)}.btn-icon{font-size:1.05rem;line-height:1}.btn-label{font-size:inherit;font-weight:inherit}.admin-toggle,.logout-btn{padding:10px 18px}.sort-icon-btn{justify-content:center;width:44px;padding:10px;display:none}.sort-icon{font-size:1.05rem;line-height:1}.admin-toggle{flex-shrink:0;justify-content:center;width:120px}.landing{flex-wrap:wrap;justify-content:center;align-items:center;display:flex}.SingleSite,.AllSites{background-color:var(--surface-color);border:1px solid var(--border-color);width:100%;height:100%;box-shadow:var(--shadow-soft);color:var(--text-color);border-radius:10px;margin-top:10px}.display{color:var(--text-color);scrollbar-gutter:stable;height:100%;padding:0;overflow:auto}.app-shell{background:var(--background-color);flex-direction:column;height:100vh;display:flex;overflow:hidden}.main-content{flex:1;min-height:0;overflow:hidden}@media (width<=1100px){.header-center{align-items:center}.header-center .header-controls{flex-direction:column;gap:10px;height:auto}}@media (width<=1024px){.control-btns{gap:8px}.control-btns .mode-copy,.control-btns .btn-label{display:none}.theme-toggle,.admin-toggle,.logout-btn{justify-content:center;width:44px;padding:10px}}@media (width<=750px){.header-center .header-controls{display:none}.sort-icon-btn{display:inline-flex}}@media (width<=350px){.control-btns{gap:6px}.control-btns .pill-button{box-shadow:none;background:0 0;border:none;width:auto;min-width:0;height:auto;padding:6px}.control-btns .pill-button:hover{background:0 0}.control-btns .btn-icon,.sort-icon{font-size:1rem}.sort-icon-btn{box-shadow:none;background:0 0;border:none;width:auto;min-width:0;height:auto;padding:6px}.pill-button.sort-icon-btn{box-shadow:none;background:0 0;border:none}}.hamburger-menu{margin-right:10px;position:relative}.hamburger-btn{justify-content:center;width:44px;height:44px;padding:10px}.hamburger-icon{font-size:1.2rem;line-height:1}.hamburger-dropdown{background:var(--surface-color);border:1px solid var(--border-color);min-width:160px;box-shadow:var(--shadow-strong);z-index:200;border-radius:12px;flex-direction:column;gap:2px;padding:6px;animation:.15s dropdown-appear;display:flex;position:absolute;top:calc(100% + 8px);right:0}@keyframes dropdown-appear{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.menu-item{width:100%;color:var(--text-color);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:10px;padding:10px 12px;font-size:.9rem;font-weight:600;transition:background .15s;display:flex}.menu-item:hover{background:var(--surface-alt-color)}.menu-item-icon{flex-shrink:0;font-size:1.05rem;line-height:1}.menu-item-label{flex:1}.menu-item-kbd{color:var(--text-muted,#888);background:var(--surface-alt-color);border:1px solid var(--border-color);letter-spacing:0;border-radius:4px;flex-shrink:0;padding:1px 5px;font-family:monospace;font-size:.7rem;font-weight:700}:root{--permission-width:170px}.admin-page{gap:16px;width:100%;max-width:1200px;margin:24px auto;padding:16px;display:grid}.user-approval,.user-permission{margin:0}.permission-layout{grid-template-columns:1fr;gap:16px;display:grid}.admin-card{background:var(--surface-color);border:1px solid var(--border-color);box-shadow:var(--shadow-soft);border-radius:14px;flex-direction:column;gap:14px;padding:18px;display:flex}.card-header{flex-direction:column;gap:6px;display:flex}.card-title{font-size:1.1rem;font-weight:800}.card-subtitle{color:var(--muted-text-color);margin:0;font-size:.95rem}.empty-state{border:1px dashed var(--border-color);text-align:center;color:var(--muted-text-color);background:var(--surface-alt-color);border-radius:12px;padding:16px}.pending-list{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.pending-user{background:var(--surface-alt-color);border:1px solid var(--border-color);border-radius:12px;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;display:flex}.pending-user__info{flex:1;min-width:0}.pending-user__name{font-size:1rem;font-weight:800}.pending-user__code{color:var(--muted-text-color);margin-top:4px}.pending-user__actions{gap:8px;display:flex}.admin-btn{border:1px solid var(--border-color);background:var(--surface-alt-color);color:var(--text-color);cursor:pointer;border-radius:10px;padding:10px 14px;font-size:.95rem;font-weight:700;line-height:1.1;transition:transform .1s,box-shadow .2s,background-color .2s,border-color .2s}.admin-btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.admin-btn:hover{box-shadow:var(--shadow-soft);transform:translateY(-1px)}.admin-btn.primary{background:var(--accent-color);border-color:var(--accent-color);color:var(--accent-text-color);box-shadow:0 10px 30px #3b82f640}.admin-btn.primary:hover{background:var(--accent-hover)}.admin-btn.ghost{color:var(--text-color);background:0 0}.admin-btn.danger{color:#b91c1c;background:#ef44441f;border-color:#ef444473}.field-label{font-size:.95rem;font-weight:700}.field{gap:10px;display:flex}.user-picker{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;display:grid}.user-chip{border:1px solid var(--border-color);background:var(--surface-alt-color);color:var(--text-color);cursor:pointer;text-align:left;border-radius:10px;flex-direction:column;align-items:flex-start;gap:4px;padding:10px 12px;transition:transform 80ms,box-shadow .2s,border-color .2s,background-color .2s;display:flex}.user-chip:hover{box-shadow:var(--shadow-soft);transform:translateY(-1px)}.user-chip.selected{border-color:var(--accent-color);background:var(--accent-glow);color:var(--accent-text-color)}.user-chip__name{font-weight:800}.user-chip__code{opacity:.8;font-size:.9rem}.permission-panel{flex-direction:column;gap:12px;margin-top:6px;display:flex}.permission-userinfo{background:var(--surface-alt-color);border:1px solid var(--border-color);border-radius:10px;align-items:center;gap:8px;width:fit-content;padding:8px 10px;display:inline-flex}.chip-label{color:var(--muted-text-color);font-weight:700}.permission-toolbar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:8px;display:flex}.toolbar-actions{flex-wrap:wrap;gap:8px;display:flex}.permission-toolbar .legend{justify-content:flex-end;min-width:220px;margin-left:auto}.legend{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.legend-item{color:var(--text-color);align-items:center;gap:6px;font-size:.95rem;font-weight:700;line-height:1.1;display:inline-flex}.legend-chip{border:1px solid var(--border-color);border-radius:6px;justify-content:center;align-items:center;width:18px;height:18px;display:inline-flex}.legend-chip.permitted{background:#22c55e24;border-color:#22c55e59}.legend-chip.non-permitted{background:var(--surface-alt-color)}.legend-text{color:var(--text-color);font-size:.95rem;font-weight:700;line-height:1.1}.permission-site-container{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px;display:grid}.permission-site{cursor:pointer;border:1px solid var(--border-color);background:var(--surface-alt-color);text-align:center;text-align:center;border-radius:10px;justify-content:center;align-items:center;min-height:64px;padding:12px;font-size:.95rem;font-weight:700;line-height:1.3;transition:transform 80ms,box-shadow .2s,border-color .2s,background-color .2s;display:flex}.permission-site:hover{box-shadow:var(--shadow-soft);transform:translateY(-1px)}.permission-site.selected{color:#15803d;background:#22c55e24;border-color:#22c55e73}.permission-site.non-selected{color:var(--text-color)}.permission-site__label{-webkit-line-clamp:2;text-overflow:ellipsis;word-break:keep-all;-webkit-box-orient:vertical;line-height:1.2;display:-webkit-box;overflow:hidden}.permission-site.long .permission-site__label{font-size:.9rem}.permission-site.xlong .permission-site__label{font-size:.85rem}.user-state-container{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:10px;display:grid}.user-state{border:1px solid var(--border-color);background:var(--surface-alt-color);border-radius:12px;flex-direction:column;gap:6px;padding:12px;display:flex}.user-state.activated{border-color:#22c55e59;box-shadow:0 10px 24px #22c55e1f}.user-state.deactivated{border-color:#94a3b859}.user-state-status{font-weight:800}.user-state-text{color:var(--muted-text-color)}.user-state-actions{flex-wrap:wrap;gap:8px;margin-top:6px;display:flex}.admin-modal{z-index:1200;background-color:#00000059;justify-content:center;align-items:center;width:100%;height:100%;padding:12px;display:flex;position:fixed;top:0;left:0}.admin-modal__content{background:var(--surface-color);color:var(--text-color);border:1px solid var(--border-color);box-shadow:var(--shadow-strong);border-radius:12px;width:min(90vw,460px);min-width:280px;max-width:460px;padding:18px}.modal-title{margin-bottom:6px;font-weight:800}.modal-body{margin-bottom:10px}.modal-subject{margin-top:8px;font-weight:700}.site-header-card{background:var(--surface-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);border:1px solid var(--border-color);box-sizing:border-box;flex-direction:column;gap:8px;width:100%;max-height:calc(60vh - 20px);padding:12px;display:flex;overflow:hidden}.nearby-sites{flex-direction:column;flex:1;gap:4px;display:flex;overflow:hidden}.prev-sites{justify-content:flex-end}.nearby-site-btn{color:var(--muted-text-color);cursor:pointer;text-align:center;border-radius:var(--radius-sm);white-space:nowrap;text-overflow:ellipsis;background:0 0;border:none;padding:6px 8px;font-size:.8rem;transition:all .2s;overflow:hidden}.nearby-site-btn:hover{background:var(--surface-alt-color);color:var(--text-color);opacity:1!important}.current-site{background:var(--accent-color);border-radius:var(--radius-md);flex-direction:column;flex-shrink:0;align-items:center;gap:4px;padding:12px 8px;display:flex}.site-name{color:var(--accent-text-color);text-align:center;word-break:keep-all;margin:0;font-size:.95rem;font-weight:800}.site-position{color:var(--accent-text-color);opacity:.8;font-size:.7rem;font-weight:600}.view-mode-section{border-top:1px solid var(--border-color);flex-shrink:0;padding-top:8px}.view-mode-segment{background:var(--surface-alt-color);border-radius:var(--radius-md);border:1px solid var(--border-color);flex-direction:column;padding:4px;display:flex}.segment-btn{color:var(--muted-text-color);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;justify-content:center;align-items:center;gap:6px;padding:8px 10px;font-size:.8rem;font-weight:600;transition:all .2s;display:flex}.segment-btn.active{background:var(--accent-color);color:var(--accent-text-color)}.segment-btn:hover:not(.active){color:var(--text-color)}.segment-icon{font-size:.9rem;font-style:normal;line-height:1}.segment-icon.icon-all:before{content:"▣"}.segment-icon.icon-photo:before{content:"📷"}.segment-icon.icon-video:before{content:"🎥"}.segment-label{font-size:inherit}@media (width<=900px){.site-header-card{flex-flow:wrap;justify-content:center;align-items:center;gap:12px;max-height:none}.nearby-sites{display:none}.current-site{flex-direction:row;gap:8px;padding:8px 16px}.view-mode-section{border-top:none;flex:1;padding-top:0}.view-mode-segment{flex-direction:row}.segment-btn{flex:1}}.media-card{background:var(--surface-color);border-radius:var(--radius-md);box-shadow:var(--shadow-soft);border:1px solid var(--border-color);flex-direction:column;display:flex;overflow:hidden}.media-card.loading{opacity:.7;pointer-events:none}.media-card-header{background:var(--surface-alt-color);border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:8px 16px;display:flex}.media-card-title{color:var(--text-color);align-items:center;gap:8px;margin:0;font-size:1rem;font-weight:700;display:flex}.media-card-info{color:var(--muted-text-color);font-size:.85rem;font-weight:600}.card-icon{justify-content:center;align-items:center;width:20px;height:20px;font-size:1rem;display:inline-flex}.card-icon.icon-photo:before{content:"photo";font-size:0}.card-icon.icon-video:before{content:"video";font-size:0}.media-card-body{flex-direction:column;flex:1;gap:12px;padding:12px;display:flex}.media-card.photo .media-card-header{border-left:3px solid var(--accent-color)}.media-card.video .media-card-header{border-left:3px solid var(--color-highlight-600)}@media (width<=768px){.media-card-header{padding:10px 16px}.media-card-body{gap:12px;padding:16px}.media-card-title{font-size:.95rem}}.react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view--down-arrow,.react-datepicker__navigation-icon:before{content:"";border:3px solid #ccc;border-width:3px 3px 0 0;width:9px;height:9px;display:block;position:absolute;top:6px}.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle,.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle{width:0;margin-left:-4px;position:absolute}.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle:before,.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle:before,.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle:after,.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle:after{box-sizing:content-box;content:"";z-index:-1;border:8px solid #0000;width:1px;height:0;position:absolute;left:-8px}.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle:before,.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle:before{border-bottom-color:#aeaeae}.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle{margin-top:-8px;top:0}.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle:before,.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle:after{border-top:none;border-bottom-color:#f0f0f0}.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle:after{top:0}.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle:before{border-bottom-color:#aeaeae;top:-1px}.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle{margin-bottom:-8px;bottom:0}.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle:before,.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle:after{border-top-color:#fff;border-bottom:none}.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle:after{bottom:0}.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle:before{border-top-color:#aeaeae;bottom:-1px}.react-datepicker-wrapper{border:0;padding:0;display:inline-block}.react-datepicker{color:#000;background-color:#fff;border:1px solid #aeaeae;border-radius:.3rem;font-family:Helvetica Neue,helvetica,arial,sans-serif;font-size:.8rem;display:inline-block;position:relative}.react-datepicker--time-only .react-datepicker__triangle{left:35px}.react-datepicker--time-only .react-datepicker__time-container{border-left:0}.react-datepicker--time-only .react-datepicker__time,.react-datepicker--time-only .react-datepicker__time-box{border-bottom-right-radius:.3rem;border-bottom-left-radius:.3rem}.react-datepicker__triangle{position:absolute;left:50px}.react-datepicker-popper{z-index:1}.react-datepicker-popper[data-placement^=bottom]{padding-top:10px}.react-datepicker-popper[data-placement=bottom-end] .react-datepicker__triangle,.react-datepicker-popper[data-placement=top-end] .react-datepicker__triangle{left:auto;right:50px}.react-datepicker-popper[data-placement^=top]{padding-bottom:10px}.react-datepicker-popper[data-placement^=right]{padding-left:8px}.react-datepicker-popper[data-placement^=right] .react-datepicker__triangle{left:auto;right:42px}.react-datepicker-popper[data-placement^=left]{padding-right:8px}.react-datepicker-popper[data-placement^=left] .react-datepicker__triangle{left:42px;right:auto}.react-datepicker__header{text-align:center;background-color:#f0f0f0;border-bottom:1px solid #aeaeae;border-top-left-radius:.3rem;padding:8px 0;position:relative}.react-datepicker__header--time{padding-bottom:8px;padding-left:5px;padding-right:5px}.react-datepicker__header--time:not(.react-datepicker__header--time--only){border-top-left-radius:0}.react-datepicker__header:not(.react-datepicker__header--has-time-select){border-top-right-radius:.3rem}.react-datepicker__year-dropdown-container--select,.react-datepicker__month-dropdown-container--select,.react-datepicker__month-year-dropdown-container--select,.react-datepicker__year-dropdown-container--scroll,.react-datepicker__month-dropdown-container--scroll,.react-datepicker__month-year-dropdown-container--scroll{margin:0 15px;display:inline-block}.react-datepicker__current-month,.react-datepicker-time__header,.react-datepicker-year-header{color:#000;margin-top:0;font-size:.944rem;font-weight:700}.react-datepicker-time__header{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.react-datepicker__navigation{text-align:center;cursor:pointer;z-index:1;text-indent:-999em;background:0 0;border:none;justify-content:center;align-items:center;width:32px;height:32px;padding:0;display:flex;position:absolute;top:2px;overflow:hidden}.react-datepicker__navigation--next--with-time:not(.react-datepicker__navigation--next--with-today-button){right:85px}.react-datepicker__navigation--years{margin-left:auto;margin-right:auto;display:block;position:relative;top:0}.react-datepicker__navigation--years-previous{top:4px}.react-datepicker__navigation--years-upcoming{top:-4px}.react-datepicker__navigation:hover :before{border-color:#a6a6a6}.react-datepicker__navigation-icon{width:0;font-size:20px;position:relative;top:-1px}.react-datepicker__navigation-icon--next{left:-2px}.react-datepicker__navigation-icon--next:before{left:-7px;transform:rotate(45deg)}.react-datepicker__navigation-icon--previous{right:-2px}.react-datepicker__navigation-icon--previous:before{right:-7px;transform:rotate(225deg)}.react-datepicker__year{text-align:center;margin:.4rem}.react-datepicker__year-wrapper{flex-wrap:wrap;max-width:180px;display:flex}.react-datepicker__year .react-datepicker__year-text{width:4rem;margin:2px;display:inline-block}.react-datepicker__month{text-align:center;margin:.4rem}.react-datepicker__month .react-datepicker__month-text,.react-datepicker__month .react-datepicker__quarter-text{width:4rem;margin:2px;display:inline-block}.react-datepicker__input-time-container{clear:both;float:left;text-align:left;width:100%;margin:5px 0 10px 15px}.react-datepicker__input-time-container .react-datepicker-time__caption,.react-datepicker__input-time-container .react-datepicker-time__input-container{display:inline-block}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input{margin-left:10px;display:inline-block}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input{width:auto}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]{-moz-appearance:textfield}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__delimiter{margin-left:5px;display:inline-block}.react-datepicker__time-container{float:right;border-left:1px solid #aeaeae;width:85px}.react-datepicker__time-container--with-today-button{border:1px solid #aeaeae;border-radius:.3rem;display:inline;position:absolute;top:0;right:-87px}.react-datepicker__time-container .react-datepicker__time{background:#fff;border-bottom-right-radius:.3rem;position:relative}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box{text-align:center;border-bottom-right-radius:.3rem;width:85px;margin:0 auto;overflow-x:hidden}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list{box-sizing:content-box;width:100%;height:calc(195px + .85rem);margin:0;padding-left:0;padding-right:0;list-style:none;overflow-y:scroll}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item{white-space:nowrap;height:30px;padding:5px 10px}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item:hover{cursor:pointer;background-color:#f0f0f0}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected{color:#fff;background-color:#216ba5;font-weight:700}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected:hover{background-color:#216ba5}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--disabled{color:#ccc}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--disabled:hover{cursor:default;background-color:#0000}.react-datepicker__week-number{color:#ccc;text-align:center;width:1.7rem;margin:.166rem;line-height:1.7rem;display:inline-block}.react-datepicker__week-number.react-datepicker__week-number--clickable{cursor:pointer}.react-datepicker__week-number.react-datepicker__week-number--clickable:hover{background-color:#f0f0f0;border-radius:.3rem}.react-datepicker__day-names,.react-datepicker__week{white-space:nowrap}.react-datepicker__day-names{margin-bottom:-8px}.react-datepicker__day-name,.react-datepicker__day,.react-datepicker__time-name{color:#000;text-align:center;width:1.7rem;margin:.166rem;line-height:1.7rem;display:inline-block}.react-datepicker__day,.react-datepicker__month-text,.react-datepicker__quarter-text,.react-datepicker__year-text{cursor:pointer}.react-datepicker__day:hover,.react-datepicker__month-text:hover,.react-datepicker__quarter-text:hover,.react-datepicker__year-text:hover{background-color:#f0f0f0;border-radius:.3rem}.react-datepicker__day--today,.react-datepicker__month-text--today,.react-datepicker__quarter-text--today,.react-datepicker__year-text--today{font-weight:700}.react-datepicker__day--highlighted,.react-datepicker__month-text--highlighted,.react-datepicker__quarter-text--highlighted,.react-datepicker__year-text--highlighted{color:#fff;background-color:#3dcc4a;border-radius:.3rem}.react-datepicker__day--highlighted:hover,.react-datepicker__month-text--highlighted:hover,.react-datepicker__quarter-text--highlighted:hover,.react-datepicker__year-text--highlighted:hover{background-color:#32be3f}.react-datepicker__day--highlighted-custom-1,.react-datepicker__month-text--highlighted-custom-1,.react-datepicker__quarter-text--highlighted-custom-1,.react-datepicker__year-text--highlighted-custom-1{color:#f0f}.react-datepicker__day--highlighted-custom-2,.react-datepicker__month-text--highlighted-custom-2,.react-datepicker__quarter-text--highlighted-custom-2,.react-datepicker__year-text--highlighted-custom-2{color:green}.react-datepicker__day--selected,.react-datepicker__day--in-selecting-range,.react-datepicker__day--in-range,.react-datepicker__month-text--selected,.react-datepicker__month-text--in-selecting-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--selected,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--selected,.react-datepicker__year-text--in-selecting-range,.react-datepicker__year-text--in-range{color:#fff;background-color:#216ba5;border-radius:.3rem}.react-datepicker__day--selected:hover,.react-datepicker__day--in-selecting-range:hover,.react-datepicker__day--in-range:hover,.react-datepicker__month-text--selected:hover,.react-datepicker__month-text--in-selecting-range:hover,.react-datepicker__month-text--in-range:hover,.react-datepicker__quarter-text--selected:hover,.react-datepicker__quarter-text--in-selecting-range:hover,.react-datepicker__quarter-text--in-range:hover,.react-datepicker__year-text--selected:hover,.react-datepicker__year-text--in-selecting-range:hover,.react-datepicker__year-text--in-range:hover{background-color:#1d5d90}.react-datepicker__day--keyboard-selected,.react-datepicker__month-text--keyboard-selected,.react-datepicker__quarter-text--keyboard-selected,.react-datepicker__year-text--keyboard-selected{color:#000;background-color:#bad9f1;border-radius:.3rem}.react-datepicker__day--keyboard-selected:hover,.react-datepicker__month-text--keyboard-selected:hover,.react-datepicker__quarter-text--keyboard-selected:hover,.react-datepicker__year-text--keyboard-selected:hover{background-color:#1d5d90}.react-datepicker__day--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__month-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__quarter-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__year-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range){background-color:#216ba580}.react-datepicker__month--selecting-range .react-datepicker__day--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__day--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__month-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__month-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__quarter-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__quarter-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__year-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__year-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range){color:#000;background-color:#f0f0f0}.react-datepicker__day--disabled,.react-datepicker__month-text--disabled,.react-datepicker__quarter-text--disabled,.react-datepicker__year-text--disabled{cursor:default;color:#ccc}.react-datepicker__day--disabled:hover,.react-datepicker__month-text--disabled:hover,.react-datepicker__quarter-text--disabled:hover,.react-datepicker__year-text--disabled:hover{background-color:#0000}.react-datepicker__input-container{width:100%;display:inline-block;position:relative}.react-datepicker__input-container .react-datepicker__calendar-icon{padding:.5rem;position:absolute}.react-datepicker__view-calendar-icon input{padding:6px 10px 5px 25px}.react-datepicker__year-read-view,.react-datepicker__month-read-view,.react-datepicker__month-year-read-view{border:1px solid #0000;border-radius:.3rem;position:relative}.react-datepicker__year-read-view:hover,.react-datepicker__month-read-view:hover,.react-datepicker__month-year-read-view:hover{cursor:pointer}.react-datepicker__year-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__year-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__month-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__month-year-read-view:hover .react-datepicker__month-read-view--down-arrow{border-top-color:#b3b3b3}.react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view--down-arrow{top:0;right:-16px;transform:rotate(135deg)}.react-datepicker__year-dropdown,.react-datepicker__month-dropdown,.react-datepicker__month-year-dropdown{z-index:1;text-align:center;background-color:#f0f0f0;border:1px solid #aeaeae;border-radius:.3rem;width:50%;position:absolute;top:30px;left:25%}.react-datepicker__year-dropdown:hover,.react-datepicker__month-dropdown:hover,.react-datepicker__month-year-dropdown:hover{cursor:pointer}.react-datepicker__year-dropdown--scrollable,.react-datepicker__month-dropdown--scrollable,.react-datepicker__month-year-dropdown--scrollable{height:150px;overflow-y:scroll}.react-datepicker__year-option,.react-datepicker__month-option,.react-datepicker__month-year-option{width:100%;margin-left:auto;margin-right:auto;line-height:20px;display:block}.react-datepicker__year-option:first-of-type,.react-datepicker__month-option:first-of-type,.react-datepicker__month-year-option:first-of-type{border-top-left-radius:.3rem;border-top-right-radius:.3rem}.react-datepicker__year-option:last-of-type,.react-datepicker__month-option:last-of-type,.react-datepicker__month-year-option:last-of-type{-webkit-user-select:none;user-select:none;border-bottom-right-radius:.3rem;border-bottom-left-radius:.3rem}.react-datepicker__year-option:hover,.react-datepicker__month-option:hover,.react-datepicker__month-year-option:hover{background-color:#ccc}.react-datepicker__year-option:hover .react-datepicker__navigation--years-upcoming,.react-datepicker__month-option:hover .react-datepicker__navigation--years-upcoming,.react-datepicker__month-year-option:hover .react-datepicker__navigation--years-upcoming{border-bottom-color:#b3b3b3}.react-datepicker__year-option:hover .react-datepicker__navigation--years-previous,.react-datepicker__month-option:hover .react-datepicker__navigation--years-previous,.react-datepicker__month-year-option:hover .react-datepicker__navigation--years-previous{border-top-color:#b3b3b3}.react-datepicker__year-option--selected,.react-datepicker__month-option--selected,.react-datepicker__month-year-option--selected{position:absolute;left:15px}.react-datepicker__close-icon{cursor:pointer;vertical-align:middle;background-color:#0000;border:0;outline:0;height:100%;padding:0 6px 0 0;display:table-cell;position:absolute;top:0;right:0}.react-datepicker__close-icon:after{cursor:pointer;color:#fff;text-align:center;vertical-align:middle;content:"×";background-color:#216ba5;border-radius:50%;width:16px;height:16px;padding:2px;font-size:12px;line-height:1;display:table-cell}.react-datepicker__today-button{cursor:pointer;text-align:center;clear:left;background:#f0f0f0;border-top:1px solid #aeaeae;padding:5px 0;font-weight:700}.react-datepicker__portal{z-index:2147483647;background-color:#000c;justify-content:center;align-items:center;width:100vw;height:100vh;display:flex;position:fixed;top:0;left:0}.react-datepicker__portal .react-datepicker__day-name,.react-datepicker__portal .react-datepicker__day,.react-datepicker__portal .react-datepicker__time-name{width:3rem;line-height:3rem}@media (width<=400px),(height<=550px){.react-datepicker__portal .react-datepicker__day-name,.react-datepicker__portal .react-datepicker__day,.react-datepicker__portal .react-datepicker__time-name{width:2rem;line-height:2rem}}.react-datepicker__portal .react-datepicker__current-month,.react-datepicker__portal .react-datepicker-time__header{font-size:1.44rem}.react-datepicker__children-container{width:13.8rem;height:auto;margin:.4rem;padding-left:.2rem;padding-right:.2rem}.react-datepicker__aria-live{clip-path:circle(0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.react-datepicker__calendar-icon{vertical-align:-.125em;width:1em;height:1em}.react-datepicker__triangle,.react-datepicker-popper__triangle,[class*=react-datepicker__triangle]{visibility:hidden!important;opacity:0!important;border:none!important;width:0!important;height:0!important;display:none!important;position:absolute!important;top:-9999px!important;left:-9999px!important}.react-datepicker:before,.react-datepicker:after{content:none!important;border:none!important;display:none!important}.react-datepicker{gap:8px;background-color:var(--surface-color)!important;color:var(--text-color)!important;border-radius:var(--radius-md)!important;box-shadow:none!important;border:none!important;margin:0 auto!important;padding:0!important;font-family:inherit!important;display:flex!important}.react-datepicker__month-container{float:none!important}.react-datepicker__header{position:relative;background-color:var(--surface-alt-color)!important;border-top-left-radius:var(--radius-md)!important;border-top-right-radius:var(--radius-md)!important;border-bottom:none!important;padding:6px 4px 2px!important}.react-datepicker__navigation{background:0 0!important;border:none!important;font-size:1.7rem!important;line-height:1.7rem!important;top:10px!important}.react-datepicker__navigation--previous{left:10px!important}.react-datepicker__navigation--next{right:10px!important}.react-datepicker__navigation-icon:before{border-color:var(--text-color)!important;border-width:1px 1px 0 0!important;width:10px!important;height:10px!important;top:0!important}.react-datepicker__navigation--previous .react-datepicker__navigation-icon:before{transform:rotate(225deg)!important}.react-datepicker__navigation--next .react-datepicker__navigation-icon:before{transform:rotate(45deg)!important}.react-datepicker__month-dropdown-container,.react-datepicker__year-dropdown-container{display:inline-block}.react-datepicker__month-read-view,.react-datepicker__year-read-view{cursor:pointer;color:var(--text-color)}.react-datepicker__month-read-view--selected,.react-datepicker__year-read-view--selected{color:var(--text-color)!important}.react-datepicker__month-dropdown,.react-datepicker__year-dropdown{box-shadow:var(--shadow-soft);border-color:var(--border-color)!important;background-color:var(--surface-color)!important;color:var(--text-color)!important}.react-datepicker__month-option,.react-datepicker__year-option{color:var(--text-color)!important}.react-datepicker__month-option:hover,.react-datepicker__year-option:hover{background-color:var(--surface-alt-color)!important}.react-datepicker__month-option--selected_month{background-color:var(--accent-color)!important;color:var(--accent-text-color)!important}.react-datepicker__day-names{margin:0!important;padding:0!important}.react-datepicker__day-name{width:26px!important;height:22px!important;color:var(--muted-text-color)!important;margin:1px!important;padding:0!important;font-size:.75rem!important;line-height:22px!important}.react-datepicker__day,.react-datepicker__month-text,.react-datepicker__quarter-text,.react-datepicker__year-text{border-radius:var(--radius-sm)!important;width:26px!important;height:26px!important;margin:1px!important;padding:0!important;font-size:.8rem!important;line-height:26px!important}.react-datepicker__week{height:28px!important;margin:0!important;padding:0!important;display:flex!important}.react-datepicker__month{margin:0!important;padding:4px!important}.react-datepicker__day{color:var(--text-color)!important}.react-datepicker__day:hover{background-color:var(--surface-alt-color)!important}.react-datepicker__day--selected,.react-datepicker__day--keyboard-selected{background-color:var(--accent-color)!important;color:var(--accent-text-color)!important}.react-datepicker__day--disabled{opacity:.3;color:var(--muted-text-color)!important}.react-datepicker__day--outside-month.react-datepicker__day--selected,.react-datepicker__day--outside-month.react-datepicker__day--keyboard-selected{opacity:.3;color:var(--muted-text-color)!important;background-color:#0000!important}.dp-overflow-selected.react-datepicker__day--selected{color:var(--text-color)!important;background-color:#0000!important}.timeline-selector{background:var(--surface-alt-color);border-radius:var(--radius-md);flex-direction:column;gap:12px;padding:12px;transition:opacity .2s;display:flex}.timeline-selector.loading{opacity:.6;pointer-events:none}.selector-layout{flex-flow:wrap;justify-content:center;align-items:flex-start;gap:16px;display:flex}.calendar-section{flex-direction:column;flex-shrink:0;justify-content:flex-start;align-items:center;display:flex}.custom-datepicker-header{justify-content:center;align-items:center;gap:8px;margin:0;padding:0;display:flex}.header-text{color:var(--text-color);white-space:nowrap;font-size:.85rem;font-weight:600;display:none}.header-dropdowns{display:flex}.header-selected-date{color:var(--accent-color);white-space:nowrap;font-size:.85rem;font-weight:600}.custom-nav-btn{cursor:pointer;color:var(--text-color);background:0 0;border:none;padding:2px 4px;font-size:1.2rem;line-height:1;transition:color .2s}.custom-nav-btn:hover:not(:disabled){color:var(--accent-color)}.custom-nav-btn:disabled{opacity:.3;cursor:not-allowed}.month-year-selects{align-items:center;gap:6px;display:flex}.header-label,.grid-label{color:var(--text-color);white-space:nowrap;font-size:.9rem;font-weight:600}.custom-header-select{background:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-color);cursor:pointer;appearance:none;padding:4px 6px;font-size:.85rem}.controls-section{flex-direction:column;flex:1;gap:12px;display:flex}.time-selection-group,.nav-controls{width:100%}.time-selection-group{flex-direction:column;flex:1;gap:8px;display:flex}.time-lists-container{flex-direction:column;gap:12px;display:flex}.time-grid-wrapper{flex-direction:column;gap:4px;display:flex}.time-grid{background:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-sm);grid-template-columns:repeat(auto-fill,minmax(30px,1fr));gap:4px;max-height:100px;padding:4px;display:grid;overflow-y:auto}.time-grid.minutes{grid-template-columns:repeat(auto-fill,minmax(30px,1fr));max-height:91px}.time-grid-item{background:var(--surface-alt-color);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-color);cursor:pointer;text-align:center;white-space:nowrap;padding:4px 2px;font-size:.75rem;transition:all .15s}.time-grid-item:hover{background:var(--surface-color);border-color:var(--accent-color)}.time-grid-item.selected{background:var(--accent-color);color:var(--accent-text-color);border-color:var(--accent-color);font-weight:700}.selection-summary{border-top:1px solid var(--border-color);justify-content:center;padding-top:8px;font-size:.8rem;display:flex}.summary-count{color:var(--muted-text-color)}@media (width<=768px){.selector-layout{flex-direction:column;align-items:center;gap:16px}.time-selection-group{width:100%}}@media (width<=750px){.selector-layout{flex-direction:row;align-items:flex-start;gap:12px}.calendar-section{flex:none}.controls-section{flex:1;min-width:0}.time-lists-container{gap:8px}.grid-label{font-size:.8rem}}.photo-viewer{background:var(--surface-alt-color);border-radius:var(--radius-md);justify-content:center;align-items:center;width:100%;margin:0 auto;display:flex;position:relative}.photo-viewer.loading{pointer-events:none;min-height:200px}.photo-image-wrapper{justify-content:center;align-items:center;width:100%;display:flex}.photo-image{object-fit:contain;border-radius:12px;max-width:100%;max-height:60vh;transition:opacity .3s}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=768px){.photo-viewer{min-height:180px}.spinner{width:32px;height:32px}.empty-icon{font-size:2.5rem}}.video-viewer{background:var(--surface-alt-color);border-radius:var(--radius-md);justify-content:center;align-items:center;width:100%;margin:0 auto;display:flex;position:relative}.video-viewer.loading{pointer-events:none;min-height:200px}.video-player-wrapper{justify-content:center;align-items:center;width:100%;display:flex}.video-player{border-radius:12px;max-width:100%;max-height:60vh}.viewer-loading{color:var(--muted-text-color);flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}.spinner{border:3px solid var(--border-color);border-top-color:var(--accent-color);border-radius:50%;width:40px;height:40px;animation:1s linear infinite spin}.loading-text{font-size:.9rem;font-weight:600}.viewer-empty{color:var(--muted-text-color);flex-direction:column;justify-content:center;align-items:center;gap:12px;display:flex}.empty-icon{opacity:.5;font-size:3rem}.empty-text{font-size:.9rem;font-weight:600}@media (width<=768px){.video-viewer{min-height:180px}.spinner{width:32px;height:32px}.empty-icon{font-size:2.5rem}}:root{--image-video-height:35vh;--image-video-height-single:calc(65vh - 80px);--image-video-height-both-horizontal:calc(60vh - 80px);--image-video-height-both-vertical:calc(32vh - 40px)}.single-site-page{gap:var(--space-sm);padding:var(--space-sm);flex-direction:column;max-width:1600px;min-height:auto;margin:0 auto;display:flex;position:relative}.main-layout{gap:var(--space-md);flex-direction:row;align-items:flex-start;display:flex}.sidebar{top:var(--space-sm);flex:0 0 200px;max-height:60vh;margin-right:15px;position:sticky}.media-content{gap:var(--space-sm);flex:1;display:grid}.media-content[data-mode=both]{--image-video-height:var(--image-video-height-both-horizontal);grid-template-columns:1fr 1fr}.media-content[data-mode=photo],.media-content[data-mode=video]{--image-video-height:var(--image-video-height-single);grid-template-columns:1fr}.media-content[data-mode=photo] .media-card-body,.media-content[data-mode=video] .media-card-body{flex-direction:row;align-items:flex-start;gap:24px}.media-content[data-mode=photo] .timeline-selector,.media-content[data-mode=video] .timeline-selector{flex:none;max-width:fit-content}.media-content[data-mode=photo] .selector-layout,.media-content[data-mode=video] .selector-layout{flex-direction:column;align-items:stretch}.media-content[data-mode=photo] .time-dropdowns,.media-content[data-mode=video] .time-dropdowns{flex-direction:column}.media-content[data-mode=video] .react-datepicker__month-container{margin-bottom:16px;float:none!important;width:100%!important;display:block!important}.media-content[data-mode=video] .react-datepicker{flex-direction:column;align-items:center;width:100%!important;display:flex!important}.floating-site-nav{cursor:pointer;z-index:100;opacity:.3;background:0 0;border:none;justify-content:center;align-items:center;width:60px;height:100px;padding:0;transition:opacity .3s,transform .2s;display:flex;position:fixed;top:50%;transform:translateY(-50%)}.floating-site-nav:hover{opacity:.9;transform:translateY(-50%)scale(1.1)}.floating-site-nav.prev{left:20px}.floating-site-nav.next{right:20px}.nav-triangle{filter:drop-shadow(0 2px 4px #0000004d);border-style:solid;width:0;height:0}.nav-triangle.left{border-width:15px 20px 15px 0;border-color:transparent var(--text-color) transparent transparent}.nav-triangle.right{border-width:15px 0 15px 20px;border-color:transparent transparent transparent var(--text-color)}.floating-buttons{z-index:100;flex-direction:column;gap:8px;display:flex;position:fixed;top:90px;left:20px}.floating-back-btn,.floating-help-btn{background:var(--surface-color);border:1px solid var(--border-color);cursor:pointer;width:44px;height:44px;color:var(--text-color);opacity:.6;border-radius:50%;justify-content:center;align-items:center;font-size:1.4rem;transition:all .2s;display:flex;box-shadow:0 2px 8px #0000001a}.floating-back-btn:hover,.floating-help-btn:hover{opacity:1;transform:scale(1.1);box-shadow:0 4px 12px #00000026}.floating-help-btn{font-size:1.2rem}.keyboard-help-overlay{z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.keyboard-help-modal{background:var(--surface-color);border:1px solid var(--border-color);border-radius:12px;width:90%;max-width:360px;padding:24px;box-shadow:0 8px 32px #0003}.keyboard-help-modal h3{color:var(--text-color);text-align:center;margin:0 0 16px;font-size:1.1rem;font-weight:700}.shortcut-group{margin-bottom:16px}.shortcut-group h4{color:var(--muted-text-color);text-transform:uppercase;letter-spacing:.05em;margin:0 0 8px;font-size:.8rem;font-weight:600}.shortcut-row{color:var(--text-color);align-items:center;gap:8px;padding:6px 0;font-size:.9rem;display:flex}.shortcut-row kbd{background:var(--surface-alt-color);border:1px solid var(--border-color);min-width:28px;height:26px;color:var(--text-color);border-radius:6px;justify-content:center;align-items:center;padding:0 8px;font-family:inherit;font-size:.8rem;font-weight:600;display:inline-flex;box-shadow:0 1px 2px #0000001a}.shortcut-row span{color:var(--muted-text-color);margin-left:auto}.close-help-btn{background:var(--surface-alt-color);border:1px solid var(--border-color);width:100%;color:var(--text-color);cursor:pointer;border-radius:8px;margin-top:8px;padding:10px;font-size:.9rem;font-weight:600;transition:background .2s}.close-help-btn:hover{background:var(--border-color)}@media (width<=900px){.main-layout{flex-direction:column}.sidebar{flex:none;width:100%;position:static}}@media (width<=750px){.media-content[data-mode=both]{--image-video-height:var(--image-video-height-both-vertical);grid-template-rows:auto auto;grid-template-columns:1fr}.media-content[data-mode=photo] .media-card-body,.media-content[data-mode=video] .media-card-body{flex-direction:column;gap:16px}.media-content[data-mode=photo] .timeline-selector,.media-content[data-mode=video] .timeline-selector{width:100%;max-width:100%}}@media (width<=768px){.single-site-page{padding:var(--space-sm);gap:var(--space-sm)}.floating-site-nav{opacity:.5;width:40px;height:60px}.floating-site-nav.prev{left:5px}.floating-site-nav.next{right:5px}.nav-triangle.left{border-width:8px 13px 8px 0}.nav-triangle.right{border-width:8px 0 8px 13px}}@media (width<=480px){.single-site-page{padding:var(--space-xs);gap:var(--space-xs)}}.logs-page{box-sizing:border-box;width:100%;max-width:1440px;height:calc(100dvh - 108px);min-height:520px;margin:0 auto;padding:16px;overflow:hidden}.logs-card{background:var(--surface-color);border:1px solid var(--border-color);box-shadow:var(--shadow-soft);border-radius:14px;flex-direction:column;gap:12px;height:100%;min-height:0;padding:16px;display:flex}.logs-card-header{flex-direction:column;gap:4px;display:flex}.logs-card-header h2{margin:0;font-size:1.15rem;font-weight:800}.logs-card-header p{color:var(--muted-text-color);margin:0;font-size:.9rem}.logs-toolbar{border:1px solid var(--border-color);background:var(--surface-alt-color);border-radius:10px;flex-wrap:wrap;align-items:center;gap:10px;padding:10px;display:flex}.logs-toolbar label,.logs-toolbar-inline-label,.logs-toolbar-inline-to{color:var(--muted-text-color);text-transform:uppercase;letter-spacing:.03em;font-size:.85rem;font-weight:800}.logs-toolbar select{border:1px solid var(--border-color);background:var(--surface-color);min-width:110px;height:34px;color:var(--text-color);border-radius:8px;padding:0 10px;font-size:.86rem;font-weight:700}.logs-toolbar input{border:1px solid var(--border-color);background:var(--surface-color);min-width:130px;height:34px;color:var(--text-color);border-radius:8px;padding:0 10px;font-size:.86rem;font-weight:700}.log-sort-toggle{border:1px solid var(--border-color);background:var(--surface-color);min-width:78px;height:34px;color:var(--text-color);text-transform:uppercase;cursor:pointer;border-radius:8px;justify-content:center;align-items:center;gap:6px;padding:0 10px;font-size:.82rem;font-weight:800;display:inline-flex}.log-sort-toggle:hover{border-color:#64748b}.logs-meta{color:var(--muted-text-color);flex-wrap:wrap;align-items:center;gap:8px;font-family:Menlo,Monaco,Consolas,Courier New,monospace;font-size:.82rem;display:flex}.logs-meta span{border:1px solid var(--border-color);background:var(--surface-alt-color);border-radius:999px;padding:4px 10px}.logs-error{color:#b91c1c;background:#dc26261f;border:1px solid #dc26268c;border-radius:10px;padding:10px 12px;font-size:.88rem;font-weight:700}.logs-list-wrap{color:#e2e8f0;background:#0b1220;border:1px solid #0f172a;border-radius:12px;flex:1;min-height:0;overflow:auto}.logs-list-header{z-index:2;letter-spacing:.04em;color:#94a3b8;background:#0f172a;border-bottom:1px solid #1e293b;grid-template-columns:72px 130px 130px 90px 1fr;align-items:center;gap:10px;padding:10px 12px;font-family:Menlo,Monaco,Consolas,Courier New,monospace;font-size:.76rem;font-weight:800;display:grid;position:sticky;top:0}.logs-list{margin:0;padding:0;list-style:none}.log-line{border-bottom:1px solid #1e293b;grid-template-columns:72px 130px 130px 90px 1fr;align-items:start;gap:10px;padding:9px 12px;font-family:Menlo,Monaco,Consolas,Courier New,monospace;font-size:.81rem;line-height:1.45;display:grid}.log-line:hover{background:#94a3b814}.log-line-number,.log-date,.log-time{color:#93a4bc;white-space:nowrap}.log-level{letter-spacing:.03em;text-transform:uppercase;white-space:nowrap;border:1px solid #334155;border-radius:999px;justify-content:center;align-items:center;min-width:70px;padding:2px 8px;font-size:.72rem;font-weight:800;display:inline-flex}.log-level.info{color:#22c55e;background:#22c55e1f;border-color:#22c55e66}.log-level.debug{color:#38bdf8;background:#38bdf81f;border-color:#38bdf866}.log-level.warning,.log-level.warn{color:#f59e0b;background:#f59e0b1f;border-color:#f59e0b73}.log-level.error,.log-level.critical{color:#f87171;background:#f871711f;border-color:#f8717173}.log-level.unknown{color:#cbd5e1;background:#94a3b81a;border-color:#475569}.log-message-wrap{min-width:0}.log-message-head{align-items:center;gap:8px;min-width:0;display:flex}.log-message{color:#e2e8f0;white-space:pre-wrap;word-break:break-word;margin:0}.log-message-detail{margin-top:8px}.log-inline-content{color:#e2e8f0;white-space:nowrap;text-overflow:ellipsis;flex:auto;min-width:0;overflow:hidden}.log-inline-content.expanded{white-space:normal;text-overflow:clip;line-height:1.5;overflow:visible}.log-message-preview{color:inherit;margin-right:6px}.log-badge{color:#a7b6cb;white-space:nowrap;text-overflow:ellipsis;vertical-align:middle;background:#94a3b814;border:1px solid #334155;border-radius:999px;align-items:center;max-width:180px;margin-top:2px;margin-right:6px;padding:1px 8px;font-size:.72rem;line-height:1.35;display:inline-block;overflow:hidden}.log-structured{background:#111b2e;border:1px solid #334155;border-radius:8px;margin:6px 0;padding:8px 10px;overflow:auto}.log-structured code{color:#cbd5e1;white-space:pre;font-size:.79rem}.logs-empty{color:#94a3b8;padding:20px 14px;font-family:Menlo,Monaco,Consolas,Courier New,monospace;font-size:.84rem}.logs-pagination{justify-content:flex-end;gap:8px;display:flex}.log-expand-btn{color:#93a4bc;cursor:pointer;background:#0f172a;border:1px solid #334155;border-radius:999px;flex-shrink:0;height:24px;padding:0 8px;font-size:.72rem;font-weight:700}.log-expand-btn:hover{color:#e2e8f0;border-color:#64748b}@media (width<=1024px){.logs-list-header,.log-line{grid-template-columns:56px 110px 96px 80px minmax(280px,1fr)}}@media (width<=768px){.logs-page{height:calc(100dvh - 88px);min-height:420px;margin:0 auto;padding:10px}.logs-card{padding:12px}.logs-list-header,.log-line{min-width:760px}}.control-page{box-sizing:border-box;width:95vw;max-width:none;margin:0 auto;padding:16px}.control-card{background:var(--surface-color);border:1px solid var(--border-color);box-shadow:var(--shadow-soft);border-radius:14px;flex-direction:column;gap:16px;padding:20px;display:flex}.ctrl-toolbar-title{letter-spacing:-.03em;white-space:nowrap;flex-shrink:0;margin:0;font-size:1rem;font-weight:800}.ctrl-toolbar-spacer{flex:1}.ctrl-refresh-info{color:var(--muted-text-color);white-space:nowrap;flex-shrink:0;align-items:center;gap:5px;margin:0;font-size:.78rem;display:flex}.live-dot{background:#22c55e;border-radius:50%;flex-shrink:0;width:7px;height:7px;animation:2s ease-in-out infinite live-pulse;display:inline-block}@keyframes live-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.75)}}.control-stats{flex-wrap:wrap;gap:10px;display:flex}.stat-card{border:1px solid var(--border-color);border-left:3px solid var(--border-color);background:var(--surface-alt-color);border-radius:10px;flex-direction:column;flex:1;gap:3px;min-width:88px;padding:12px 14px;display:flex}.stat-card.success{background:#22c55e0f;border-color:#22c55e40 #22c55e40 #22c55e40 #22c55e}.stat-card.error{background:#ef44440f;border-color:#ef444440 #ef444440 #ef444440 #ef4444}.stat-value{letter-spacing:-.04em;font-size:2rem;font-weight:800;line-height:1}.stat-card.success .stat-value{color:#16a34a}.stat-card.error .stat-value{color:#dc2626}.stat-label{color:var(--muted-text-color);text-transform:uppercase;letter-spacing:.06em;font-size:.72rem;font-weight:700}.ctrl-stat-pills{flex-shrink:0;align-items:center;gap:6px;display:flex}.ctrl-stat-pill{border:1px solid var(--border-color);background:var(--surface-alt-color);color:var(--muted-text-color);white-space:nowrap;border-radius:20px;padding:3px 8px;font-size:.75rem;font-weight:700}.ctrl-stat-pill.success{color:#16a34a;background:#22c55e14;border-color:#22c55e66}.ctrl-stat-pill.error{color:#dc2626;background:#ef444414;border-color:#ef444466}.control-toolbar{z-index:100;background:var(--surface-color);border-bottom:1px solid var(--border-color);align-items:center;gap:10px;padding:10px 24px;display:flex;position:fixed;top:75px;left:0;right:0;box-shadow:0 2px 8px #00000014}.control-page{padding-top:56px}.control-search-wrap{flex:1;min-width:180px;max-width:360px;position:relative}.control-search-wrap:before{content:"⌕";color:var(--muted-text-color);pointer-events:none;font-size:1rem;line-height:1;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.control-search{border:1px solid var(--border-color);background:var(--surface-alt-color);width:100%;height:34px;color:var(--text-color);border-radius:8px;padding:0 12px 0 30px;font-size:.85rem;font-weight:600;transition:border-color .15s,box-shadow .15s}.control-search:focus{border-color:var(--accent-color);box-shadow:0 0 0 3px var(--accent-glow);outline:none}.control-filter-result{color:var(--muted-text-color);white-space:nowrap;font-size:.78rem;font-weight:700}.ctrl-font-scale{border:1px solid var(--border-color);background:var(--surface-alt-color);border-radius:8px;align-items:center;display:inline-flex;overflow:hidden}.ctrl-font-btn{appearance:none;color:var(--text-color);cursor:pointer;background:0 0;border:none;min-width:36px;padding:6px 10px;font-size:.76rem;font-weight:700;line-height:1;transition:background .12s,color .12s}.ctrl-font-btn+.ctrl-font-btn{border-left:1px solid var(--border-color)}.ctrl-font-btn:hover:not(:disabled){background:color-mix(in srgb, var(--accent-color) 14%, transparent);color:var(--accent-color)}.ctrl-font-btn:disabled{color:var(--muted-text-color);cursor:default;opacity:.55}.ctrl-font-reset{min-width:44px;color:var(--muted-text-color);font-family:Menlo,Monaco,Consolas,monospace;font-size:.72rem}.control-loading{text-align:center;color:var(--muted-text-color);padding:32px;font-size:.88rem}.control-table-outer{border:1px solid var(--border-color);border-radius:12px;max-height:calc(100vh - 200px);overflow:hidden auto}.control-table-wrap{grid-template-columns:repeat(10,minmax(max-content,1fr));width:100%;font-size:.84rem;display:grid}.control-table-header,.control-table-list,.control-row{display:contents}.control-table-header>span{border-bottom:1px solid var(--border-color);border-right:1px solid var(--border-color);background:var(--surface-alt-color);letter-spacing:.05em;color:var(--muted-text-color);text-transform:uppercase;z-index:5;white-space:nowrap;text-align:center;padding:9px 12px;font-size:.68rem;font-weight:800;position:sticky;top:0}.control-table-header>span:last-child{border-right:none}.ctrl-th-sortable{cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;gap:2px;transition:color .12s,background .12s;display:flex!important}.ctrl-th-sortable:hover{color:var(--text-color);background:color-mix(in srgb, var(--accent-color) 12%, var(--surface-alt-color) 88%)!important}.ctrl-th-active{color:var(--accent-color)!important}.ctrl-th-label{flex-flow:wrap;justify-content:center;align-items:center;gap:1px 4px;line-height:1.2;display:flex}.ctrl-th-sublabel{opacity:.6;font-size:.6rem}.ctrl-sort-icon{opacity:.35;text-align:center;flex-shrink:0;width:.65em;font-size:.65rem;line-height:1}.ctrl-th-active .ctrl-sort-icon{opacity:1}.control-table-header>span:nth-child(n+8):nth-child(-n+12){background:color-mix(in srgb, var(--surface-alt-color) 60%, var(--accent-color) 5%)}.control-row>*{border-bottom:1px solid var(--border-color);border-right:1px solid var(--border-color);isolation:isolate;justify-content:center;align-self:stretch;align-items:center;padding:8px 12px;transition:background .1s;display:flex;position:relative}.control-row>:nth-child(2),.control-row>:nth-child(5){justify-content:flex-start}.ctrl-cell{align-items:center;display:flex}.control-row>:last-child{border-right:none}.control-row:nth-child(2n)>*{background:color-mix(in srgb, var(--surface-color) 80%, var(--surface-alt-color) 20%)}.control-row:hover>*{background:color-mix(in srgb, var(--accent-color) 8%, var(--surface-color) 92%)!important}.control-row.row-error>*{background:#ef44440a}.control-row.row-error:hover>*{background:#ef444417!important}.control-row.row-error .ctrl-id{animation:2.5s ease-in-out infinite err-pulse}@keyframes err-pulse{0%,to{opacity:1}50%{opacity:.45}}.control-row.row-unknown>*{opacity:.55}.control-row.row-withdrawn>*{background:color-mix(in srgb, var(--surface-color) 60%, transparent 40%)}.control-row.row-withdrawn:hover>*{background:color-mix(in srgb, var(--surface-color) 75%, transparent 25%)!important}.control-row.row-fading>:not(.ctrl-id):after,.control-row.row-withdrawn>:not(.ctrl-id):after{content:"";background:var(--surface-color);opacity:calc(var(--row-fade,0) * .95);pointer-events:none;z-index:1;transition:opacity .5s;position:absolute;inset:0 0 1px}.control-row.row-withdrawn .ctrl-id{opacity:1;filter:none}.ctrl-id{color:var(--muted-text-color);justify-content:center;font-family:Menlo,Monaco,Consolas,monospace;font-size:.8rem;font-weight:700}.ctrl-name{color:var(--muted-text-color);white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;font-weight:700;overflow:hidden}.ctrl-time,.ctrl-ip{color:var(--muted-text-color);white-space:nowrap;font-family:Menlo,Monaco,Consolas,monospace;font-size:.76rem}.ctrl-mono{font-family:Menlo,Monaco,Consolas,monospace;font-size:.8rem}.ctrl-schedule{justify-content:center;padding-left:6px;padding-right:6px}.ctrl-mono.muted,.muted{color:var(--muted-text-color)}.ctrl-focus{font-size:.8rem;line-height:1.3}.ctrl-highlight{color:inherit;background:#eab30859;border-radius:2px;padding:0 1px}.ctrl-col{flex-flow:wrap;justify-content:center;align-items:center;gap:1px 6px;display:flex}.ctrl-time-col{justify-content:flex-end}.ctrl-rel-time{font-variant-numeric:tabular-nums;color:var(--muted-text-color);gap:2px;font-family:Menlo,Monaco,Consolas,monospace;font-size:.7rem;display:flex}.ctrl-rel-val{text-align:right;color:var(--muted-text-color);flex:1;font-family:Menlo,Monaco,Consolas,monospace;font-size:.7rem}.ctrl-rel-unit{text-align:left;min-width:1.4em;color:var(--muted-text-color);font-family:Menlo,Monaco,Consolas,monospace;font-size:.7rem}.ctrl-sub{color:var(--muted-text-color);margin-top:1px;font-family:Menlo,Monaco,Consolas,monospace;font-size:.7rem}.usage-pie-wrap{align-items:center;gap:6px;display:flex}.usage-pie-info{flex-flow:wrap;align-items:center;gap:1px 6px;display:flex}.usage-pie-label{color:var(--muted-text-color);white-space:nowrap;font-family:Menlo,Monaco,Consolas,monospace;font-size:.74rem}.usage-pie-gb{color:var(--muted-text-color);white-space:nowrap;opacity:.7;font-family:Menlo,Monaco,Consolas,monospace;font-size:.68rem}.status-type-badge{white-space:nowrap;appearance:none;letter-spacing:-.04em;border:1.5px solid #0000;border-radius:50%;justify-content:center;align-items:center;width:24px;min-width:24px;height:24px;padding:0 2px;font-size:.56rem;font-weight:800;line-height:1;display:inline-flex;position:relative;overflow:hidden}.status-type-badge:disabled{opacity:1}.status-type-badge.clickable{cursor:pointer;transition:transform .15s,box-shadow .15s}.status-type-badge.clickable:hover{transform:translateY(-1px);box-shadow:0 4px 10px #0f172a1f}.status-type-badge.clickable:focus-visible{outline:2px solid var(--accent-color);outline-offset:2px}.status-type-badge.updating{color:#f97316;background:0 0;border-color:#0000}.status-type-badge.updating:after{content:"";animation:1.55s infinite ctrl-spin;animation-timing-function:linear(0, .06 8%, .42 24%, .74 46%, .84 60%, .97 84%, 1);pointer-events:none;will-change:transform;background:conic-gradient(#f97316fa 0deg,#fb923cf0 34deg,#ef4444d6 58deg,#ef444400 74deg 188deg,#f97316f5 188deg,#fb923ce6 220deg,#ef4444c7 246deg,#ef444400 262deg,#dc262600 360deg);border-radius:50%;position:absolute;inset:1px;-webkit-mask:radial-gradient(farthest-side,#0000 calc(100% - 2px),#000 0);mask:radial-gradient(farthest-side,#0000 calc(100% - 2px),#000 0)}.status-type-badge.update-completed{box-shadow:0 0 0 2px #22c55e24}.status-type-badge.update-failed{box-shadow:0 0 0 2px #ef444424}.status-type-badge.success{color:#16a34a;background:#22c55e24;border-color:#22c55e80}.status-type-badge.error{color:#dc2626;background:#ef444424;border-color:#ef444480;animation:2.5s ease-in-out infinite err-pulse}.status-type-badge.unknown{color:var(--muted-text-color);border-color:var(--border-color);background:var(--surface-alt-color)}@keyframes warn-bg-pulse{0%,to{background-color:#ef44440a}50%{background-color:#ef444429}}.ctrl-warn-bg{animation:2s ease-in-out infinite warn-bg-pulse!important}.control-empty{color:var(--muted-text-color);text-align:center;padding:28px 14px;font-size:.88rem}@keyframes ctrl-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.control-modal-overlay{z-index:1200;background:#0f172a61;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.control-confirm-modal{border:1px solid var(--border-color);background:var(--surface-color);border-radius:16px;width:min(420px,100%);padding:20px;box-shadow:0 20px 50px #0f172a2e}.control-confirm-title{margin:0 0 12px;font-size:1rem;font-weight:800}.control-confirm-text,.control-confirm-subtext,.control-confirm-status{margin:0;line-height:1.5}.control-confirm-subtext,.control-confirm-status{color:var(--muted-text-color);margin-top:8px;font-size:.88rem}.control-confirm-actions{justify-content:flex-end;gap:8px;margin-top:18px;display:flex}.control-confirm-actions .hist-close-btn,.control-confirm-actions .admin-btn{min-width:88px;height:34px}.control-toast-wrap{z-index:1300;position:fixed;bottom:20px;right:20px}.control-toast{border:1px solid var(--border-color);background:var(--surface-color);border-radius:12px;justify-content:space-between;align-items:center;gap:12px;min-width:260px;max-width:360px;padding:12px 14px;font-size:.84rem;font-weight:700;display:flex;box-shadow:0 16px 36px #0f172a2e}.control-toast.info{color:#1d4ed8;border-color:#3b82f647}.control-toast.success{color:#15803d;border-color:#22c55e47}.control-toast.error{color:#dc2626;border-color:#ef444447}.control-toast-close{color:inherit;cursor:pointer;background:0 0;border:none;padding:0;font-size:.82rem;line-height:1}@media (width<=768px){.control-stats{gap:8px}.stat-card{min-width:70px;padding:10px 12px}.stat-value{font-size:1.5rem}}.hist-overlay{z-index:500;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0000008c;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.hist-modal{background:var(--surface-color);border:1px solid var(--border-color);border-radius:16px;flex-direction:column;width:100%;max-width:1100px;max-height:96vh;display:flex;overflow:hidden;box-shadow:0 20px 60px #00000059}.hist-header{border-bottom:1px solid var(--border-color);background:var(--surface-alt-color);flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:14px 18px;display:flex}.hist-title{align-items:baseline;gap:8px;display:flex}.hist-module-id{color:var(--muted-text-color);font-family:Menlo,Monaco,Consolas,monospace;font-size:.78rem;font-weight:700}.hist-module-name{letter-spacing:-.02em;font-size:.95rem;font-weight:800}.hist-subtitle{color:var(--muted-text-color);font-size:.78rem;font-weight:600}.hist-controls{align-items:center;gap:6px;display:flex}.hist-range-wrap{position:relative}.hist-range-trigger{background:var(--surface-color);border:1px solid var(--border-color);min-width:198px;color:var(--muted-text-color);cursor:pointer;text-align:left;border-radius:6px;padding:4px 10px;font-size:.75rem;font-weight:700;transition:background .12s,color .12s,border-color .12s}.hist-range-trigger:hover{border-color:var(--accent-color);color:var(--text-color)}.hist-range-trigger.active{color:var(--text-color);border-color:var(--accent-color);background:color-mix(in srgb, var(--accent-color) 10%, var(--surface-color))}.hist-range-popover{z-index:10;background:var(--surface-color);border:1px solid var(--border-color);border-radius:10px;width:272px;padding:12px;position:absolute;top:calc(100% + 8px);left:0;box-shadow:0 16px 40px #00000038}.hist-range-fields{gap:10px;display:grid}.hist-range-field{color:var(--muted-text-color);gap:4px;font-size:.72rem;font-weight:700;display:grid}.hist-range-field input{background:var(--surface-alt-color);border:1px solid var(--border-color);width:100%;color:var(--text-color);border-radius:6px;padding:7px 8px;font-family:inherit;font-size:.78rem}.hist-range-note{color:var(--muted-text-color);margin-top:10px;font-size:.68rem}.hist-range-actions{justify-content:flex-end;gap:6px;margin-top:10px;display:flex}.hist-range-action{border:1px solid var(--border-color);cursor:pointer;border-radius:6px;padding:5px 10px;font-size:.72rem;font-weight:700;transition:background .12s,color .12s,border-color .12s,opacity .12s}.hist-range-action.ghost{background:var(--surface-alt-color);color:var(--muted-text-color)}.hist-range-action.primary{background:var(--accent-color);border-color:var(--accent-color);color:#fff}.hist-range-action:disabled{opacity:.45;cursor:default}.hist-hour-btn{background:var(--surface-color);border:1px solid var(--border-color);color:var(--muted-text-color);cursor:pointer;border-radius:6px;padding:4px 10px;font-size:.75rem;font-weight:700;transition:background .12s,color .12s,border-color .12s}.hist-hour-btn:hover{border-color:var(--accent-color);color:var(--text-color)}.hist-hour-btn.active{background:var(--accent-color);border-color:var(--accent-color);color:#fff}.hist-close-btn{border:1px solid var(--border-color);color:var(--muted-text-color);cursor:pointer;background:0 0;border-radius:6px;justify-content:center;align-items:center;width:30px;height:30px;margin-left:4px;font-size:.8rem;transition:background .12s,color .12s;display:flex}.hist-close-btn:hover{color:#ef4444;background:#ef44441a;border-color:#ef444466}.hist-body{flex-direction:column;gap:10px;padding:14px 16px;display:flex;overflow-y:auto}.hist-loading,.hist-error,.hist-empty,.hist-no-events{text-align:center;color:var(--muted-text-color);padding:32px;font-size:.88rem}.hist-error{color:#ef4444}.hist-chart-panel{border:1px solid var(--border-color);background:var(--surface-alt-color);border-radius:10px;min-width:0;padding:6px 6px 4px}.hist-chart-toolbar{justify-content:flex-start;padding:0 6px 4px;display:flex}.hist-tooltip{background:var(--surface-color);border:1px solid var(--border-color);border-radius:8px;min-width:120px;padding:8px 12px;font-size:.78rem;box-shadow:0 4px 16px #0000002e}.hist-tooltip-time{color:var(--muted-text-color);margin-bottom:5px;font-family:Menlo,Monaco,Consolas,monospace;font-size:.72rem;font-weight:700}.hist-tooltip-row{justify-content:space-between;gap:12px;padding:1px 0;display:flex}.hist-tooltip-name{font-weight:600}.hist-tooltip-val{font-family:Menlo,Monaco,Consolas,monospace;font-weight:700}.hist-events{border:1px solid var(--border-color);border-radius:10px;overflow:hidden}.hist-events-title{letter-spacing:.06em;text-transform:uppercase;color:var(--muted-text-color);background:var(--surface-alt-color);border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;gap:10px;padding:5px 12px;font-size:.72rem;font-weight:800;display:flex}.hist-tab-group{gap:4px;display:flex}.hist-tab-btn{border:1px solid var(--border-color);color:var(--muted-text-color);cursor:pointer;letter-spacing:0;text-transform:none;background:0 0;border-radius:5px;padding:3px 9px;font-size:.7rem;font-weight:700;transition:background .12s,color .12s,border-color .12s}.hist-tab-btn:hover{border-color:var(--accent-color);color:var(--text-color)}.hist-tab-btn.active{background:var(--accent-color);border-color:var(--accent-color);color:#fff}.hist-events-list{margin:0;padding:0;list-style:none}.hist-event-row{border-bottom:1px solid var(--border-color);align-items:center;gap:10px;padding:7px 14px;font-size:.8rem;display:flex}.hist-event-row:last-child{border-bottom:none}.hist-event-row.hardware{border-left:3px solid #a855f7}.hist-event-row.config{border-left:3px solid #3b82f6}.hist-event-row.update{border-left:3px solid #16a34a}.hist-event-icon{text-align:center;flex-shrink:0;min-width:20px;font-size:.85rem;font-weight:800}.hist-event-time{color:var(--muted-text-color);white-space:nowrap;flex-shrink:0;font-family:Menlo,Monaco,Consolas,monospace;font-size:.72rem}.hist-event-field{color:var(--text-color);white-space:nowrap;font-weight:700}.hist-event-change{flex-wrap:wrap;align-items:center;gap:5px;font-family:Menlo,Monaco,Consolas,monospace;font-size:.75rem;display:flex}.hist-event-from{color:var(--muted-text-color);text-decoration:line-through}.hist-event-arrow{color:var(--muted-text-color)}.hist-event-to{color:var(--text-color);font-weight:700}.hist-event-desc{color:var(--muted-text-color);flex:1;font-size:.75rem}.hist-fields-body{flex-direction:column;display:flex}.hist-field-group-title{letter-spacing:.08em;text-transform:uppercase;color:var(--accent-color);padding:6px 12px 2px;font-size:.64rem;font-weight:800}.hist-field-row{border-bottom:1px solid var(--border-color);align-items:baseline;gap:0;min-height:30px;padding:5px 0 5px 12px;display:flex}.hist-field-row:last-child{border-bottom:none}@media (width<=900px){.hist-header{flex-direction:column;align-items:flex-start}.hist-controls{flex-wrap:wrap;width:100%}.hist-range-wrap,.hist-range-trigger{width:100%}.hist-range-popover{width:min(100%,320px)}}.hist-field-row.no-change{opacity:.45}.hist-field-label{width:96px;color:var(--muted-text-color);flex-shrink:0;font-size:.72rem;font-weight:700}.hist-field-value{width:140px;color:var(--text-color);flex-shrink:0;padding-right:12px;font-family:Menlo,Monaco,Consolas,monospace;font-size:.8rem;font-weight:700}.hist-field-chain{flex-wrap:wrap;flex:1;align-items:baseline;gap:4px;min-width:0;font-family:Menlo,Monaco,Consolas,monospace;font-size:.75rem;display:flex}.hist-chain-origin{color:var(--muted-text-color)}.hist-chain-step{align-items:baseline;gap:4px;display:flex}.hist-chain-arrow{color:var(--muted-text-color);font-size:.7rem}.hist-field-time{color:var(--muted-text-color);white-space:nowrap;font-size:.67rem}.hist-field-nochange{color:var(--muted-text-color);font-size:.72rem}.timeline-page{box-sizing:border-box;width:95vw;max-width:none;margin:0 auto;padding:16px}.timeline-card{background:var(--surface-color);border:1px solid var(--border-color);box-shadow:var(--shadow-soft);border-radius:14px;flex-direction:column;gap:16px;padding:20px;display:flex}.timeline-toolbar{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.timeline-toolbar-title{letter-spacing:-.03em;white-space:nowrap;flex-shrink:0;margin:0;font-size:1rem;font-weight:800}.timeline-toolbar label{align-items:center;gap:4px;font-size:.85rem;font-weight:600;display:flex}.timeline-toolbar input[type=date],.timeline-toolbar select{border:1px solid var(--border-color);background:var(--surface-alt-color);color:var(--text-color);border-radius:8px;padding:4px 8px;font-size:.85rem}.timeline-table-wrap{border:1px solid var(--border-color);border-radius:10px;overflow-x:auto}.timeline-table{border-collapse:collapse;table-layout:auto;min-width:100%;font-size:.75rem}.timeline-col-primary{width:52px}.timeline-col-secondary{width:100px}.timeline-col-load-more{width:28px}.timeline-col-day{width:20px}.timeline-table th,.timeline-table td{border:1px solid var(--border-color);text-align:center;white-space:nowrap;width:20px;min-width:20px;height:22px;padding:0}.timeline-table thead th.timeline-day{padding:1px;line-height:1}.timeline-day-top,.timeline-day-bottom{font-size:.65rem;font-weight:700;line-height:1;display:block}.timeline-day-single{letter-spacing:-.02em;white-space:nowrap;font-size:.58rem;font-weight:700;line-height:1;display:block}.timeline-table thead th{background:var(--surface-alt-color);z-index:2;padding:4px 2px;font-size:.7rem;font-weight:700;position:sticky;top:0}.timeline-table thead th.timeline-year,.timeline-table thead th.timeline-month{padding:2px 4px;font-size:.75rem;font-weight:800}.timeline-table thead th.timeline-corner{z-index:3;background:var(--surface-alt-color);position:sticky}.timeline-table thead th.timeline-corner-primary{white-space:nowrap;left:0}.timeline-table thead th.timeline-corner-secondary{white-space:nowrap;left:52px}.timeline-table tbody th{z-index:1;background:var(--surface-color);text-align:left;padding:4px 6px;font-size:.75rem;font-weight:700;position:sticky}.timeline-table tbody th:first-child{white-space:nowrap;text-overflow:ellipsis;max-width:100px;left:0;overflow:hidden}.timeline-table tbody th:nth-child(2){white-space:nowrap;text-overflow:ellipsis;max-width:20px;left:52px;overflow:hidden}.timeline-table tbody th.timeline-row-current{background:color-mix(in srgb, var(--accent-color) 100%, transparent)}.timeline-table tbody tr.timeline-row-alt th,.timeline-table tbody tr.timeline-row-alt td{background-blend-mode:multiply;background-image:linear-gradient(#ff00000d,#ff00000d)}.timeline-row-main{text-overflow:ellipsis;font-weight:700;line-height:1.05;display:block;overflow:hidden}.timeline-row-subcell{opacity:.9;white-space:nowrap;word-break:normal;text-overflow:ellipsis;font-size:.6rem;font-weight:500;line-height:1.1;display:block;overflow:hidden}.timeline-table thead .timeline-weekend{color:var(--accent-color)}.timeline-cell-segment{background:var(--accent-color);color:#fff;font-size:var(--segment-font-size,.65rem);letter-spacing:.024em;text-overflow:ellipsis;word-break:keep-all;justify-content:center;align-items:center;min-width:0;height:100%;padding:2px 4px;font-weight:600;line-height:1;display:flex;overflow:hidden}.timeline-cell-segment.tone-0{background:var(--accent-color)}.timeline-cell-segment.tone-1{background:color-mix(in srgb, var(--accent-color) 84%, white 16%)}.timeline-cell-segment.tone-2{background:color-mix(in srgb, var(--accent-color) 78%, black 22%)}.timeline-cell-segment.tone-3{background:color-mix(in srgb, var(--accent-color) 70%, white 30%)}.timeline-table td.timeline-cell-current{background:color-mix(in srgb, var(--accent-color) calc(var(--segment-opacity,1) * 100%), transparent);border-left-color:#0000;border-right-color:#0000;border-top-color:var(--border-color);border-bottom-color:var(--border-color)}.timeline-cell-segment.is-current{background:0 0;transition:background-color .2s,border-color .2s}.timeline-table td.timeline-cell-current .timeline-cell-segment.tone-0{background:0 0}.timeline-table td.timeline-cell-current .timeline-cell-segment.tone-1{background:#ffffff1a}.timeline-table td.timeline-cell-current .timeline-cell-segment.tone-2{background:#0000001f}.timeline-table td.timeline-cell-current .timeline-cell-segment.tone-3{background:#ffffff2e}.timeline-cell-segment.confidence-medium{opacity:.55;border:1px dashed #ffffff80}.timeline-cell-segment.is-current.confidence-medium{opacity:1;border-color:rgba(255, 255, 255, calc(var(--segment-opacity,1) * .55))}.timeline-empty,.timeline-loading{text-align:center;color:var(--text-muted-color,#999);padding:40px 20px;font-size:.9rem}.timeline-loading-more{color:var(--text-muted-color,#999);font-size:.75rem;font-weight:600}.timeline-load-more-cell{border:1px solid var(--border-color);width:28px;min-width:28px;padding:0}.timeline-load-more-cell-body{vertical-align:top;background:var(--surface-alt-color)}.timeline-load-more{background:var(--surface-alt-color);width:100%;height:100%;color:var(--text-color);cursor:pointer;border:none;padding:1px;font-size:.62rem;font-weight:700;transition:background .2s}.timeline-load-more-body{writing-mode:vertical-rl;text-orientation:mixed;letter-spacing:.02em;height:100%;min-height:100%}.timeline-load-more:hover:not(:disabled){background:var(--accent-color);color:#fff}.timeline-load-more:disabled{opacity:.5;cursor:default}
