:root{color-scheme:light;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#f3f5f0;color:#172013;--ifg-green: #55c400;--ifg-green-dark: #2f7d04;--ink: #101510;--muted: #657063;--line: #d9dfd4;--panel: #ffffff;--soft: #eef3ea;--warning: #b3392d;--blue: #1d5f8f}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input,select{font:inherit}button{cursor:pointer}.app-shell{min-height:100vh;display:grid;grid-template-rows:64px auto 1fr}.app-header{height:64px;display:flex;align-items:center;justify-content:space-between;padding:0 18px;background:#050805;color:#fff;border-bottom:3px solid var(--ifg-green)}.brand{display:flex;align-items:center;min-width:0;gap:12px}.brand img{width:38px;height:38px}.brand span{display:grid;gap:1px}.brand strong{font-size:18px;letter-spacing:0}.brand small{color:#b7c6b0;font-size:12px}.header-status{display:flex;align-items:center;justify-content:flex-end;gap:8px;min-width:0}.public-address-chip,.version-chip,.server-status-button{min-height:34px;display:inline-flex;align-items:center;justify-content:center;gap:7px;border:1px solid rgba(255,255,255,.18);border-radius:7px;padding:7px 10px;color:#cfe5c6;background:#ffffff0a;font-size:13px;text-decoration:none;white-space:nowrap}.public-address-chip{font-weight:700}.version-chip{border-color:#82b54166;background:#82b54129;color:#e6f8dd;font-weight:850}.version-chip:hover,.version-chip:focus-visible{border-color:#82b541c2;background:#82b54142;outline:none}.server-status-button{min-width:132px}.server-status-button.online{border-color:#55c4006b;background:#55c40029;color:#dff9d1}.server-status-button.offline{border-color:#ff8a7875;background:#b3392d38;color:#ffd7d1}.server-status-button.checking svg{animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.global-error{margin:12px 16px 0;padding:10px 12px;border:1px solid #f1c3bd;color:var(--warning);background:#fff3f1;border-radius:7px}.loading-state{margin:18px;color:var(--muted)}.header-tabs{display:inline-flex;min-height:34px;overflow:hidden;border:1px solid rgba(255,255,255,.16);border-radius:7px}.header-tabs button{display:inline-flex;align-items:center;gap:6px;border:0;border-right:1px solid rgba(255,255,255,.12);padding:7px 10px;background:#ffffff08;color:#cfe5c6;font-weight:700}.header-tabs button:last-child{border-right:0}.header-tabs button.active{background:#55c40038;color:#fff}.user-chip{min-height:34px;display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(255,255,255,.14);border-radius:7px;padding:6px 9px;color:#fff;font-size:13px;font-weight:800;white-space:nowrap}.user-chip small{color:#b7c6b0;font-size:11px;font-weight:700}.header-icon{background:#ffffff0f;color:#fff;border-color:#ffffff29}.app-shell.auth-mode{min-height:100vh;grid-template-rows:1fr;background:radial-gradient(circle at 50% 36%,rgba(130,181,65,.08),transparent 34%),#111211}.auth-screen{min-height:100vh;display:grid;place-items:center;padding:32px 16px}.auth-panel{width:min(400px,100%);display:grid;gap:18px;border:1px solid rgba(255,255,255,.09);border-radius:8px;padding:42px 40px 36px;background:#1b1d1b;box-shadow:0 22px 55px #00000073}.auth-heading{display:flex;align-items:flex-start;gap:10px}.auth-heading svg{flex:0 0 auto;margin-top:4px;color:#82b541;fill:#82b541}.auth-panel h1{margin:0;color:#f4f4f0;font-size:28px;line-height:1.12;font-weight:850}.auth-panel p{margin-top:6px;color:#aab0aa;font-size:14px;line-height:1.35}.auth-panel label{color:#aab0aa}.auth-panel input{min-height:49px;border-color:#dfe9f8;background:#eaf2ff;color:#020502;border-radius:4px;padding:10px 13px}.auth-panel input:focus{outline:2px solid rgba(130,181,65,.42);border-color:#82b541}.auth-submit{width:100%;min-height:48px;margin-top:2px;border:0;border-radius:8px;background:#82b541;color:#fff;font-weight:850}.auth-footer-brand{display:grid;justify-items:center;gap:12px;margin-top:8px}.auth-footer-brand img{width:124px;max-width:48%;height:auto;object-fit:contain}.auth-footer-brand .server-status-button{min-width:0;min-height:29px;padding:5px 8px;font-size:11px}.auth-footer-brand .server-status-button svg{width:13px;height:13px}.auth-footer-actions{display:inline-flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:8px}.auth-footer-brand .version-chip{min-height:29px;padding:5px 8px;font-size:11px}.auth-panel .form-error{margin:0;border-color:#ff8a7866;background:#b3392d33;color:#ffd7d1}.form-error{padding:9px 10px;border:1px solid #f1c3bd;border-radius:7px;color:var(--warning);background:#fff3f1;font-size:13px}.app-grid{display:grid;grid-template-columns:280px minmax(0,1fr) 340px;gap:14px;padding:14px;min-height:calc(100vh - 64px)}.sidebar,.jobs-panel,.workspace,.form-panel{background:var(--panel);border:1px solid var(--line);border-radius:8px}.sidebar,.jobs-panel{min-height:0;overflow:hidden;display:flex;flex-direction:column}.panel-heading,.editor-header{min-height:52px;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px;border-bottom:1px solid var(--line)}.panel-heading.compact{min-height:44px}h1,h2{margin:0;letter-spacing:0}h1{font-size:24px}h2{font-size:15px}.icon-row{display:flex;gap:7px}.icon-button,.row-icon-button{display:inline-grid;place-items:center;width:34px;height:34px;border:1px solid var(--line);border-radius:7px;background:#fff;color:var(--ink)}.icon-button.primary,.command-button{background:var(--ifg-green);color:#071007;border-color:#49ae00}.stream-list,.jobs-list{display:grid;gap:8px;padding:10px;overflow:auto}.stream-row{position:relative;width:100%;min-height:64px;display:grid;grid-template-columns:minmax(0,1fr) auto 30px;align-items:center;gap:8px;text-align:left;border:1px solid var(--line);background:#fbfcfa;border-radius:8px;padding:9px}.stream-select{min-width:0;display:block;border:0;background:transparent;padding:0;text-align:left}.stream-row.selected{border-color:var(--ifg-green);box-shadow:inset 3px 0 0 var(--ifg-green)}.stream-row strong,.stream-row small{display:block;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stream-row small{color:var(--muted);margin-top:3px}.source-pill,.job-status,.live-badge{font-size:12px;border-radius:999px;padding:4px 7px;background:#e6eae2;color:#394235;text-transform:lowercase}.source-pill.active{background:#dcf4ce;color:var(--ifg-green-dark)}.live-badge{min-width:58px;text-align:center;font-weight:700}.live-badge.live{background:#dcf4ce;color:var(--ifg-green-dark)}.live-badge.offline{background:#fff0ed;color:var(--warning)}.row-icon-button{width:28px;height:28px;color:#64705d}.workspace{min-width:0;overflow:auto}.workspace-empty{display:grid;place-items:center;border:1px dashed var(--line);border-radius:8px;background:#fff9;color:var(--muted);font-size:18px}.editor-header{align-items:flex-start}.meta-line{display:flex;flex-wrap:wrap;align-items:center;gap:9px;color:var(--muted);margin-top:7px;font-size:13px}.status-dot{width:10px;height:10px;border-radius:50%;background:#9ba393}.status-dot.online{background:var(--ifg-green);box-shadow:0 0 0 3px #55c40029}.player-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:12px;padding:12px}.video-shell{min-width:0;display:grid;gap:8px}.video-title{color:var(--muted);font-size:13px}video,.video-empty{width:100%;aspect-ratio:16 / 9;border-radius:8px;background:#070907;color:#aab3a2}.video-empty{display:grid;place-items:center}.tool-band{display:grid;grid-template-columns:repeat(2,minmax(180px,1fr)) repeat(2,auto);align-items:end;gap:10px;padding:12px;border-top:1px solid var(--line)}.archive-band{grid-template-columns:repeat(2,minmax(180px,1fr)) auto}.watermark-band{grid-template-columns:auto 110px minmax(180px,1fr) 140px minmax(150px,190px) auto}label{display:grid;gap:6px;font-size:12px;color:var(--muted)}input,select{width:100%;min-height:38px;border:1px solid #cdd6c7;background:#fff;color:var(--ink);border-radius:7px;padding:8px 10px}input:focus,select:focus{outline:2px solid rgba(85,196,0,.28);border-color:var(--ifg-green)}input[aria-invalid=true]{border-color:var(--warning);background:#fff7f5}.date-time-field{min-width:0}.field-error{color:var(--warning);font-size:11px}.checkbox-row{display:flex;align-items:center;gap:8px;min-height:38px;color:var(--ink)}.checkbox-row input{width:16px;min-height:16px}.checkbox-row.tight{align-self:end}.wide-field{min-width:0}.logo-select-field{min-width:0;display:grid;grid-template-columns:minmax(0,1fr) 58px;align-items:end;gap:8px}.logo-select-preview{width:58px;height:38px;object-fit:contain;border:1px solid #cdd6c7;border-radius:7px;padding:4px;background:#101510}.command-button,.command-link,.download-chip{min-height:38px;display:inline-flex;align-items:center;justify-content:center;gap:7px;border:1px solid #49ae00;border-radius:7px;padding:8px 12px;color:#071007;font-weight:700;text-decoration:none;white-space:nowrap}.command-button.secondary{background:#edf4e8;border-color:#c9d9bf;color:#27331f}.command-button:disabled{opacity:.65;cursor:wait}.auth-panel .auth-submit{border:0;background:#82b541;color:#fff}.recordings{border-top:1px solid var(--line)}.download-chip{min-height:30px;padding:5px 9px;border-color:#c9d9bf;background:#eef5e9;font-size:12px}.timeline-panel{border-top:1px solid var(--line);background:#fbfcfa}.timeline-duration{color:var(--ifg-green-dark);font-size:13px;font-weight:800}.timeline-meta,.timeline-scale,.clip-summary,.interval-list{display:flex;align-items:center;justify-content:space-between;gap:10px;color:var(--muted);font-size:12px}.timeline-meta{padding:10px 12px 0}.timeline-track{position:relative;height:176px;margin:10px 12px 6px;border:1px solid #cbd6c4;border-radius:8px;overflow:hidden;background:linear-gradient(180deg,#ffffffb8,#eff5eaeb),repeating-linear-gradient(90deg,rgba(16,21,16,.05) 0 1px,transparent 1px 48px)}.availability-layer,.waveform-bars,.thumbnail-strip,.timeline-selection{position:absolute;left:0;right:0}.thumbnail-strip{top:0;height:66px;display:grid;gap:1px;background:#090d09}.thumbnail-strip img{width:100%;height:66px;display:block;object-fit:cover}.timeline-empty-layer{display:grid;place-items:center;color:#aab3a2;font-size:12px}.availability-segment{position:absolute;top:0;bottom:0;background:#55c40024;border-inline:1px solid rgba(85,196,0,.28)}.waveform-bars{top:66px;bottom:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(2px,1fr));align-items:center;gap:2px;padding:18px 12px 16px}.waveform-bars.is-empty{display:grid;grid-template-columns:1fr;place-items:center}.wave-bar{display:block;min-height:5px;border-radius:999px;background:linear-gradient(180deg,#315b25,#7cc955);opacity:.82}.waveform-empty{color:var(--muted);font-size:12px}.timeline-selection{top:8px;bottom:8px;border:2px solid var(--ifg-green);background:#55c4002e;border-radius:7px;pointer-events:none}.availability-layer{top:66px;right:0;bottom:0;left:0}.timeline-marker-label{position:absolute;z-index:3;top:8px;transform:translate(-50%);min-width:28px;padding:3px 5px;border-radius:5px;background:#071007;color:#fff;font-size:11px;font-weight:800;text-align:center;pointer-events:none}.timeline-marker-label.out{top:auto;bottom:8px}.timeline-range{position:absolute;left:8px;right:8px;width:calc(100% - 16px);padding:0;border:0;background:transparent;pointer-events:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.timeline-range.in{top:6px}.timeline-range.out{bottom:6px}.timeline-range::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;pointer-events:auto;width:18px;height:58px;border:2px solid #071007;border-radius:5px;background:var(--ifg-green);box-shadow:0 3px 10px #10151038}.timeline-range::-moz-range-thumb{pointer-events:auto;width:18px;height:58px;border:2px solid #071007;border-radius:5px;background:var(--ifg-green);box-shadow:0 3px 10px #10151038}.timeline-range::-webkit-slider-runnable-track,.timeline-range::-moz-range-track{background:transparent}.timeline-scale{padding:0 12px 12px}.clip-summary{justify-content:flex-start;padding:12px;border-top:1px solid var(--line)}.clip-summary span{min-height:34px;display:inline-flex;align-items:center;border:1px solid #d9dfd4;border-radius:7px;padding:6px 10px;background:#fbfcfa;color:#293127;font-weight:700}.interval-list{align-items:stretch;flex-direction:column;padding:12px;background:#fbfcfa}.interval-list span,.interval-button{width:100%;min-height:34px;padding:8px 10px;border:1px solid #e2e8de;border-radius:7px;background:#fff;color:#46503f;text-align:left}.interval-button:hover,.interval-button:focus-visible{border-color:var(--ifg-green);background:#eef8e7;color:#172013}.form-workspace{padding:12px}.form-panel{max-width:680px;margin:0 auto;overflow:hidden}.form-panel>label,.form-panel>.two-column,.form-panel>.checkbox-row,.form-panel>.command-button,.form-panel>.inline-error{margin:12px}.two-column{display:grid;grid-template-columns:1fr 1fr;gap:10px}.job-card{display:grid;gap:8px;border:1px solid var(--line);border-radius:8px;padding:10px;background:#fbfcfa}.job-topline,.job-meta{display:flex;align-items:center;justify-content:space-between;gap:8px}.job-meta{color:var(--muted);font-size:12px}.job-filename{overflow-wrap:anywhere;border:1px solid #e0e8da;border-radius:6px;padding:6px 8px;background:#f4f8f0;color:#33402d;font-size:12px;line-height:1.25}.job-status.running,.job-status.queued{background:#e7f0f9;color:var(--blue)}.job-status.done{background:#dcf4ce;color:var(--ifg-green-dark)}.job-status.failed{background:#fff0ed;color:var(--warning)}.progress-track{height:7px;background:#e3e8de;border-radius:99px;overflow:hidden}.progress-track span{display:block;height:100%;background:linear-gradient(90deg,var(--ifg-green),#94d45f)}.command-link{border-color:#c9d9bf;background:#eef5e9;font-size:13px}.empty-state{color:var(--muted);border:1px dashed var(--line);border-radius:8px;padding:16px;text-align:center}.admin-layout{display:grid;gap:14px;padding:14px}.admin-panel{overflow:hidden;border:1px solid var(--line);border-radius:8px;background:#fff}.admin-error{margin:12px}.admin-logo-tools{display:grid;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:10px;margin:12px 12px 0;padding:10px 12px;border:1px solid var(--line);border-radius:8px;background:#fbfcfa}.admin-logo-tools div{display:grid;gap:2px}.admin-logo-tools span,.admin-logo-tools small{color:var(--muted);font-size:12px}.admin-users-grid{display:grid;grid-template-columns:240px 280px minmax(0,1fr);gap:12px;padding:12px}.admin-form{display:grid;align-content:start;gap:10px;padding:12px;border:1px solid var(--line);border-radius:8px;background:#fbfcfa}.admin-form h3{margin:0 0 2px;font-size:15px}.selected-user-chip{min-height:38px;display:flex;align-items:center;justify-content:space-between;gap:8px;border:1px solid #cfe2c4;border-radius:7px;padding:8px 10px;background:#f1faec;font-weight:800}.selected-user-chip span{color:var(--ifg-green-dark);font-size:12px}.users-table-wrap,.log-table-wrap{overflow:auto;border:1px solid var(--line);border-radius:8px}.data-table{width:100%;border-collapse:collapse;font-size:13px}.data-table th,.data-table td{padding:9px 10px;border-bottom:1px solid #e7ece3;text-align:left;vertical-align:top}.data-table th{position:sticky;top:0;z-index:1;background:#f4f7f1;color:#43503e;font-size:12px}.data-table tbody tr{background:#fff}.data-table tbody tr:hover{background:#f8fbf5}.data-table tbody tr:last-child td{border-bottom:0}.users-table tbody tr{cursor:pointer}.selected-row td{background:#eef8e7}.users-table td strong,.users-table td small{display:block}.users-table td small{margin-top:3px;color:var(--muted)}.status-pill,.action-pill{display:inline-flex;align-items:center;min-height:24px;border-radius:999px;padding:4px 9px;font-size:12px;font-weight:800;white-space:nowrap}.status-pill.active{background:#dcf4ce;color:var(--ifg-green-dark)}.status-pill.inactive{background:#fff0ed;color:var(--warning)}.log-filters{display:grid;grid-template-columns:160px 160px repeat(2,minmax(170px,1fr)) auto;align-items:end;gap:10px;padding:12px;border-bottom:1px solid var(--line);background:#fbfcfa}.log-table-wrap{margin:12px;max-height:46vh}.log-table{min-width:920px}.command-button.subtle{border-color:#c9d9bf;background:#eef5e9;color:#27331f}.action-login{background:#dcf4ce;color:var(--ifg-green-dark)}.action-login_failed{background:#fff0ed;color:var(--warning)}.action-logout,.action-setup{background:#eef3ea;color:#46503f}.action-user{background:#f1ebff;color:#57358d}.action-stream{background:#e7f0f9;color:var(--blue)}.action-export{background:#fff6d7;color:#7c5b00}.inline-error,.inline-success{margin:12px;padding:9px 10px;border-radius:7px;font-size:13px}.inline-error{color:var(--warning);border:1px solid #f1c3bd;background:#fff3f1}.inline-success{color:var(--ifg-green-dark);border:1px solid #bfe6ad;background:#f1faec}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;display:grid;place-items:center;padding:18px;background:#0508059e}.changelog-modal{width:min(620px,100%);max-height:min(760px,calc(100vh - 36px));overflow:hidden;border:1px solid rgba(255,255,255,.1);border-radius:8px;background:#fff;box-shadow:0 24px 70px #00000061}.changelog-modal .panel-heading{background:#111611;color:#f4f8f0;border-bottom-color:#82b5416b}.changelog-modal .panel-heading small{display:block;margin-top:3px;color:#b7c6b0}.changelog-modal .icon-button{border-color:#ffffff29;background:#ffffff0f;color:#fff}.changelog-content{max-height:calc(100vh - 130px);overflow:auto;padding:14px}.changelog-entry{display:grid;gap:10px;padding:14px;border:1px solid var(--line);border-radius:8px;background:#fbfcfa}.changelog-entry+.changelog-entry{margin-top:12px}.changelog-version{display:flex;align-items:center;justify-content:space-between;gap:10px}.changelog-version strong{display:inline-flex;align-items:center;min-height:28px;border-radius:999px;padding:5px 10px;background:#dcf4ce;color:var(--ifg-green-dark)}.changelog-version span{color:var(--muted);font-size:12px}.changelog-entry h3{margin:0;font-size:17px}.changelog-entry ul{display:grid;gap:7px;margin:0;padding-left:18px;color:#394235;line-height:1.42}@media(max-width:1180px){.app-grid{grid-template-columns:260px minmax(0,1fr)}.jobs-panel{grid-column:1 / -1;max-height:360px}.admin-users-grid{grid-template-columns:minmax(220px,1fr) minmax(240px,1fr)}.users-table-wrap{grid-column:1 / -1}.log-filters{grid-template-columns:repeat(2,minmax(160px,1fr))}}@media(max-width:820px){.app-header{align-items:flex-start;height:auto;min-height:64px;padding:12px;gap:10px;flex-direction:column}.header-status{width:100%;justify-content:space-between;flex-wrap:wrap}.header-tabs{order:3;width:100%}.header-tabs button{flex:1;justify-content:center}.app-grid{grid-template-columns:1fr;padding:10px}.sidebar,.jobs-panel{max-height:360px}.player-grid,.tool-band,.archive-band,.watermark-band,.logo-select-field,.two-column,.admin-users-grid,.log-filters,.admin-logo-tools{grid-template-columns:1fr}.admin-layout{padding:10px}.auth-screen{min-height:100vh;padding:16px 10px}.auth-panel{padding:30px 24px 28px}}
