:root{
  --font-ui: 'Geist Sans', sans-serif;
  --font-code: 'Geist Mono', monospace;
  --bg:#0b0c10; --panel:#151823; --text:#eaf2ff; --subtle:#a8b3cf; --muted:#66708b; --brand:#7aa2ff; --accent:#9b8cff; --danger:#ff6b6b; --ok:#3bd671; --border:#22283a;
  --panel-gradient:linear-gradient(180deg,#121728,#0f1424);
  --card-gradient:linear-gradient(180deg,#0e1220,#0c1120);
  --surface-soft:#0e1324;
  --surface-muted:#0e1220;
  --surface-accent:#101528;
  --surface-deep:#0b0f1c;
  --chip-bg:#0e1324;
  --chip-border:#2a3147;
  --chip-fg:#aeb8d4;
  --chip-active-bg:rgba(122,162,255,.12);
  --chip-active-fg:#d8e2ff;
  --chip-hover-border:rgba(122,162,255,.35);
  --switch-track:#0e1324;
  --switch-thumb:#aeb8d4;
  --shadow-raised:0 18px 40px rgba(0,0,0,.35);
  --shadow-card:0 12px 28px rgba(0,0,0,.25);
  --shadow-lightbox:0 40px 90px rgba(0,0,0,.55);
  --shadow-drawer:-16px 0 40px rgba(0,0,0,.35);
  --overlay-button-bg:rgba(255,255,255,.08);
  --overlay-button-fg:#aeb8d4;
  --overlay-button-hover-bg:rgba(255,255,255,.16);
}

html[data-theme='dark']{color-scheme:dark}
html[data-theme='light']{
  color-scheme:light;
  --bg:#f4f6ff;
  --panel:#ffffff;
  --text:#1d2334;
  --subtle:#4e5d78;
  --muted:#6f7d96;
  --brand:#335cff;
  --accent:#7450ff;
  --danger:#d64545;
  --ok:#1f9d60;
  --border:#d6dcf3;
  background-color:#f4f6ff;
  background-image:radial-gradient(1200px 500px at 20% -10%, rgba(97,118,182,.28) 0%, rgba(23,32,58,0) 60%), linear-gradient(180deg,#f4f6ff,#e7ecff);
  --panel-gradient:linear-gradient(180deg,#ffffff,#e9edff);
  --card-gradient:linear-gradient(180deg,#ffffff,#f2f5ff);
  --surface-soft:#eef1ff;
  --surface-muted:#f9faff;
  --surface-accent:#dde3ff;
  --surface-deep:#eef1ff;
  --chip-bg:#eef1ff;
  --chip-border:#cdd5f2;
  --chip-fg:#4e5d78;
  --chip-active-bg:rgba(51,92,255,.16);
  --chip-active-fg:#233160;
  --chip-hover-border:rgba(51,92,255,.35);
  --switch-track:#dbe2ff;
  --switch-thumb:#ffffff;
  --shadow-raised:0 18px 40px rgba(33,53,106,.12);
  --shadow-card:0 12px 28px rgba(33,53,106,.08);
  --shadow-lightbox:0 40px 90px rgba(33,53,106,.16);
  --shadow-drawer:-16px 0 40px rgba(33,53,106,.12);
  --overlay-button-bg:rgba(51,92,255,.12);
  --overlay-button-fg:#335cff;
  --overlay-button-hover-bg:rgba(51,92,255,.22);
}
html[data-theme='light'] body{color:var(--text)}

@font-face {
  font-family: 'Geist Sans';
  src: url('/fonts/Geist-Regular.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Geist Sans';
  src: url('/fonts/Geist-Semibold.woff2') format('woff2');
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Geist Mono';
  src: url('/fonts/GeistMono-Regular.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Geist Mono';
  src: url('/fonts/GeistMono-Semibold.woff2') format('woff2');
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}

/* Tippy core styles */
[data-tippy-root]{max-width:calc(100vw - 10px)}
.tippy-box{position:relative;background-color:#333;color:#fff;border-radius:4px;font-size:14px;line-height:1.4;white-space:normal;outline:0;transition-property:transform,visibility,opacity}
.tippy-box[data-animation=fade][data-state=hidden]{opacity:0}
.tippy-box[data-inertia][data-state=visible]{transition-timing-function:cubic-bezier(.54,1.5,.38,1.11)}
.tippy-box[data-placement^='top']>.tippy-arrow{bottom:0}
.tippy-box[data-placement^='bottom']>.tippy-arrow{top:0}
.tippy-box[data-placement^='left']>.tippy-arrow{right:0}
.tippy-box[data-placement^='right']>.tippy-arrow{left:0}
.tippy-box[data-placement^='top']>.tippy-arrow:before{bottom:-7px;left:0;border-width:8px 8px 0;border-top-color:initial;transform-origin:center top}
.tippy-box[data-placement^='bottom']>.tippy-arrow:before{top:-7px;left:0;border-width:0 8px 8px;border-bottom-color:initial;transform-origin:center bottom}
.tippy-box[data-placement^='left']>.tippy-arrow:before{border-width:8px 0 8px 8px;border-left-color:initial;right:-7px;transform-origin:center left}
.tippy-box[data-placement^='right']>.tippy-arrow:before{left:-7px;border-width:8px 8px 8px 0;border-right-color:initial;transform-origin:center right}
.tippy-arrow{width:16px;height:16px;color:#333}
.tippy-arrow:before{content:"";position:absolute;border-color:transparent;border-style:solid}
.tippy-content{position:relative;padding:5px 9px;z-index:1}

/* Tippy tooltip theme */
.tippy-box[data-theme~='sora']{background:#11162a;color:#fff;border-radius:8px;box-shadow:0 12px 30px rgba(0,0,0,.45);font-family:var(--font-ui);font-size:12px;line-height:1.3;padding:6px 10px}
.tippy-box[data-theme~='sora'] .tippy-content{padding:0}
.tippy-box[data-theme~='sora'][data-placement^='top'] > .tippy-arrow::before{border-top-color:#11162a}
.tippy-box[data-theme~='sora'][data-placement^='bottom'] > .tippy-arrow::before{border-bottom-color:#11162a}
.tippy-box[data-theme~='sora'][data-placement^='left'] > .tippy-arrow::before{border-left-color:#11162a}
.tippy-box[data-theme~='sora'][data-placement^='right'] > .tippy-arrow::before{border-right-color:#11162a}

/* Ensure the HTML hidden attribute always hides, even if our CSS sets display */
[hidden]{display:none !important}
*{box-sizing:border-box}
html,body{height:100%}
html{background-color:#0b0c10; background-image:radial-gradient(1200px 500px at 20% -10%, #17203a 0%, rgba(23,32,58,0) 60%), linear-gradient(180deg,#0b0c10,#0f1320); background-attachment:fixed, fixed}
body{margin:0;font-family:var(--font-ui);background:transparent;color:var(--text);min-height:100vh;overscroll-behavior-y:none}
html[data-theme='light']{background-attachment:fixed, fixed}

.status-bar{position:sticky;top:0;z-index:1300;background:var(--panel);border-bottom:1px solid var(--border);backdrop-filter:blur(12px)}
.status-bar__inner{position:relative;width:min(100%, 1500px);margin:0 auto;padding:10px 24px;display:flex;align-items:center;gap:16px}
.status-bar__menu-btn{flex:0 0 auto;width:38px;height:34px;border-radius:10px;border:1px solid var(--chip-border);background:var(--chip-bg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:6px;cursor:pointer;transition:background .18s ease,border-color .18s ease}
.status-bar__menu-btn span{display:block;width:100%;height:2px;background:var(--chip-fg);border-radius:999px;transition:background .18s ease}
.status-bar__menu-btn:hover{border-color:var(--chip-hover-border);background:var(--chip-active-bg)}
.status-bar--menu-open .status-bar__menu-btn{border-color:var(--chip-hover-border);background:var(--chip-active-bg)}
.status-bar--menu-open .status-bar__menu-btn span{background:var(--chip-active-fg)}
.status-bar__menu{position:absolute;top:calc(100% + 10px);left:24px;padding:12px;border-radius:12px;border:1px solid var(--border);background:var(--panel-gradient);box-shadow:var(--shadow-card);min-width:220px;display:flex;flex-direction:column;gap:10px;z-index:10}
.status-bar__menu-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.status-bar__menu-list li{margin:0;padding:0}
.status-bar__menu-link{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 10px;border-radius:8px;border:1px solid transparent;text-decoration:none;font-size:13px;color:var(--text);background:transparent;cursor:pointer;transition:background .18s ease,border-color .18s ease,color .18s ease}
.status-bar__menu-link:hover{background:var(--chip-active-bg);border-color:var(--chip-hover-border);color:var(--chip-active-fg)}
.status-bar__menu-link:focus-visible{outline:2px solid var(--brand);outline-offset:2px}
.status-bar__menu-link--button{width:100%;background:transparent;border:none;text-align:left}
.status-bar__menu-text{display:block;padding:8px 10px;font-size:12px;color:var(--muted)}
.status-bar__menu[hidden]{display:none}
.status-bar__controls{display:flex;align-items:center;gap:12px;flex:0 0 auto}
.status-bar__menu-extras{display:none;flex-direction:column;gap:12px;margin-top:8px;padding-top:12px;border-top:1px solid var(--border)}
.status-bar__menu-extras #statusBarControls{display:flex;flex-direction:column;gap:12px}
.status-bar__menu-extras .theme-toggle{justify-content:space-between}
.status-bar__menu-extras .status-bar__user{display:flex;justify-content:space-between;align-items:center}
.status-bar__user{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--text)}
.status-bar__user-name{max-width:180px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.status-bar__logout-btn{display:inline-flex;align-items:center;justify-content:center;height:34px;padding:0 14px;border-radius:999px;border:1px solid var(--chip-border);background:var(--chip-bg);color:var(--text);font-size:12px;cursor:pointer;transition:background .18s ease,border-color .18s ease,color .18s ease}
.status-bar__logout-btn:hover{border-color:var(--chip-hover-border);background:var(--chip-active-bg);color:var(--chip-active-fg)}
.status-bar__logout-btn:focus-visible{outline:2px solid var(--brand);outline-offset:2px}
.status-bar--menu-open{z-index:1400}
.status-bar__queue{flex:1 1 auto;min-width:0;display:flex;flex-wrap:wrap;align-items:center;gap:6px;font-size:12px;color:var(--subtle)}
.status-bar__queue[hidden]{display:none}
.status-bar__queue-empty{color:var(--muted);font-size:13px;white-space:nowrap}
.status-bar--empty .status-bar__queue{color:var(--muted)}
.status-bar__queue-item{flex:0 0 auto;display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;border:1px solid var(--chip-border);background:var(--chip-bg);color:var(--chip-fg);font-size:12px;line-height:1;white-space:nowrap;max-width:100%;overflow:hidden;text-overflow:ellipsis;cursor:default}
.status-bar__queue-item--active{border-color:var(--chip-hover-border);background:var(--chip-active-bg);color:var(--chip-active-fg);font-weight:600}
.theme-toggle{--theme-toggle-size:34px;--theme-toggle-icon-size:18px;display:inline-flex;align-items:center;gap:6px}
.theme-toggle__btn{display:grid;place-items:center;width:var(--theme-toggle-size);height:var(--theme-toggle-size);padding:0;border-radius:10px;border:1px solid transparent;background:transparent;color:var(--subtle);cursor:pointer;transition:background .2s ease,border-color .2s ease,color .2s ease;line-height:0}
.theme-toggle__btn svg{width:var(--theme-toggle-icon-size);height:var(--theme-toggle-icon-size);display:block}
.theme-toggle__btn:hover{color:var(--text);border-color:rgba(122,162,255,.32)}
.theme-toggle__btn:focus-visible{outline:2px solid var(--brand);outline-offset:3px}
.theme-toggle__btn.is-active{background:rgba(122,162,255,.18);border-color:rgba(122,162,255,.45);color:var(--text)}
html[data-theme='light'] .theme-toggle__btn:hover{border-color:rgba(51,92,255,.3)}
html[data-theme='light'] .theme-toggle__btn.is-active{background:rgba(51,92,255,.16);border-color:rgba(51,92,255,.45);color:#1d2334}
header{padding:28px 28px 4px}
header h1{margin:0 0 4px;font-size:26px;letter-spacing:.2px}
header p{margin:0;color:var(--subtle)}
.browser-warning{position:sticky;top:0;z-index:1200;display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:12px;padding:12px 20px;background:linear-gradient(180deg,rgba(255,107,107,.22),rgba(73,20,32,.85));border-bottom:1px solid rgba(255,107,107,.45);box-shadow:0 14px 32px rgba(0,0,0,.35);color:#ffe4e4;font-size:13px}
.browser-warning__content{display:flex;flex-direction:column;gap:4px;text-align:center;max-width:min(100%,900px)}
.browser-warning__message{margin:0;font-size:13px;line-height:1.45;color:#ffe4e4}
.browser-warning__message strong{color:#ffd0d0}
.browser-warning__ua-line{margin:0;font-size:12px;color:rgba(255,214,214,.9)}
.browser-warning__ua{display:inline-flex;align-items:center;padding:2px 6px;margin-left:4px;border-radius:6px;background:rgba(13,17,29,.7);border:1px solid rgba(255,107,107,.35);font-family:var(--font-code);font-size:12px;color:#ffd7d7}
.browser-warning__dismiss{appearance:none;border:1px solid rgba(255,107,107,.35);background:rgba(255,107,107,.12);color:#ffd0d0;border-radius:999px;padding:6px 14px;font-size:12px;font-weight:500;cursor:pointer;transition:background .2s ease,border-color .2s ease,transform .03s ease}
.browser-warning__dismiss:hover{border-color:rgba(255,107,107,.6);background:rgba(255,107,107,.22)}
.browser-warning__dismiss:active{transform:translateY(1px)}
.browser-warning__dismiss:focus-visible{outline:2px solid rgba(255,225,225,.9);outline-offset:2px}
@media (min-width:720px){
  .browser-warning{justify-content:space-between;padding:12px 28px}
  .browser-warning__content{text-align:left}
  .browser-warning__ua{margin-left:6px}
}
/* Footer user strip */
header a{color:#9bb4ff;text-decoration:none}
header a:hover{text-decoration:underline}
main{padding:24px;display:grid;gap:24px;grid-template-columns:1fr;width:min(100%, 1500px);margin:0 auto}
.panel{background:var(--panel-gradient);border:1px solid var(--border);border-radius:16px;padding:18px 18px 22px;box-shadow:var(--shadow-raised)}
.panel h2{margin:0 0 12px;font-size:18px}
/* Smaller, muted panel title variant */
.subtle-title{font-size:14px;color:var(--muted);font-weight:500;margin:0 0 8px}
.panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.panel-header .tools{display:flex;gap:10px;align-items:center}
.filters{display:flex;gap:6px}
.filter-group{display:inline-flex;align-items:center;gap:8px;padding:4px 10px;border:1px solid var(--chip-border);border-radius:999px;background:var(--chip-bg);color:var(--subtle);font-size:13px}
.filter-group .filter-label{line-height:1;white-space:nowrap;font-weight:500}
.filter-group .filters{gap:6px}
.pillbtn{appearance:none;border:1px solid var(--chip-border);background:var(--chip-bg);color:var(--chip-fg);padding:4px 12px;border-radius:999px;cursor:pointer;font-size:12px;white-space:nowrap;line-height:1.2;transition:border-color .2s ease, color .2s ease, background .2s ease}
.pillbtn:hover{border-color:var(--chip-hover-border);}
.pillbtn.active{background:var(--chip-active-bg);border-color:var(--chip-hover-border);color:var(--chip-active-fg)}
.panel-header .compact{display:flex;gap:6px;align-items:center;color:var(--subtle);font-size:13px}
.panel-header .compact input{width:110px;background:var(--surface-muted);border:1px solid var(--border);border-radius:8px;padding:6px 10px;color:var(--text);line-height:1.2}

form{display:grid;gap:12px}
label{display:grid;gap:6px;color:var(--subtle);font-size:14px}
.label-head{display:flex;align-items:center;justify-content:space-between}
.ghost.small{padding:4px 8px;font-size:12px;border-radius:8px}
.input-wrap{position:relative}
.clear-btn{position:absolute;right:8px;top:8px;z-index:2;appearance:none;border:1px solid var(--border);background:var(--chip-bg);color:var(--chip-fg);width:24px;height:24px;border-radius:999px;cursor:pointer;line-height:1;display:flex;align-items:center;justify-content:center;font-size:16px}
.clear-btn:hover{color:var(--chip-active-fg);border-color:var(--chip-hover-border);background:var(--surface-accent)}
.clear-btn:focus{outline:2px solid var(--brand);outline-offset:2px}
/* Unify input look for dark mode */
textarea,
input:not([type="checkbox"]):not([type="radio"]):not([type="file"]),
select{width:100%;background:var(--surface-muted);color:var(--text);border:1px solid var(--border);border-radius:10px;padding:10px 32px 10px 12px;outline:none;transition:border-color .2s ease, box-shadow .2s ease}
textarea{font-family:var(--font-code);}
pre,code{font-family:var(--font-code);}
textarea:focus,
input:not([type="checkbox"]):not([type="radio"]):not([type="file"]):focus,
select:focus{border-color:var(--brand)}
.input-error{border-color:#ff6b6b !important;box-shadow:0 0 0 1px rgba(255,107,107,.35)}
.error-message{font-size:12px;color:#ff6b6b;margin-top:4px}
::placeholder{color:color-mix(in srgb,var(--muted) 65%,transparent 35%);font-style:italic}
/* Remove number spinners */
input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button{appearance:none;margin:0}
input[type="number"]{appearance:textfield}
.hint{font-size:12px;color:var(--muted);margin-top:2px}
.pill{display:inline-flex;gap:6px;align-items:center;background:var(--chip-bg);border:1px solid var(--chip-border);border-radius:999px;padding:6px 10px;color:var(--chip-fg)}
.row{display:grid;grid-template-columns:1fr 110px 210px;gap:12px}
.file input{background:var(--surface-muted);border:1px solid var(--border);padding:12px;border-radius:10px}
.dropzone{position:relative;border:1px dashed var(--border);border-radius:10px;background:var(--surface-muted);min-height:64px;padding:32px 12px 12px 12px}
.dropzone input[type="file"]{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:pointer;border:0;padding:0;margin:0;background:transparent}
.dropzone{position:relative}
.dropzone .dz-text{position:absolute;left:12px;top:8px;color:var(--subtle);font-size:13px;pointer-events:none}
.dropzone.dragover{outline:2px dashed #7aa2ff;outline-offset:2px}
.preview{margin-top:4px;position:relative}
.preview.hidden{display:none}
.preview img{max-height:320px;border-radius:10px;border:1px solid var(--border);width:100%;height:auto;display:block}
.preview .cropper-container{width:100% !important;max-width:100%}
.crop-tools{position:absolute;right:8px;bottom:8px;display:flex;gap:6px;z-index:5}
.crop-tools .pillbtn{padding:4px 8px}

.form-footer{display:flex;align-items:center;justify-content:space-between;margin-top:2px;gap:10px;flex-wrap:wrap}
.form-tools{display:flex;gap:10px;align-items:center;margin-top:-4px}

.switch{display:inline-flex;align-items:center;gap:10px;cursor:pointer;user-select:none;color:var(--subtle);font-size:14px;margin:4px 0}
.switch input{position:absolute;opacity:0;width:1px;height:1px;overflow:hidden}
.switch .switch-ui{width:36px;height:22px;border-radius:999px;border:1px solid var(--border);background:var(--switch-track);display:inline-block;position:relative;transition:background .2s ease, border-color .2s ease}
.switch .switch-ui::after{content:"";position:absolute;left:2px;top:2px;width:16px;height:16px;border-radius:50%;background:var(--switch-thumb);transition:transform .2s ease, background .2s ease}
.switch input:checked + .switch-ui{background:linear-gradient(180deg,var(--brand),#5c75ff);border-color:transparent}
.switch input:checked + .switch-ui::after{transform:translateX(14px);background:#fff}
.switch.switch-inline{font-size:13px;gap:6px;margin:0}
.switch.switch-inline .switch-ui{width:32px;height:18px}
.switch.switch-inline .switch-ui::after{width:14px;height:14px}
.switch.switch-inline span:last-child{font-size:13px;color:var(--chip-fg)}
.actions .switch-inline{margin-right:0;flex:0 0 auto;gap:4px;font-size:10px;color:var(--chip-fg);line-height:1}
.actions .switch-inline .switch-ui{width:28px;height:16px}
.actions .switch-inline .switch-ui::after{width:12px;height:12px;left:1px;top:1px}
.actions .switch-inline input:checked + .switch-ui::after{transform:translateX(12px)}
.actions .switch-inline span:last-child{font-size:10px;color:var(--chip-fg)}
.switch.switch-inline.disabled{opacity:.6;cursor:default}
.switch.switch-inline.disabled span:last-child{color:#6d7790}
.switch.switch-inline.disabled input{pointer-events:none}
.switch.switch-inline.loading{opacity:.6;pointer-events:none}

.primary,.ghost{appearance:none;border:1px solid var(--border);background:var(--surface-accent);color:var(--text);padding:8px 12px;border-radius:10px;cursor:pointer;transition:transform .03s ease, box-shadow .2s ease}
.primary{background:linear-gradient(180deg,var(--brand),#5c75ff);border:none;color:#fff;font-weight:600;padding:9px 14px}
.primary:hover{box-shadow:0 8px 20px rgba(122,162,255,.25)}
.primary:active{transform:translateY(1px)}
.primary.loading{position:relative;pointer-events:none;opacity:.85}
.primary.loading::after{content:"";width:14px;height:14px;border-radius:50%;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;display:inline-block;margin-left:10px;vertical-align:middle;animation:spin .9s linear infinite}
.primary[disabled]{opacity:.6}
.ghost[disabled]{opacity:.5;pointer-events:none}
.ghost{color:var(--subtle)}
.ghost:hover{border-color:var(--chip-hover-border)}
.danger.loading{position:relative;pointer-events:none;opacity:.85}
.danger.loading::after{content:"";width:14px;height:14px;border-radius:50%;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;display:inline-block;margin-left:10px;vertical-align:middle;animation:spin .9s linear infinite}
.danger{border-color:rgba(255,107,107,.35);color:#ffb3b3}
.danger:hover{border-color:#ff6b6b}

.status{margin-top:10px;color:var(--subtle)}
.info{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:12px;border:1px dashed var(--border);border-radius:10px;padding:10px;background:var(--surface-soft);font-size:13px}
.info-col{display:grid;gap:6px}
.info-row{display:grid;grid-template-columns:1fr auto;align-items:center;gap:12px;line-height:1.25}
.info-row .muted{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.info-row span:last-child{font-variant-numeric:tabular-nums;white-space:normal;text-align:right;word-break:break-word}
.muted{color:var(--muted)}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}
.jobs-by-day{display:flex;flex-direction:column;gap:16px}
.jobs-day{background:var(--card-gradient);border:1px solid var(--border);border-radius:14px;overflow:hidden;box-shadow:var(--shadow-card)}
.jobs-day-header{display:flex;align-items:center;gap:16px;justify-content:flex-start;width:100%;padding:16px 18px;border:none;background:transparent;color:var(--text);font-size:15px;font-weight:600;text-align:left;cursor:pointer;transition:background .2s ease}
.jobs-day-header:hover{background:rgba(122,162,255,.05)}
.jobs-day-header:focus-visible{outline:2px solid rgba(122,162,255,.65);outline-offset:-4px}
.jobs-day-title{display:flex;align-items:center;gap:10px;min-width:0}
.jobs-day-label{font-weight:600;white-space:nowrap}
.jobs-day-summary{margin-left:auto;display:grid;grid-template-columns:repeat(4,auto);gap:16px;align-items:center;font-variant-numeric:tabular-nums}
.jobs-day-summary .small{text-align:right}
@media (max-width:900px){.jobs-day-summary{grid-template-columns:repeat(2,auto)}}
@media (max-width:640px){.jobs-day-header{flex-wrap:wrap;gap:12px}.jobs-day-summary{grid-template-columns:repeat(2,1fr);gap:10px;margin-left:0;width:100%;justify-items:flex-start}.jobs-day-summary .small{text-align:left}}
@media (max-width:480px){.jobs-day-summary{grid-template-columns:1fr}}
.jobs-day-caret{flex-shrink:0;width:10px;height:10px;border-right:2px solid var(--muted);border-bottom:2px solid var(--muted);transform:rotate(-45deg);transition:transform .2s ease}
.jobs-day[data-expanded="true"] .jobs-day-caret{transform:rotate(45deg)}
.jobs-day-body{border-top:1px solid var(--border);padding:16px 18px 20px;display:block}
.jobs-day-body[hidden]{display:none}
.jobs-day-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:16px}
.jobs-day-note{margin-bottom:12px;font-size:12px;color:var(--muted)}
.jobs-day-note[hidden]{display:none}
.jobs-day-empty{margin-top:8px;font-size:12px;color:var(--muted);text-align:center;padding:12px;border:1px dashed rgba(122,162,255,.3);border-radius:10px}
.jobs-day-empty[hidden]{display:none}
.jobs-day.is-filter-empty{opacity:.65}
.jobs-day.is-archived .jobs-day-label{color:#d2c6aa}
.jobs-day.is-archived .jobs-day-caret{border-color:#ffc57a}
.jobs-day.is-archived .jobs-day-summary .small{color:var(--muted)}
.job-card-archived{opacity:.6}
.job-card-archived .actions{pointer-events:none}
.job-card-archived button,.job-card-archived a{pointer-events:none}
.badge-archived{background:rgba(255,197,122,.12);border-color:rgba(255,197,122,.35);color:#ffe3b5}
.badge-archived::before{background:#ffc57a}
.list-footer{display:flex;justify-content:center;margin-top:10px}
.list-footer .ghost{min-width:140px}
/* Hide Load more by default; JS will reveal when applicable */
#loadMoreBtn{display:none}
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:14px;padding:48px 20px;border:1px dashed rgba(122,162,255,.35);border-radius:14px;background:rgba(12,18,32,.65);box-shadow:inset 0 0 40px rgba(122,162,255,.08);color:var(--subtle);animation:fadeInUp .24s ease-out}
.empty-state-icon{width:56px;height:56px;border-radius:50%;display:grid;place-items:center;font-size:28px;background:rgba(122,162,255,.12);color:#d5deff;box-shadow:0 12px 28px rgba(0,0,0,.35)}
.empty-state-title{margin:0;font-size:20px;color:#e8edff;font-weight:600}
.empty-state-copy{margin:0;max-width:360px;font-size:14px;line-height:1.5;color:var(--muted)}
.empty-state .primary{min-width:0;padding:10px 22px}
html[data-theme='light'] .empty-state{border-color:color-mix(in srgb,var(--chip-border) 70%,transparent 30%);background:color-mix(in srgb,#ffffff 92%,var(--surface-soft) 8%);box-shadow:inset 0 0 32px rgba(119,131,186,.16);color:color-mix(in srgb,var(--muted) 65%,var(--text) 35%)}
html[data-theme='light'] .empty-state-icon{background:color-mix(in srgb,var(--surface-accent) 70%,#ffffff 30%);color:color-mix(in srgb,var(--brand) 55%,var(--text) 45%);box-shadow:0 12px 24px rgba(51,64,110,.15)}
html[data-theme='light'] .empty-state-title{color:color-mix(in srgb,var(--text) 85%,var(--brand) 15%)}
html[data-theme='light'] .empty-state-copy{color:color-mix(in srgb,var(--muted) 70%,var(--text) 30%)}
html[data-theme='light'] .empty-state .primary{box-shadow:0 12px 24px rgba(51,64,110,.12)}
.prompt-flash{animation:promptFlash 1.3s ease}
@keyframes promptFlash{
  0%{box-shadow:0 0 0 0 rgba(122,162,255,.6);border-color:rgba(122,162,255,.9)}
  40%{box-shadow:0 0 0 6px rgba(122,162,255,.15);border-color:rgba(122,162,255,.9)}
  100%{box-shadow:0 0 0 0 rgba(122,162,255,0);border-color:var(--brand)}
}
.card{position:relative;background:var(--card-gradient);border:1px solid var(--border);border-radius:14px;overflow:hidden;transition:box-shadow .3s ease;box-shadow:var(--shadow-card)}
.card.job-card{background:var(--panel);border:1px solid var(--chip-border);box-shadow:var(--shadow-card)}
html[data-theme='light'] .card.job-card{background:var(--panel);border-color:var(--chip-border);box-shadow:0 16px 34px rgba(51,64,110,.12)}
.card.highlight{border:2px solid transparent;background:
var(--card-gradient) padding-box,
linear-gradient(130deg,#86b6ff,#4ec8ff,#8d7aff,#ff6bff,#3bd671,#86b6ff) border-box;background-size:100% 100%,260% 260%;animation:borderSweep 2.4s linear infinite;box-shadow:0 0 26px rgba(134,182,255,.55),0 0 46px rgba(141,122,255,.25)}
.card.highlight::before{content:"";position:absolute;inset:6px;border-radius:10px;pointer-events:none;box-shadow:0 0 30px rgba(111,180,255,.4);opacity:.65;animation:borderPulse 1.8s ease-in-out infinite}
.card.highlight .card-body{position:relative}
@keyframes borderSweep{0%{background-position:0 0,0% 50%}50%{background-position:0 0,100% 50%}100%{background-position:0 0,0% 50%}}
@keyframes borderPulse{0%,100%{opacity:.35}50%{opacity:.85}}
html[data-theme='light'] .card.highlight{box-shadow:0 0 22px rgba(134,182,255,.55),0 0 42px rgba(116,138,240,.45),0 0 0 3px rgba(116,138,240,.3)}
html[data-theme='light'] .card.highlight::before{box-shadow:0 0 36px rgba(116,138,240,.55)}
.card-body{padding:12px}
.meta{display:grid;grid-template-rows:auto auto;row-gap:4px;margin-bottom:8px}
.meta-top{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.meta-bottom{display:flex;gap:10px;align-items:baseline;justify-content:flex-start;flex-wrap:wrap;text-align:left}
.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:999px;font-size:12px;border:1px solid var(--chip-border);color:var(--chip-fg);background:var(--chip-bg)}
.badge-new{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:600;letter-spacing:.3px;text-transform:uppercase;background:linear-gradient(135deg,rgba(255,138,195,.35),rgba(122,228,255,.35));border:1px solid rgba(172,197,255,.55);color:#ffe9ff;box-shadow:0 0 12px rgba(151,211,255,.35),0 0 30px rgba(151,211,255,.25)}
.badge-new::before{content:"●";font-size:10px;color:#fff;text-shadow:0 0 12px rgba(255,255,255,.8)}
.card.highlight .badge-new{animation:newBadgePulse 1.4s ease-in-out infinite}
.card:not(.highlight) .badge-new{animation:none}
@keyframes newBadgePulse{0%,100%{box-shadow:0 0 12px rgba(151,211,255,.35),0 0 30px rgba(151,211,255,.25)}50%{box-shadow:0 0 18px rgba(255,186,255,.45),0 0 40px rgba(112,197,255,.45)}}
.badge::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--chip-fg)}
.badge[data-state="queued"]::before{background:var(--chip-fg)}
.badge[data-state="in_progress"]::before{background:var(--brand)}
.badge[data-state="completed"]::before{background:var(--ok)}
.badge[data-state="failed"]::before{background:var(--danger)}
.badge[data-state="completed"]{background:color-mix(in srgb,var(--ok) 14%,transparent);border-color:color-mix(in srgb,var(--ok) 32%,transparent);color:color-mix(in srgb,var(--ok) 65%,#ffffff 35%)}
.badge[data-state="failed"]{background:color-mix(in srgb,var(--danger) 12%,transparent);border-color:color-mix(in srgb,var(--danger) 30%,transparent);color:color-mix(in srgb,var(--danger) 62%,#ffffff 38%)}
html[data-theme='light'] .badge[data-state="completed"]{background:color-mix(in srgb,var(--ok) 12%,#ffffff 88%);border-color:color-mix(in srgb,var(--ok) 26%,#ffffff 74%);color:color-mix(in srgb,var(--ok) 58%,var(--text) 42%)}
html[data-theme='light'] .badge[data-state="failed"]{background:color-mix(in srgb,var(--danger) 10%,#ffffff 90%);border-color:color-mix(in srgb,var(--danger) 24%,#ffffff 76%);color:color-mix(in srgb,var(--danger) 56%,var(--text) 44%)}
.small{color:var(--muted);font-size:12px}
.progress{position:relative;height:6px;background:var(--surface-soft);border:1px solid var(--border);border-radius:999px;overflow:hidden;margin:8px 0}
.progress.with-meta{margin-bottom:2px}
.progress + .eta{margin-top:2px}
.eta{color:var(--muted);font-size:12px}
.progress .bar{height:100%;background:linear-gradient(90deg,#7aa2ff,#9b8cff)}
/* When a job is fully done (completed + preview ready), show a subtle green bar */
.progress.done .bar{background:linear-gradient(90deg, rgba(59,214,113,.85), rgba(92,232,157,.9))}

/* Purple refresh icon button */
#refreshBtn.ghost.icon{color:var(--accent)}
#refreshBtn.ghost.icon:hover{color:#c1b8ff}
.media{position:relative;border:1px solid var(--border);border-radius:10px;aspect-ratio:9/16;background:var(--surface-soft);overflow:hidden;width:min(100%,180px);margin:0 auto;max-height:320px}
.media video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border-radius:inherit;pointer-events:none;filter:brightness(.92)}
.media img.poster{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;border-radius:inherit;pointer-events:none;z-index:1;transition:opacity .2s ease}
.media .media-trigger{position:absolute;inset:0;display:flex;align-items:flex-end;justify-content:center;padding:16px;border:none;background:transparent;color:#fff;font-size:14px;font-weight:600;cursor:pointer;z-index:2;transition:background .2s ease, transform .2s ease, box-shadow .2s ease, opacity .2s ease}
.media .media-trigger:focus-visible{outline:2px solid var(--brand);outline-offset:2px}
.media .media-trigger:hover{background:linear-gradient(180deg,rgba(11,15,28,0) 20%,rgba(14,18,36,.82) 100%);box-shadow:0 18px 30px rgba(0,0,0,.35);transform:translateY(-1px)}
.media .media-trigger:active{transform:translateY(0)}
.media .media-trigger .media-trigger-label{display:inline-flex;align-items:center;gap:10px;padding:8px 18px;border-radius:999px;background:rgba(12,17,32,.78);box-shadow:0 8px 22px rgba(0,0,0,.45);backdrop-filter:blur(4px)}
.media .media-trigger .media-trigger-icon{width:28px;height:28px;border-radius:50%;border:2px solid rgba(255,255,255,.65);display:inline-flex;align-items:center;justify-content:center}
.media .media-trigger .media-trigger-icon::after{content:"";width:0;height:0;border-left:9px solid rgba(255,255,255,.85);border-top:5px solid transparent;border-bottom:5px solid transparent;margin-left:2px}
.media.loading{position:relative}
/* Hide shimmer when explicit spinner is shown */
.media.loading.show-spinner::after{display:none}
.media.loading::after{content:"";position:absolute;inset:0;border-radius:10px;background:linear-gradient(90deg, rgba(255,255,255,.05), rgba(255,255,255,.02), rgba(255,255,255,.05));background-size:200% 100%;animation:shimmer 1.2s linear infinite}
.media .empty{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:0 12px;text-align:center;color:var(--muted);font-size:13px}
.media .empty-title{font-weight:600;display:block}
.media .empty-note{font-size:12px;color:var(--muted);display:block;margin-top:0}
.media .empty.moderation{background:rgba(255,107,107,.12);color:#ffc6c6;flex-direction:column;gap:4px;padding:0 18px;text-shadow:0 0 8px rgba(0,0,0,.25)}
.media .empty.moderation .empty-note{color:rgba(255,198,198,.82)}
.media .empty .empty-provider-label{font-weight:600;font-size:12px;color:rgba(255,198,198,.9)}
html[data-theme='light'] .media .empty.moderation{background:color-mix(in srgb,var(--danger) 12%,#ffffff 88%);color:color-mix(in srgb,var(--danger) 52%,var(--text) 48%);text-shadow:none;border:1px solid color-mix(in srgb,var(--danger) 22%,#ffffff 78%);box-shadow:0 8px 20px rgba(214,69,69,.12)}
html[data-theme='light'] .media .empty.moderation .empty-title{color:color-mix(in srgb,var(--danger) 60%,var(--text) 40%)}
html[data-theme='light'] .media .empty.moderation .empty-note,
html[data-theme='light'] .media .empty .empty-provider-label{color:color-mix(in srgb,var(--danger) 50%,var(--text) 50%)}
.media .empty.failure.provider-error{background:rgba(255,107,107,.14);color:#ffe0e0;padding:14px 18px;gap:12px;text-shadow:0 0 10px rgba(0,0,0,.22)}
.media .empty.failure.provider-error .empty-title{color:#ffeaea}
.media .empty.failure.provider-error .error-detail{display:flex;flex-direction:column;gap:8px;width:100%}
.media .empty.failure.provider-error .error-detail-row{display:flex;flex-direction:column;align-items:center;gap:2px}
.media .empty.failure.provider-error .error-detail-key{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,198,198,.78)}
.media .empty.failure.provider-error .error-detail-value{font-size:13px;color:#ffeaea;word-break:break-word;line-height:1.35}
.media .empty.failure.provider-error .error-detail-value.code{color:#ff7f7f;font-weight:600}
.media .empty.failure.provider-error .error-detail-value.message{color:#ffd0d0}
.media .empty.failure.provider-error .error-detail-value.identifier{color:#ffeaea;font-family:var(--font-code,'JetBrains Mono','SFMono-Regular',Consolas,monospace)}
.media .empty.has-tooltip{cursor:help}

/* Centered purple spinner for generating/previews */
.media .media-spinner{position:absolute;inset:0;z-index:3;display:grid;place-items:center;pointer-events:none;animation:none !important;transform:none !important;filter:drop-shadow(0 8px 22px rgba(0,0,0,.45))}
.media .media-spinner::before{content:"";width:46px;height:46px;border-radius:50%;border:3px solid rgba(155,140,255,.22);border-top-color:var(--accent);border-right-color:var(--accent);animation:spin .8s linear infinite}
html[data-theme='light'] .media .media-spinner{filter:drop-shadow(0 10px 26px rgba(36,42,76,.2))}
.media .cooldown-overlay{position:absolute;inset:0;z-index:5;display:flex;align-items:center;justify-content:center;padding:16px;background:linear-gradient(180deg,rgba(9,13,26,.85),rgba(9,13,26,.92));backdrop-filter:blur(8px)}
.media .cooldown-panel{display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px;padding:20px;border-radius:16px;background:rgba(13,16,29,.88);border:1px solid rgba(146,132,255,.28);box-shadow:0 18px 32px rgba(7,9,20,.6);width:100%;max-width:232px}
.media .cooldown-heading{display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:rgba(214,206,255,.7)}
.media .cooldown-timer{font-size:24px;font-weight:700;color:#fff;font-variant-numeric:tabular-nums;margin-top:-2px}
.media .cooldown-reason{font-size:12px;line-height:1.5;color:rgba(214,206,255,.78);max-width:180px}
.media .cooldown-spinner{display:flex;align-items:center;gap:10px;color:rgba(214,206,255,.86);font-size:13px;font-weight:600}
.media .cooldown-spinner-icon{display:inline-block;width:20px;height:20px;border-radius:50%;border:2px solid transparent;border-top-color:var(--accent);border-right-color:var(--accent);animation:spin .8s linear infinite;flex-shrink:0;filter:drop-shadow(0 6px 16px rgba(0,0,0,.35))}
.media .cooldown-spinner-label{letter-spacing:.02em}
.media .cooldown-actions{display:flex;flex-direction:column;gap:8px;width:100%;justify-content:center}
.cooldown-action{width:100%;padding:10px 14px;border-radius:999px;border:1px solid rgba(208,203,255,.32);background:rgba(17,20,33,.6);color:rgba(229,224,255,.92);font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .18s ease,color .18s ease,transform .18s ease,box-shadow .18s ease;text-align:center}
.cooldown-action.fast{background:var(--accent);color:#060a1a;border-color:transparent;box-shadow:0 12px 24px rgba(146,132,255,.45)}
.cooldown-action.fast:hover{background:var(--accent-strong,#b4a7ff);transform:translateY(-1px)}
.cooldown-action.cancel{background:rgba(18,22,38,.65);color:rgba(226,221,255,.86)}
.cooldown-action.cancel:hover{background:rgba(24,28,46,.9);transform:translateY(-1px)}
.cooldown-action:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.cooldown-action:disabled{opacity:.55;cursor:default;transform:none;box-shadow:none}
html[data-theme='light'] .media .cooldown-overlay{background:linear-gradient(180deg,color-mix(in srgb,#ffffff 88%,var(--brand) 12%),color-mix(in srgb,#eef1ff 92%,var(--brand) 8%));box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--brand) 6%,transparent)}
html[data-theme='light'] .media .cooldown-panel{background:color-mix(in srgb,var(--panel) 90%,var(--surface-accent) 10%);border:1px solid color-mix(in srgb,var(--brand) 20%,#cdd5f2 80%);box-shadow:0 18px 36px rgba(51,64,110,.18)}
html[data-theme='light'] .media .cooldown-heading{color:color-mix(in srgb,var(--brand) 55%,var(--muted) 45%)}
html[data-theme='light'] .media .cooldown-timer{color:var(--text)}
html[data-theme='light'] .media .cooldown-reason{color:color-mix(in srgb,var(--brand) 30%,var(--muted) 70%)}
html[data-theme='light'] .media .cooldown-spinner{color:color-mix(in srgb,var(--brand) 48%,var(--text) 52%)}
html[data-theme='light'] .media .cooldown-spinner-icon{filter:drop-shadow(0 6px 16px rgba(51,64,110,.2))}
html[data-theme='light'] .media .cooldown-actions{gap:10px}
html[data-theme='light'] .cooldown-action{background:color-mix(in srgb,#ffffff 86%,var(--surface-accent) 14%);border:1px solid color-mix(in srgb,var(--brand) 18%,#cdd5f2 82%);color:color-mix(in srgb,var(--brand) 34%,var(--text) 66%);box-shadow:0 8px 18px rgba(51,64,110,.08)}
html[data-theme='light'] .cooldown-action:hover{background:color-mix(in srgb,var(--surface-accent) 70%,#ffffff 30%);color:color-mix(in srgb,var(--brand) 28%,var(--text) 72%);box-shadow:0 12px 22px rgba(51,64,110,.14)}
html[data-theme='light'] .cooldown-action.fast{color:#1a1f37;box-shadow:0 14px 26px rgba(116,80,255,.25)}
html[data-theme='light'] .cooldown-action.fast:hover{color:#0d1024;background:color-mix(in srgb,var(--accent) 86%,#ffffff 14%)}
html[data-theme='light'] .cooldown-action.cancel{background:color-mix(in srgb,var(--surface-accent) 90%,#ffffff 10%);color:color-mix(in srgb,var(--muted) 68%,var(--text) 32%)}
html[data-theme='light'] .cooldown-action.cancel:hover{background:color-mix(in srgb,var(--surface-accent) 74%,var(--brand) 26%);color:color-mix(in srgb,var(--muted) 58%,var(--text) 42%)}

/* Small toggle in top-right of preview (contact vs poster) */
.media .preview-switch{position:absolute;top:8px;right:8px;z-index:4;appearance:none;border:1px solid rgba(155,140,255,.45);background:rgba(155,140,255,.14);color:#d8e2ff;padding:4px 8px;border-radius:999px;font-size:11px;line-height:1;cursor:pointer;backdrop-filter:blur(4px);box-shadow:0 8px 22px rgba(0,0,0,.45)}
.media .preview-switch:hover{background:rgba(155,140,255,.22);border-color:rgba(155,140,255,.6)}
.media .preview-switch:focus-visible{outline:2px solid var(--accent);outline-offset:2px}

/* Utility for accessible-only text */
.visually-hidden{position:absolute !important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
.lineage{margin-bottom:6px;color:var(--muted);font-size:12px}
.lineage a{color:#9bb4ff;text-decoration:none}
.lineage a:hover{text-decoration:underline}
.errorbox{margin:8px 0;padding:8px 10px;border-radius:10px;border:1px solid color-mix(in srgb,var(--danger) 30%,transparent);background:color-mix(in srgb,var(--danger) 12%,transparent);color:color-mix(in srgb,var(--danger) 62%,#ffffff 38%);font-size:12px}
html[data-theme='light'] .errorbox{background:color-mix(in srgb,var(--danger) 10%,#ffffff 90%);border-color:color-mix(in srgb,var(--danger) 24%,#ffffff 76%);color:color-mix(in srgb,var(--danger) 56%,var(--text) 44%)}
.errorbox--provider .errorbox-label{display:block;font-weight:600;margin-bottom:2px;font-size:11px;letter-spacing:.01em;color:inherit;opacity:.85}
.errorbox--provider em{display:block;font-style:italic}
.hidden{display:none}

body.lightbox-open{overflow:hidden}
.lightbox{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:32px;background:transparent;backdrop-filter:blur(10px);z-index:900;opacity:0;pointer-events:none;transition:opacity .2s ease}
.lightbox.visible{opacity:1;pointer-events:auto}
.lightbox[hidden]{display:none}
.lightbox-backdrop{position:absolute;inset:0;background:rgba(6,8,14,.68);z-index:0}
.lightbox-panel{position:relative;width:min(90vw,720px);max-height:90vh;display:flex;flex-direction:column;gap:12px;background:var(--panel-gradient);border:1px solid var(--border);border-radius:18px;padding:20px;box-shadow:var(--shadow-lightbox);z-index:1}
.lightbox-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}
.lightbox-title{font-size:16px;font-weight:600;color:var(--text)}
.lightbox-close{width:36px;height:36px;border-radius:50%;border:none;background:var(--overlay-button-bg);color:var(--overlay-button-fg);font-size:20px;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s ease,color .2s ease}
.lightbox-close:hover{background:var(--overlay-button-hover-bg);color:#fff}
.lightbox-close:focus-visible{outline:2px solid var(--brand);outline-offset:2px}
.lightbox-body{position:relative;display:flex}
.lightbox-body video{width:100%;max-height:70vh;border-radius:12px;background:#000;box-shadow:0 18px 40px rgba(0,0,0,.4)}
.prompt-block{display:flex;flex-direction:column;gap:6px}
.prompt-block .prompt-toggle{align-self:flex-start}
.prompt-block pre{margin:0;background:var(--surface-deep);border:1px solid var(--border);color:var(--text);padding:10px;border-radius:10px;font-family:var(--font-code);font-size:13px;line-height:1.45;white-space:pre-wrap;overflow:auto;max-height:280px}
.actions{display:flex;align-items:center;gap:6px;margin-top:8px;min-width:0}
.actions-buttons{display:flex;align-items:center;flex-wrap:nowrap;gap:6px;margin-left:auto;flex:1 1 auto;min-width:0}
.actions-buttons>*{flex:0 0 auto}
.actions .ghost,
.actions .danger{font-size:10px;padding:4px 8px;border-radius:999px;min-width:0;white-space:nowrap;line-height:1.2;text-align:center;display:inline-flex;align-items:center;justify-content:center;background:var(--chip-bg);border:1px solid var(--chip-border);color:var(--chip-fg);gap:4px}
.actions .ghost:hover{border-color:var(--chip-hover-border);color:var(--chip-active-fg);background:var(--chip-active-bg)}
.actions .danger:hover{border-color:rgba(255,107,107,.5);color:#ff8585;background:rgba(255,120,120,.18)}
.actions .danger{color:#ff6b6b;border-color:rgba(255,107,107,.35);background:rgba(255,107,107,.08)}
/* Admin daily summary line */
.summary{border-top:1px dashed var(--border);border-bottom:1px dashed var(--border);margin:4px 0}

.modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:24px;background:rgba(8,12,24,.68);backdrop-filter:blur(6px);z-index:1200}
.modal-backdrop{position:absolute;inset:0}
.modal-panel{position:relative;z-index:1;width:100%;max-width:420px;background:linear-gradient(180deg,#141a2f,#0f1424);border:1px solid var(--border);border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.55);padding:20px;display:flex;flex-direction:column;gap:16px}
html[data-theme='light'] .modal-panel{background:linear-gradient(180deg,var(--panel),color-mix(in srgb,var(--panel) 80%,var(--surface-muted) 20%));box-shadow:0 24px 64px rgba(51,64,110,.18)}
.modal-header{display:flex;align-items:center;justify-content:space-between;gap:12px}
.modal-header h3{margin:0;font-size:18px}
.modal-body{display:grid;gap:12px}
.modal-field{display:grid;gap:6px}
.modal-label{color:var(--subtle);font-size:13px}
.modal-body #confirmMessage{margin:0;color:var(--text);font-size:14px;line-height:1.45}
.modal-footer{display:flex;justify-content:flex-end;gap:10px}
.modal-footer .primary,
.modal-footer .danger{min-width:130px}
body.modal-open{overflow:hidden}
.ghost.icon{padding:4px 8px;font-size:20px;line-height:1;border-radius:8px}

@media (max-width: 900px){
  .panel-header{flex-direction:column;align-items:flex-start;gap:12px}
  .panel-header .tools{width:100%;gap:10px;flex-wrap:wrap;justify-content:flex-start}
  .filter-group{flex:1 1 160px}
  .filter-group .filters{flex-wrap:wrap}
}

@media (max-width: 680px){
  .status-bar__inner{padding:10px 16px;flex-direction:row;align-items:center;gap:8px}
  .status-bar__inner>.status-bar__controls{display:none}
  .status-bar__queue{flex-wrap:nowrap;overflow:auto;-webkit-overflow-scrolling:touch}
  .status-bar__menu-extras{display:flex}
  header{padding:24px 16px 8px}
  header h1{font-size:22px}
  header p{font-size:14px}
  main{padding:16px;gap:18px}
  .panel{padding:16px}
  .footer{padding:12px}
  .filters{flex-wrap:wrap}
  .filter-group{width:100%;flex-direction:column;align-items:flex-start;gap:6px}
  .filter-group .filter-label{margin-bottom:0}
  .filter-group .filters{width:100%;justify-content:flex-start}
  .filter-group .filters .pillbtn{flex:1 1 140px}
  .filter-group{border:none;padding:0;background:transparent;border-radius:0}
  .panel-header .tools .ghost.icon{margin-left:0;flex:1 1 100%}
  .row{grid-template-columns:1fr !important;gap:10px}
  .form-footer{flex-wrap:wrap;justify-content:flex-start;gap:10px}
  .form-footer .pill{margin-bottom:4px}
  .form-footer button{flex:1 1 160px}
  .info{grid-template-columns:1fr}
  .list-footer{justify-content:flex-start}
  .sticky-bar .sticky-inner{flex-direction:column;align-items:flex-start;gap:12px}
  .sticky-bar .right{width:100%;justify-content:flex-start}
  .sticky-bar .btn-cluster{flex-wrap:wrap;gap:8px}
  .sticky-bar .btn-cluster .ghost,
  .sticky-bar .btn-cluster .primary{flex:1 1 140px}
  .lightbox-panel{width:100%;max-width:none}
  .drawer-panel{width:100%}
  .log-row-header{grid-template-columns:repeat(2, minmax(0, 1fr))}
}

@media (max-width: 520px){
  .actions{flex-direction:column;align-items:stretch;gap:6px}
  .actions-buttons{margin-left:0;flex-wrap:wrap}
}

@media (max-width: 760px){
  .row{grid-template-columns:1fr 1fr;gap:8px}
}

@media (min-width: 900px){
  main{grid-template-columns:minmax(320px, 480px) minmax(0, 1fr)}
  #jobs.grid{grid-template-columns:repeat(auto-fit, minmax(320px, 1fr))}
}

@media (min-width: 1400px){
  main{gap:32px;grid-template-columns:minmax(360px, 520px) minmax(0, 1fr)}
}

textarea[data-autogrow]{overflow-y:hidden;resize:none}

/* Keep generic spin for small inline loaders without affecting positioning */
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* Home Presets */
.preset-inline{display:block;margin-top:8px}
.preset-links{display:flex;gap:12px;align-items:center;color:var(--subtle);font-size:12px}
.preset-link{appearance:none;border:1px solid transparent;background:transparent;color:inherit;padding:2px 6px;border-radius:8px;cursor:pointer;transition:background-color .15s ease,color .15s ease,border-color .15s ease}
.preset-link:hover{color:var(--text);background:var(--surface-accent);border-color:var(--border)}
.preset-link.active{color:var(--text);background:var(--surface-accent);border-color:var(--border)}
.preset-link .count{color:var(--muted)}
.preset-wrap{margin-top:6px}
.preset-wrap[hidden]{display:none !important}
.preset-wrap.show{animation:fadeInUp .18s ease-out}
.preset-groups{display:grid;gap:10px;margin-top:8px}
.preset-grid{display:flex;flex-wrap:wrap;gap:8px;align-items:flex-start}
.preset-mini{display:flex;align-items:center;gap:6px;min-width:0;max-width:260px;padding:8px 10px;border:1px solid var(--border);background:var(--chip-bg);color:var(--chip-fg);border-radius:10px;cursor:pointer;font-size:12px;line-height:1.3;flex:0 0 auto;transition:border-color .2s ease,color .2s ease}
.preset-mini:hover{border-color:var(--chip-hover-border);color:var(--chip-active-fg)}
.preset-mini .name{flex:1;min-width:0;white-space:normal;word-break:break-word}
.preset-mini .info{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:999px;border:1px solid var(--border);background:var(--surface-accent);color:var(--chip-fg);font-size:12px;transition:border-color .2s ease,color .2s ease}
.preset-mini .info:hover{color:var(--chip-active-fg);border-color:var(--chip-hover-border)}

/* Folded preset sections */
@keyframes fadeInUp{from{opacity:0;transform:translateY(2px)}to{opacity:1;transform:translateY(0)}}

/* Drawer (embedded designer) */
.drawer{position:fixed;inset:0;z-index:1200;display:flex;justify-content:flex-end}
.drawer[hidden]{display:none !important}
.drawer-overlay{position:absolute;inset:0;background:rgba(8,12,24,.55)}
.drawer-panel{position:relative;height:100%;width:min(960px, 100%);background:var(--panel-gradient);border-left:1px solid var(--border);box-shadow:var(--shadow-drawer);display:flex;flex-direction:column}
.drawer-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-bottom:1px solid var(--border)}
.drawer-header .drawer-actions{display:inline-flex;gap:8px;align-items:center}
.drawer-panel iframe{flex:1;border:0;width:100%;height:100%}
.drawer-body{flex:1;display:flex;flex-direction:column;overflow:auto;min-height:0}
.log-drawer-body{display:flex;flex-direction:column;padding:12px;gap:12px;min-height:0}
.log-prompt-section{display:flex;flex-direction:column;gap:8px;border:1px solid var(--border);border-radius:12px;padding:12px;background:var(--panel-gradient);box-shadow:var(--shadow-card)}
.log-prompt-header{display:flex;align-items:center;justify-content:space-between;gap:12px}
.log-prompt-title{margin:0;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:color-mix(in srgb,var(--brand) 55%,var(--text) 45%)}
.log-prompt-count{font-size:12px;color:var(--muted)}
.log-prompt-preview{font-family:var(--font-code);font-size:12px;line-height:1.5;color:var(--text);background:color-mix(in srgb,var(--surface-deep) 92%,transparent 8%);border:1px solid color-mix(in srgb,var(--border) 75%,transparent 25%);border-radius:8px;padding:10px;white-space:pre-wrap;overflow:hidden;max-height:140px;box-shadow:inset 0 1px 0 rgba(255,255,255,.04)}
.log-prompt-preview[data-collapsed="false"]{max-height:420px;overflow:auto}
.log-prompt-actions{display:flex;gap:8px;flex-wrap:wrap}
.log-input-section{display:flex;flex-direction:column;gap:10px;border:1px solid var(--border);border-radius:12px;padding:12px;background:var(--panel-gradient);box-shadow:var(--shadow-card)}
.log-input-header{display:flex;align-items:center;justify-content:space-between;gap:12px}
.log-input-title{margin:0;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:color-mix(in srgb,var(--brand) 55%,var(--text) 45%)}
.log-input-actions{display:flex;align-items:center;gap:8px}
.log-input-body{position:relative;border-radius:8px;border:1px solid color-mix(in srgb,var(--border) 75%,transparent 25%);background:color-mix(in srgb,var(--surface-deep) 90%,transparent 10%);padding:8px;display:flex;align-items:center;justify-content:center;min-height:120px}
.log-input-body img{max-width:100%;max-height:320px;border-radius:6px;box-shadow:0 12px 28px rgba(0,0,0,.35);object-fit:contain}
.log-input-meta{margin:0;font-size:12px;color:var(--muted)}
.log-table{flex:0 0 auto;overflow:auto;display:flex;flex-direction:column;gap:8px;font-family:var(--font-code);font-size:12px;background:var(--panel-gradient);border:1px solid var(--border);border-radius:12px;padding:12px;box-shadow:var(--shadow-card)}
.log-row{border:1px solid color-mix(in srgb,var(--border) 80%,transparent 20%);border-radius:10px;padding:10px;cursor:pointer;transition:border-color .18s ease, background-color .18s ease, box-shadow .18s ease;outline:none;background:color-mix(in srgb,var(--surface-soft) 88%,transparent 12%)}
.log-row:hover{border-color:color-mix(in srgb,var(--brand) 45%,var(--border) 55%);background:color-mix(in srgb,var(--surface-accent) 70%,var(--panel) 30%);box-shadow:0 10px 26px rgba(0,0,0,.22)}
.log-row:focus{border-color:var(--brand);box-shadow:0 0 0 2px color-mix(in srgb,var(--brand) 35%,transparent 65%)}
.log-row.expanded{border-color:color-mix(in srgb,var(--brand) 60%,var(--border) 40%);background:color-mix(in srgb,var(--surface-accent) 75%,var(--panel) 25%);box-shadow:0 12px 28px rgba(0,0,0,.28)}
.log-row-header{display:grid;grid-template-columns:auto auto auto 1fr;gap:8px;align-items:center;font-size:12px;line-height:1.3}
.log-time{font-variant-numeric:tabular-nums;color:color-mix(in srgb,var(--brand) 55%,var(--text) 45%)}
.log-level{font-weight:600;text-transform:uppercase;color:color-mix(in srgb,var(--text) 80%,var(--subtle) 20%)}
.log-level.level-warn{color:color-mix(in srgb,var(--danger) 60%,var(--text) 40%)}
.log-level.level-error{color:var(--danger)}
.log-level.level-info{color:color-mix(in srgb,var(--brand) 60%,var(--text) 40%)}
.log-event{color:color-mix(in srgb,var(--text) 85%,var(--subtle) 15%)}
.log-message{color:color-mix(in srgb,var(--text) 88%,var(--muted) 12%);overflow-wrap:anywhere}
.log-meta-panel{margin-top:8px}
.log-meta-panel pre{margin:0;padding:10px;background:color-mix(in srgb,var(--surface-deep) 92%,transparent 8%);border-radius:8px;border:1px solid color-mix(in srgb,var(--border) 75%,transparent 25%);color:var(--text);overflow:auto;max-height:260px;box-shadow:inset 0 1px 0 rgba(255,255,255,.04)}

html[data-theme='light'] .log-prompt-section,
html[data-theme='light'] .log-input-section,
html[data-theme='light'] .log-table{box-shadow:0 18px 36px rgba(51,64,110,.16)}
html[data-theme='light'] .log-prompt-preview,
html[data-theme='light'] .log-input-body,
html[data-theme='light'] .log-meta-panel pre{border-color:color-mix(in srgb,var(--chip-border) 75%,transparent 25%);box-shadow:inset 0 1px 0 rgba(255,255,255,.7)}
html[data-theme='light'] .log-input-body img{box-shadow:0 12px 28px rgba(51,64,110,.18)}
html[data-theme='light'] .log-row{background:color-mix(in srgb,var(--panel) 90%,var(--surface-soft) 10%);box-shadow:none;border-color:color-mix(in srgb,var(--chip-border) 75%,transparent 25%)}
html[data-theme='light'] .log-row:hover{border-color:color-mix(in srgb,var(--brand) 45%,var(--chip-border) 55%);background:color-mix(in srgb,var(--surface-accent) 70%,#ffffff 30%);box-shadow:0 12px 28px rgba(51,64,110,.18)}
html[data-theme='light'] .log-row:focus{box-shadow:0 0 0 2px color-mix(in srgb,var(--brand) 45%,transparent 55%)}
html[data-theme='light'] .log-row.expanded{box-shadow:0 14px 32px rgba(51,64,110,.18);background:color-mix(in srgb,var(--surface-accent) 80%,#ffffff 20%);border-color:color-mix(in srgb,var(--brand) 55%,var(--chip-border) 45%)}
html[data-theme='light'] .log-time{color:color-mix(in srgb,var(--brand) 55%,var(--text) 45%)}
html[data-theme='light'] .log-level.level-info{color:color-mix(in srgb,var(--brand) 65%,var(--text) 35%)}
.filter-subrow{display:flex;align-items:center;gap:12px;margin:12px 0 12px;flex-wrap:wrap}
.filter-subrow .filter-label{font-size:13px;color:var(--subtle)}
.user-filter-controls{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.pillselect{appearance:none;border:1px solid var(--chip-border);background:var(--chip-bg);color:var(--chip-fg);padding:6px 18px;border-radius:999px;cursor:pointer;font-size:12px;line-height:1.2;min-height:28px;transition:border-color .2s ease,color .2s ease}
.pillselect:focus{outline:2px solid var(--brand);outline-offset:2px}
.pillbtn-clear{border-color:var(--chip-border);background:var(--chip-bg);color:var(--chip-fg);transition:border-color .2s ease,color .2s ease}
.pillbtn-clear:hover{border-color:var(--chip-hover-border);color:var(--chip-active-fg)}
.deleted-filter-controls{display:flex;align-items:center;gap:8px}
.deleted-filter-controls .filter-label{margin-right:0;color:var(--subtle)}
.card.card-hidden{opacity:.55;box-shadow:none}
.card.card-hidden::after{content:"Hidden";position:absolute;top:12px;right:12px;padding:2px 8px;border-radius:999px;background:rgba(148,163,255,.15);color:#cbd2ff;font-size:11px;letter-spacing:.08em;text-transform:uppercase;pointer-events:none}
