@import url('https://fonts.googleapis.com/css2?family=Syne:wght@400;600;700;800&family=Syne+Mono&family=DM+Sans:wght@300;400;500&display=swap');
:root {
  --bg:#080b12;--s1:#0e1219;--s2:#141824;--s3:#1a2030;
  --border:#232c3d;--border2:#2e3a52;
  --cyan:#41d1ff;--blue:#7b9cff;--green:#3ddc84;
  --yellow:#ffc043;--red:#ff6b6b;--violet:#c084fc;
  --text:#dce6f5;--dim:#5a6a88;--dim2:#8899bb;
  --tip-text:#dce6f5;--tip-bg:#1a2030;--tip-border:#41d1ff;--tip-offset:8px;--tip-max-width:280px;--tip-font-size:11px;
  --mono:'Syne Mono',monospace;--display:'Syne',sans-serif;--body:'DM Sans',sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{background:var(--bg);color:var(--text);font-family:var(--body);min-height:100vh;
  background-image:radial-gradient(ellipse 70% 50% at 15% 50%,rgba(65,209,255,.05) 0%,transparent 60%),
    radial-gradient(ellipse 50% 40% at 85% 20%,rgba(123,156,255,.04) 0%,transparent 60%)}
body::before{content:'';position:fixed;inset:0;pointer-events:none;
  background-image:linear-gradient(rgba(65,209,255,.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(65,209,255,.025) 1px,transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 30%,transparent 100%)}
body.hpf-compact-panel-active{background-image:none}
body.hpf-compact-panel-active::before{display:none}
body.hpf-compact-panel-active,
body.hpf-sidepanel-dim-backdrop{
  overflow-x:hidden;
}
body.hpf-compact-panel-active #appShell,
body.hpf-sidepanel-dim-backdrop #appShell{
  padding-right:0!important;
}
body.hpf-compact-panel-active .hpf-tip-popover,
body.hpf-sidepanel-dim-backdrop .hpf-tip-popover{
  display:none!important;
}
body.hpf-sidepanel-dim-backdrop #spOverlay.open{
  background:rgba(2,5,10,.76);
  backdrop-filter:brightness(.45);
}
body.hpf-sidepanel-dim-backdrop{background-image:none}
body.hpf-sidepanel-dim-backdrop::before{display:none}
@keyframes up{from{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}

/* LOGIN */
#loginScreen{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}
.login-card{background:var(--s1);border:1px solid var(--border2);border-top:3px solid var(--cyan);
  width:100%;max-width:420px;animation:up .35s cubic-bezier(.16,1,.3,1);position:relative}
.login-card::after{content:'';position:absolute;bottom:0;right:0;width:60px;height:60px;
  background:linear-gradient(135deg,transparent 50%,rgba(65,209,255,.06) 50%)}
.lc-head{padding:36px 36px 0;text-align:center}
.brand{font-family:var(--display);font-weight:800;font-size:28px;color:var(--text);
  letter-spacing:3px;display:flex;align-items:center;justify-content:center;gap:10px}
.brand-dot{width:8px;height:8px;border-radius:50%;background:var(--cyan);animation:pulse 2s infinite}
.brand-ac{color:var(--cyan)}
.brand-sub{font-family:var(--mono);font-size:10px;color:var(--dim);letter-spacing:3px;text-transform:uppercase;margin-top:6px}
.lc-body{padding:32px 36px 36px}
.lc-title{font-family:var(--display);font-weight:700;font-size:15px;color:var(--text);margin-bottom:24px}
.lang-row{display:flex;justify-content:flex-end;margin-bottom:20px}
.lang-tog{display:flex;border:1px solid var(--border2);border-radius:2px;overflow:hidden}
.lang-tog button{font-family:var(--mono);font-size:10px;letter-spacing:1px;padding:5px 12px;
  background:transparent;border:none;color:var(--dim);cursor:pointer;transition:all .15s}
.lang-tog button.active{background:var(--s3);color:var(--cyan)}
.err-box{background:rgba(255,107,107,.09);border:1px solid rgba(255,107,107,.3);
  border-left:3px solid var(--red);padding:10px 14px;font-family:var(--mono);font-size:11px;
  color:var(--red);margin-bottom:18px;display:none}
.err-box.on{display:block}
.field{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}
.field label{font-family:var(--mono);font-size:9px;letter-spacing:1.5px;text-transform:uppercase;color:var(--dim2)}
.field input,.field select,.field textarea{background:var(--s2);border:1px solid var(--border2);
  color:var(--text);font-family:var(--body);font-size:13px;padding:10px 12px;
  border-radius:3px;outline:none;transition:border-color .15s;width:100%}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--cyan)}
.field input::placeholder{color:var(--dim)}
.field select option{background:var(--s2)}
.field textarea{resize:vertical;min-height:60px}
.field .ferr{font-family:var(--mono);font-size:9px;color:var(--red);margin-top:3px;display:none}
.field .ferr.on{display:block}
.field input.err{border-color:var(--red)}
.hpf-tip{display:inline-flex;align-items:center;justify-content:center;width:13px;height:13px;
  margin-left:4px;border:1px solid var(--tip-border);border-radius:50%;background:rgba(255,255,255,.04);
  color:var(--tip-border);font-family:var(--mono);font-size:8px;line-height:1;cursor:help;
  position:relative;vertical-align:super;text-transform:none;letter-spacing:0}
.hpf-tooltips-off .hpf-tip{display:none}
.hpf-tip:hover,.hpf-tip:focus{background:rgba(255,255,255,.1);outline:none}
.hpf-tip::after{content:attr(data-tip);position:absolute;left:50%;bottom:calc(100% + var(--tip-offset));
  transform:translateX(-50%) translateY(4px);width:max-content;max-width:var(--tip-max-width);
  background:var(--tip-bg);border:1px solid var(--tip-border);color:var(--tip-text);padding:8px 10px;
  border-radius:2px;box-shadow:0 8px 24px rgba(0,0,0,.45);font-family:var(--body);
  font-size:var(--tip-font-size);line-height:1.35;text-align:left;white-space:normal;text-transform:none;
  letter-spacing:0;opacity:0;pointer-events:none;z-index:500;transition:opacity .12s,transform .12s}
.hpf-tip:hover::after,.hpf-tip:focus::after{opacity:1;transform:translateX(-50%) translateY(0)}
.hpf-tip.tip-open-right::after{left:0;right:auto;transform:translateY(4px)}
.hpf-tip.tip-open-right:hover::after,.hpf-tip.tip-open-right:focus::after{transform:translateY(0)}
.hpf-tip.tip-open-left::after{left:auto;right:0;transform:translateY(4px)}
.hpf-tip.tip-open-left:hover::after,.hpf-tip.tip-open-left:focus::after{transform:translateY(0)}
.hpf-js-tooltips .hpf-tip::after{display:none}
.hpf-tip-popover{position:fixed;z-index:3000;max-width:min(var(--tip-max-width),calc(100vw - 24px));
  background:var(--tip-bg);border:1px solid var(--tip-border);color:var(--tip-text);padding:8px 10px;
  border-radius:2px;box-shadow:0 8px 24px rgba(0,0,0,.45);font-family:var(--body);
  font-size:var(--tip-font-size);line-height:1.35;text-align:left;white-space:pre-line;text-transform:none;
  letter-spacing:0;opacity:0;pointer-events:none;transition:opacity .12s,transform .12s}
.hpf-tip-popover.on{opacity:1}
.hpf-hover-tip{transition:color .12s,border-color .12s}
.hpf-hover-tip:hover,.hpf-hover-tip:focus{color:#fff!important}
.hpf-tooltips-off .hpf-hover-tip{color:inherit!important}
.chk-group{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.chk-item{display:flex;align-items:center;gap:6px;cursor:pointer;padding:5px 10px;
  border:1px solid var(--border2);border-radius:2px;transition:all .15s;
  font-family:var(--mono);font-size:11px;color:var(--dim2)}
.chk-item:hover{border-color:var(--cyan);color:var(--text)}
.chk-item input[type=checkbox]{accent-color:var(--cyan);width:13px;height:13px;cursor:pointer}
.chk-item.checked{border-color:rgba(65,209,255,.5);background:rgba(65,209,255,.06);color:var(--cyan)}
.btn-login{width:100%;font-family:var(--display);font-weight:700;font-size:13px;
  letter-spacing:2px;text-transform:uppercase;padding:14px;background:var(--cyan);
  color:#000;border:none;cursor:pointer;transition:all .2s;margin-top:4px;overflow:hidden;position:relative}
.btn-login::after{content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);
  transform:translateX(-100%);transition:transform .4s}
.btn-login:hover::after{transform:translateX(100%)}
.btn-login:hover{background:#7be8ff;transform:translateY(-1px)}
.lc-foot{border-top:1px solid var(--border);padding:14px 36px;font-family:var(--mono);
  font-size:9px;color:var(--dim);display:flex;align-items:center;justify-content:space-between;letter-spacing:.5px}
.cf-dot{width:5px;height:5px;border-radius:50%;background:var(--green)}

/* APP SHELL */
#appShell{display:none;min-height:100vh;flex-direction:column}
.topbar{background:var(--s1);border-bottom:1px solid var(--border);padding:0 24px;
  display:flex;align-items:stretch;height:54px;position:sticky;top:0;z-index:50;flex-shrink:0}
.tb-logo{font-family:var(--display);font-weight:800;font-size:16px;color:var(--cyan);
  display:flex;align-items:center;gap:8px;padding-right:20px;
  border-right:1px solid var(--border);letter-spacing:1px;flex-shrink:0}
.tb-dot{width:6px;height:6px;border-radius:50%;background:var(--cyan);animation:pulse 2s infinite}
.tb-right{margin-left:auto;display:flex;align-items:center;gap:12px}
.tb-user-info{display:flex;flex-direction:column;align-items:flex-end;gap:1px}
.tb-name{font-family:var(--display);font-weight:600;font-size:13px;color:var(--text)}
.tb-role-label{font-family:var(--mono);font-size:9px;color:var(--dim2);letter-spacing:1px;text-transform:uppercase}
.tb-companies{font-family:var(--mono);font-size:9px;color:var(--cyan);letter-spacing:.5px}
.tb-avatar{width:32px;height:32px;border-radius:50%;background:var(--s3);
  border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;
  font-family:var(--display);font-weight:700;font-size:12px}
.btn-so{font-family:var(--mono);font-size:10px;padding:6px 12px;background:transparent;
  border:1px solid var(--border2);color:var(--dim2);cursor:pointer;border-radius:2px;transition:all .15s}
.btn-so:hover{border-color:var(--red);color:var(--red)}
.tab-nav{background:var(--s1);border-bottom:1px solid var(--border);
  padding:0 24px;display:flex;align-items:stretch;gap:0;overflow-x:auto;flex-shrink:0;position:relative}
.tab-nav.sticky-tabs{position:sticky;top:54px;z-index:49}
.tab-nav.sticky-tabs::before{content:'';position:absolute;left:0;right:0;top:-8px;height:8px;
  background:var(--s1);pointer-events:none}
.tab-btn{font-family:var(--mono);font-size:11px;letter-spacing:1px;text-transform:uppercase;
  padding:0 18px;height:44px;background:transparent;border:none;
  border-bottom:2px solid transparent;color:var(--dim2);cursor:pointer;
  transition:all .2s;display:flex;align-items:center;gap:8px;white-space:nowrap}
.tab-btn:hover{color:var(--text)}
.tab-btn.active{color:var(--cyan);border-bottom-color:var(--cyan)}
.tab-icon{font-size:14px}
.role-banner{margin:20px 24px 0;border:1px solid var(--border2);border-left:3px solid;
  padding:14px 18px;display:flex;align-items:flex-start;gap:14px;animation:up .3s ease}
.rb-admin{border-left-color:var(--violet);background:rgba(192,132,252,.05)}
.rb-operator{border-left-color:var(--cyan);background:rgba(65,209,255,.05)}
.rb-reviewer{border-left-color:var(--green);background:rgba(61,220,132,.05)}
.rb-readonly{border-left-color:var(--dim2);background:rgba(136,153,187,.05)}
.rb-icon{font-size:22px;flex-shrink:0;margin-top:1px}
.rb-role{font-family:var(--mono);font-size:9px;letter-spacing:2px;text-transform:uppercase;margin-bottom:4px;
  display:inline-flex;align-items:center;gap:7px}
.rb-admin .rb-role{color:var(--violet)} .rb-operator .rb-role{color:var(--cyan)}
.rb-reviewer .rb-role{color:var(--green)} .rb-readonly .rb-role{color:var(--dim2)}
.rb-name{font-family:var(--display);font-weight:700;font-size:16px;color:var(--text);margin-bottom:4px}
.rb-co{font-family:var(--mono);font-size:10px;color:var(--cyan);margin-bottom:6px}
.rb-desc{font-size:13px;color:var(--dim2);line-height:1.6}
.rb-perms{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.perm-tag{font-family:var(--mono);font-size:9px;letter-spacing:.5px;padding:3px 8px;
  border-radius:2px;border:1px solid;color:var(--green);border-color:rgba(61,220,132,.3);background:rgba(61,220,132,.08)}
.tab-content{flex:1;padding:24px;max-width:1300px;margin:0 auto;width:100%;transition:max-width .3s cubic-bezier(.16,1,.3,1)}
.sp-open-shift{/* deprecated — layout now via appShell padding-right */}
.tab-panel{display:none;animation:up .2s ease}
.tab-panel.active{display:block}

/* SHARED COMPONENTS */
.page-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px}
.page-title{font-family:var(--display);font-weight:800;font-size:22px;color:var(--text)}
.page-title span{color:var(--cyan)}
.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:10px;margin-bottom:20px}
.scard{background:var(--s1);border:1px solid var(--border);padding:14px;position:relative;overflow:hidden}
.scard::after{content:'';position:absolute;top:0;left:0;right:0;height:2px}
.sc-admin::after{background:var(--violet)} .sc-op::after{background:var(--cyan)}
.sc-rev::after{background:var(--green)} .sc-ro::after{background:var(--dim2)}
.sc-tot::after{background:var(--blue)} .sc-co::after{background:var(--yellow)}
.sc-fm::after{background:var(--green)} .sc-mag::after{background:var(--yellow)}
.sc-tbp::after{background:var(--blue)} .sc-ent::after{background:var(--dim2)}
.sc-l{font-family:var(--mono);font-size:9px;text-transform:uppercase;letter-spacing:1.5px;color:var(--dim);margin-bottom:5px}
.sc-v{font-family:var(--display);font-weight:700;font-size:26px;line-height:1;color:var(--text)}
.sc-s{font-family:var(--mono);font-size:9px;color:var(--dim2);margin-top:4px}
.filters{display:flex;align-items:center;gap:10px;margin-bottom:14px;flex-wrap:wrap}
.f-wrap{position:relative}
.f-select{background:var(--s2);border:1px solid var(--border2);color:var(--text);
  font-family:var(--mono);font-size:11px;padding:7px 28px 7px 10px;border-radius:2px;
  cursor:pointer;outline:none;appearance:none;-webkit-appearance:none;min-width:150px}
.f-select:focus{border-color:var(--cyan)}
.f-select option{background:var(--s2)}
.f-wrap::after{content:'▾';position:absolute;right:9px;top:50%;transform:translateY(-50%);
  color:var(--dim2);pointer-events:none;font-size:10px}
.search-inp{background:var(--s2);border:1px solid var(--border2);color:var(--text);
  font-family:var(--body);font-size:13px;padding:7px 12px;border-radius:2px;
  outline:none;transition:border-color .15s;min-width:200px}
.search-inp:focus{border-color:var(--cyan)}
.search-inp::placeholder{color:var(--dim)}
.f-count{font-family:var(--mono);font-size:10px;color:var(--dim);margin-left:auto}
.tbl-wrap{border:1px solid var(--border);overflow:hidden;margin-bottom:20px}
.utbl{width:100%;border-collapse:collapse}
.utbl thead tr{background:var(--s2);border-bottom:2px solid var(--border2)}
.utbl thead th{font-family:var(--mono);font-size:9px;letter-spacing:1.5px;text-transform:uppercase;
  color:var(--text);padding:10px 14px;text-align:left;white-space:nowrap;border-right:1px solid var(--border)}
.utbl thead th:last-child{border-right:none}
.utbl tbody tr{border-bottom:1px solid var(--border);transition:background .1s}
.utbl tbody tr:hover{background:rgba(255,255,255,.012)}
.utbl tbody tr.row-inactive{opacity:.45}
.utbl td{padding:11px 14px;vertical-align:middle;border-right:1px solid var(--border);font-size:13px}
.utbl td:last-child{border-right:none}
.u-cell{display:flex;align-items:center;gap:10px}
.u-av{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-family:var(--display);font-weight:700;font-size:12px;flex-shrink:0;border:1px solid var(--border2)}
.u-name{font-family:var(--display);font-weight:600;font-size:13px;color:var(--text)}
.u-email{font-family:var(--mono);font-size:10px;color:var(--dim2);margin-top:1px}
.u-companies{display:flex;gap:4px;flex-wrap:wrap;margin-top:3px}
.co-tag{font-family:var(--mono);font-size:9px;padding:2px 6px;border-radius:2px;border:1px solid}
.role-chip{font-family:var(--mono);font-size:9px;letter-spacing:1px;text-transform:uppercase;
  padding:3px 8px;border-radius:2px;border:1px solid;display:inline-flex;align-items:center;gap:4px}
.role-chip-btn{cursor:pointer;background:transparent}
.role-chip-btn:hover,.role-chip-btn:focus{filter:brightness(1.18);outline:none}
.role-chip.has-extra-rights{gap:6px}
.role-extra-mark{display:inline-flex;align-items:center;justify-content:center;width:13px;height:13px;
  border:1px solid currentColor;border-radius:50%;font-size:10px;line-height:13px;font-weight:700;
  padding:0;text-align:center;transform:translateY(-.5px)}
.rb-extra-mark{letter-spacing:0}
.rc-admin{color:var(--violet);border-color:rgba(192,132,252,.4);background:rgba(192,132,252,.08)}
.rc-operator{color:var(--cyan);border-color:rgba(65,209,255,.4);background:rgba(65,209,255,.08)}
.rc-reviewer{color:var(--green);border-color:rgba(61,220,132,.4);background:rgba(61,220,132,.08)}
.rc-readonly{color:var(--dim2);border-color:rgba(136,153,187,.4);background:rgba(136,153,187,.08)}
.sp{display:inline-flex;align-items:center;gap:5px;font-family:var(--mono);font-size:9px;
  letter-spacing:1px;text-transform:uppercase;padding:4px 10px;border-radius:2px;
  border:1px solid;cursor:pointer;transition:all .15s;background:transparent}
.sp-on{color:var(--green);border-color:rgba(61,220,132,.4)}
.sp-on:hover{background:rgba(61,220,132,.1)}
.sp-on::before{content:'●';font-size:7px}
.sp-off{color:var(--dim);border-color:var(--border2)}
.sp-off:hover{background:var(--s3)}
.sp-off::before{content:'○';font-size:7px}
.sp:disabled{opacity:.3;cursor:not-allowed}
.act-cell{display:flex;gap:6px;align-items:center}
.btn-sm{font-family:var(--mono);font-size:9px;letter-spacing:.5px;padding:5px 10px;
  background:transparent;border:1px solid var(--border2);color:var(--dim2);
  cursor:pointer;border-radius:2px;transition:all .15s}
.btn-sm:hover{border-color:var(--text);color:var(--text)}
.btn-sm.del:hover{border-color:var(--red);color:var(--red)}
.btn-sm:disabled{opacity:.3;cursor:not-allowed}

/* COMPANIES */
.co-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;margin-bottom:20px}
.co-card{background:var(--s1);border:1px solid var(--border);overflow:hidden;position:relative}
.co-stripe{position:absolute;top:0;left:0;right:0;height:3px}
.co-card-header{padding:16px 18px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;gap:10px}
.co-card-name{font-family:var(--display);font-weight:700;font-size:16px;color:var(--text)}
.co-card-code{font-family:var(--mono);font-size:10px;padding:3px 8px;border-radius:2px;letter-spacing:1px}
.co-card-body{padding:14px 18px}
.co-row{display:flex;align-items:center;justify-content:space-between;
  padding:6px 0;border-bottom:1px solid var(--border);font-size:12px}
.co-row:last-child{border-bottom:none}
.co-row-label{font-family:var(--mono);font-size:9px;color:var(--dim);text-transform:uppercase;letter-spacing:1px}
.co-row-val{font-family:var(--mono);font-size:12px;color:var(--text)}
.co-row-val.accent{color:var(--green)}
.co-card-footer{padding:12px 18px;border-top:1px solid var(--border);display:flex;gap:8px;background:var(--s2)}
.co-inactive{opacity:.5}
.br-item{display:flex;align-items:center;gap:8px;padding:5px 0;border-bottom:1px solid var(--border);font-family:var(--mono);font-size:10px}
.br-item:last-child{border-bottom:none}
.br-name{flex:1;color:var(--text)} .br-val{color:var(--green)} .br-unit{color:var(--dim2)}
.br-empty{font-family:var(--mono);font-size:10px;color:var(--dim);padding:8px 0;text-align:center}

/* FLIGHT LOG TAB */
.fl-section{margin-bottom:20px}
.api-warn{background:rgba(255,195,67,.08);border:1px solid rgba(255,195,67,.4);
  border-left:3px solid var(--yellow);padding:12px 16px;margin-bottom:16px;
  font-family:var(--mono);font-size:11px;color:var(--yellow);display:none}
.api-warn.on{display:block}
.upload-zone{border:2px dashed var(--border2);background:var(--s1);
  padding:40px 32px;text-align:center;cursor:pointer;transition:all .25s;position:relative;overflow:hidden}
.upload-zone.dragover{border-color:var(--cyan);background:rgba(65,209,255,.04);transform:scale(1.005)}
.uz-icon{font-size:32px;margin-bottom:10px;opacity:.5}
.uz-title{font-family:var(--display);font-weight:700;font-size:18px;color:var(--text);margin-bottom:6px}
.uz-sub{font-family:var(--mono);font-size:11px;color:var(--dim2);margin-bottom:14px}
.uz-types{display:flex;justify-content:center;gap:8px;flex-wrap:wrap}
.uz-type{font-family:var(--mono);font-size:9px;letter-spacing:1px;padding:3px 8px;border-radius:2px;border:1px solid var(--border2);color:var(--dim2)}
.uz-type.ok{color:var(--cyan);border-color:rgba(65,209,255,.4);background:rgba(65,209,255,.06)}
.file-queue{margin-top:14px}
.fq-item{background:var(--s2);border:1px solid var(--border);padding:10px 14px;margin-bottom:8px;
  display:flex;align-items:center;gap:12px;animation:up .2s ease}
.fq-thumb{width:40px;height:40px;object-fit:cover;border:1px solid var(--border2);border-radius:2px;flex-shrink:0;background:var(--s3)}
.fq-thumb-pdf{width:40px;height:40px;background:var(--s3);border:1px solid var(--border2);border-radius:2px;
  display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:9px;color:var(--red);flex-shrink:0}
.fq-info{flex:1;min-width:0}
.fq-name{font-family:var(--display);font-weight:600;font-size:13px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fq-meta{font-family:var(--mono);font-size:9px;color:var(--dim2);margin-top:2px}
.fq-status{font-family:var(--mono);font-size:10px}
.fqs-wait{color:var(--dim2)} .fqs-proc{color:var(--cyan)} .fqs-done{color:var(--green)} .fqs-err{color:var(--red)}
.prog-wrap{height:3px;background:var(--border);border-radius:2px;margin-top:6px;overflow:hidden}
.prog-bar{height:100%;border-radius:2px;transition:width .3s;background:linear-gradient(90deg,var(--cyan),var(--blue))}
.prog-bar.shimmer{background:linear-gradient(90deg,var(--cyan) 0%,var(--blue) 50%,var(--cyan) 100%);
  background-size:200% 100%;animation:shimmer 1.5s infinite}
.fq-rm{background:none;border:none;color:var(--dim);cursor:pointer;font-size:14px;padding:4px;transition:color .15s;flex-shrink:0}
.fq-rm:hover{color:var(--red)}
.extract-bar{display:flex;align-items:center;gap:12px;margin-top:14px;flex-wrap:wrap}
.btn-extract{font-family:var(--display);font-weight:700;font-size:13px;letter-spacing:2px;
  text-transform:uppercase;padding:12px 28px;background:var(--cyan);color:#000;
  border:none;cursor:pointer;transition:all .2s;position:relative;overflow:hidden}
.btn-extract::after{content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);
  transform:translateX(-100%);transition:transform .5s}
.btn-extract:hover::after{transform:translateX(100%)}
.btn-extract:hover:not(:disabled){background:#7be8ff;transform:translateY(-1px)}
.btn-extract:disabled{opacity:.3;cursor:not-allowed;transform:none}
.spinner{width:14px;height:14px;border:2px solid rgba(65,209,255,.3);border-top-color:var(--cyan);
  border-radius:50%;animation:spin .8s linear infinite;display:inline-block;vertical-align:middle;margin-right:6px}
.result-banner{padding:12px 16px;margin-bottom:14px;border:1px solid;display:flex;align-items:center;gap:10px;animation:up .2s ease}
.rb-ok{border-color:rgba(61,220,132,.4);background:rgba(61,220,132,.06);border-left:3px solid var(--green)}
.rb-warn{border-color:rgba(255,195,67,.4);background:rgba(255,195,67,.06);border-left:3px solid var(--yellow)}
.rb-err{border-color:rgba(255,107,107,.4);background:rgba(255,107,107,.06);border-left:3px solid var(--red)}
.rb-msg{flex:1;font-family:var(--mono);font-size:11px;line-height:1.6}
.src-bar{--src-row-h:17px;display:grid;grid-template-columns:minmax(520px,1fr) minmax(420px,1.25fr);gap:18px;
  margin-bottom:14px;align-items:start}
.src-dash-left{display:grid;grid-template-columns:1.45fr .75fr .9fr;border:1px solid var(--border2);
  border-left:3px solid var(--cyan);background:rgba(10,15,26,.55)}
.src-dash-workflow{display:grid;grid-template-columns:minmax(250px,.62fr) minmax(360px,1.38fr);gap:6px;
  background:rgba(0,0,0,.45);padding:0 12px 0;align-items:stretch}
.src-card{background:rgba(10,15,26,.65);border-right:1px solid var(--border2);
  min-height:104px;padding:11px 14px;box-sizing:border-box}
.src-card:last-child{border-right:none}
.src-card-title,.src-work-label,.src-history-title{font-family:var(--mono);font-size:9px;color:var(--cyan);
  text-transform:uppercase;letter-spacing:1.6px;line-height:var(--src-row-h)}
.src-card-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:18px}
.src-add-files{font-size:10px!important;padding:7px 12px!important;border-color:var(--cyan)!important;
  color:var(--cyan)!important;background:rgba(65,209,255,.06)!important}
.src-stat-row{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center;
  font-family:var(--mono);font-size:10px;color:var(--dim2);text-transform:uppercase;letter-spacing:1.2px;line-height:var(--src-row-h)}
.src-stat-value,.src-metric,.src-work-value{font-family:var(--mono);font-size:11px;color:var(--text);
  font-weight:700;background:none;border:none;padding:0;text-align:right}
.src-stat-value.ok{color:var(--green)}
.src-underlined{cursor:pointer;text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}
.src-underlined:hover{color:var(--text)!important}
.src-underlined:disabled{cursor:default;text-decoration:none;opacity:.7}
.src-work-card{border:1px solid var(--border2);border-left:3px solid var(--cyan);min-height:104px}
.src-work-grid{display:grid;grid-template-columns:1fr auto;gap:0 10px;align-items:center}
.src-work-label{font-size:10px;color:var(--dim2);letter-spacing:1.2px;text-align:left}
.src-work-label:first-child{color:var(--cyan)}
.src-work-value{color:var(--text);text-transform:uppercase;letter-spacing:.8px;line-height:var(--src-row-h)}
.src-history-card{border:1px solid var(--border2);min-height:104px;position:relative}
.src-history-title{font-size:8px;color:var(--cyan);margin-bottom:12px}
.src-mini-timeline{display:grid;gap:16px;padding:6px 10px}
.src-mini-lane{display:grid;grid-template-columns:22px repeat(3,1fr);align-items:center;gap:8px;
  font-family:var(--mono);font-size:8px;color:var(--dim)}
.src-mini-lane i{height:8px;width:8px;border:1px solid var(--cyan);border-radius:50%;justify-self:center;opacity:.35}
.src-mini-lane i.done{background:var(--green);border-color:var(--green);box-shadow:0 0 8px rgba(61,220,132,.45);opacity:1}
.src-event-bar{background:rgba(10,15,26,.82);border:1px solid var(--border2);
  color:var(--dim2);font-family:var(--mono);font-size:10px;letter-spacing:1px;text-transform:uppercase;
  padding:6px 10px;display:flex;justify-content:space-between;align-items:center;text-align:left}
.panel-event-bar{flex:1 1 420px;min-width:260px;max-width:720px;margin-right:10px;height:34px}
.src-assist-bar{grid-column:1/-1;border:1px solid var(--border2);background:rgba(10,15,26,.72);
  color:var(--dim2);font-family:var(--mono);font-size:9px;letter-spacing:1px;line-height:1.35;
  text-transform:uppercase;padding:6px 10px;min-height:28px;display:flex;align-items:center}
.src-assist-bar span{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.src-assist-bar.ready{border-color:rgba(65,209,255,.55);color:var(--cyan)}
.src-assist-bar.attn{border-color:rgba(255,195,67,.55);color:var(--yellow)}
.src-assist-bar.ok{border-color:rgba(61,220,132,.5);color:var(--green)}

/* ── WORKFLOW WIDGET v8.6.0 ─────────────────────────────────────────────── */
#workflowWidget{--ww-op:#22c55e;--ww-re:#facc15;--ww-cta:#41d1ff;overflow:hidden}
#workflowWidget .ww-empty{font-family:var(--mono);font-size:10px;color:var(--dim2);letter-spacing:1px;margin-top:18px}
.ww-timeline{position:relative;height:86px;padding:12px 12px 0 0}
.ww-lane{display:grid;grid-template-columns:24px 1fr;align-items:center;height:38px}
.ww-lane>span{font-family:var(--mono);font-size:8px;letter-spacing:1.2px;font-weight:700}
.ww-lane-op>span{color:var(--ww-op)}
.ww-lane-re>span{color:var(--ww-re)}
.ww-track{position:relative;height:38px}
.ww-track:before{content:"";position:absolute;left:0;right:0;top:50%;height:1px;background:rgba(138,169,207,.18)}
.ww-flow-svg{position:absolute;left:24px;right:12px;top:0;width:calc(100% - 36px);height:86px;pointer-events:none;overflow:visible}
.ww-flow{stroke-width:2;stroke-linecap:round;opacity:.62;vector-effect:non-scaling-stroke}
.ww-flow.green{stroke:var(--ww-op)}
.ww-flow.yellow{stroke:var(--ww-re)}
.ww-flow.cyan{stroke:var(--ww-cta)}
.ww-node{position:absolute;top:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:2px}
.ww-node i{display:block;width:8px;height:8px;border-radius:50%;box-sizing:border-box}
.ww-dot-green{background:var(--ww-op);border:2px solid var(--ww-op)}
.ww-dot-yellow{background:var(--ww-re);border:2px solid var(--ww-re)}
.ww-dot-cyan{background:var(--ww-cta);border:2px solid var(--ww-cta)}
.ww-ring-green{background:transparent;border:2px solid var(--ww-op);opacity:.35}
.ww-ring-yellow{background:transparent;border:2px solid var(--ww-re);opacity:.35}
.ww-ring-cyan{background:transparent;border:2px solid var(--ww-cta);opacity:.35}
.ww-node.current i{box-shadow:0 0 8px 2px currentColor}
.ww-node.active:hover i{box-shadow:0 0 8px 2px currentColor}
.ww-node[data-color="green"]{color:var(--ww-op)}
.ww-node[data-color="yellow"]{color:var(--ww-re)}
.ww-node[data-color="cyan"]{color:var(--ww-cta)}
.ww-node b{font-family:var(--mono);font-size:7px;font-weight:700;letter-spacing:.4px;white-space:nowrap;text-transform:uppercase}
.ww-node b.green{color:var(--ww-op)}
.ww-node b.yellow{color:var(--ww-re)}
.ww-node b.cyan{color:var(--ww-cta)}
.ww-node b.hidden{display:none}
.wf-event-card{display:grid;gap:8px;padding:10px 0 12px;border-bottom:1px solid var(--border2);
  border-left:3px solid var(--cyan);padding-left:10px}
.wf-event-card.op{border-left-color:var(--green)}
.wf-event-card.re{border-left-color:var(--yellow)}
.wf-event-head{display:flex;align-items:center;justify-content:space-between;gap:12px}
.wf-event-pill{font-family:var(--mono);font-size:10px;letter-spacing:1px;text-transform:uppercase;
  color:var(--text);font-weight:800}
.wf-event-card.op .wf-event-pill{color:var(--green)}
.wf-event-card.re .wf-event-pill{color:var(--yellow)}
.wf-event-time{font-family:var(--mono);font-size:9px;color:var(--dim2);letter-spacing:.5px;text-align:right}
.wf-event-grid{display:grid;grid-template-columns:1.2fr 1fr 64px;gap:10px}
.wf-event-grid div,.wf-event-detail{display:grid;gap:2px;min-width:0}
.wf-event-card b{font-family:var(--mono);font-size:8px;letter-spacing:1.1px;text-transform:uppercase;
  color:var(--dim2);font-weight:700}
.wf-event-card span{font-family:var(--mono);font-size:10px;line-height:1.35;color:var(--text);
  letter-spacing:.4px;overflow:hidden;text-overflow:ellipsis}
.wf-event-detail span{white-space:normal;color:var(--dim)}
/* ── END WORKFLOW WIDGET ─────────────────────────────────────────────────── */
.alert{display:none;border:1px solid;padding:10px 14px;margin-bottom:12px;font-size:12px;line-height:1.6}
.alert.on{display:block}
.al-horo{border-color:rgba(255,107,107,.4);background:rgba(255,107,107,.06);border-left:3px solid var(--red)}
.al-title{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--red);margin-bottom:4px}
.toolbar{display:flex;align-items:center;gap:8px;margin-bottom:12px;flex-wrap:wrap}
.sec-title{font-family:var(--mono);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--dim2)}
.review-toolbar-title{display:none}
.toolbar-right{display:flex;align-items:center;gap:8px;margin-left:auto;flex-wrap:wrap}
.panel-tabs{display:flex;border-bottom:1px solid var(--border);gap:0}
.filter-control{display:flex;align-items:center;gap:8px;margin-right:10px}
.filter-glyph{position:relative;width:18px;height:16px;color:var(--dim2);flex:0 0 auto}
.filter-glyph::before{content:"";position:absolute;inset:1px 1px 0 1px;
  background:currentColor;clip-path:polygon(0 0,100% 0,62% 48%,62% 100%,38% 100%,38% 48%)}
.filter-glyph::after{content:"";position:absolute;inset:3px 4px 4px 4px;
  background:var(--bg);clip-path:polygon(0 0,100% 0,58% 46%,58% 100%,42% 100%,42% 46%)}
.filter-control:hover .filter-glyph{color:var(--cyan)}
.panel-filter-wrap{margin-right:0}
.ptab{font-family:var(--mono);font-size:10px;letter-spacing:1px;text-transform:uppercase;
  padding:10px 22px 10px 22px;background:transparent;border:none;border-left:1px solid rgba(138,169,207,.28);
  border-bottom:2px solid transparent;color:var(--dim2);cursor:pointer;transition:all .2s;position:relative}
.ptab:last-of-type{border-right:1px solid rgba(138,169,207,.28)}
.ptab::before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:rgba(138,169,207,.35);
  transition:background .2s,box-shadow .2s}
.ptab.active::before{background:var(--cyan);box-shadow:0 0 6px rgba(65,209,255,.45)}
.ptab.active{color:var(--cyan);border-bottom-color:var(--cyan)}
.ptab:hover:not(.active){color:var(--text)}
.ptab:hover:not(.active)::before{background:var(--text)}
.ptab-count{display:inline-flex;align-items:center;justify-content:center;
  width:18px;height:18px;border-radius:50%;background:var(--s3);font-size:9px;margin-left:6px;color:var(--dim2)}
.ptab.active .ptab-count{background:rgba(65,209,255,.15);color:var(--cyan)}
.panel-content{border:1px solid var(--border);border-top:none;margin-bottom:20px}
.ppanel{display:none}
.ppanel.active{display:block}
.fl-tbl-wrap{overflow-x:auto;border:none;margin-bottom:0}
table.fl-tbl{width:100%;border-collapse:separate;border-spacing:0}
table.fl-tbl thead tr{background:var(--s2)}
table.fl-tbl thead tr:nth-child(1) th{border-top:2px solid var(--border2)}
table.fl-tbl thead tr:nth-child(2) th{border-bottom:2px solid var(--border2)}
table.fl-tbl thead th{font-family:var(--mono);font-size:9px;letter-spacing:1.5px;text-transform:uppercase;
  color:var(--text);padding:9px 10px;text-align:left;white-space:nowrap;border-right:1px solid var(--border)}
table.fl-tbl thead th:last-child{border-right:none}
table.fl-tbl th.gm{border-top:2px solid var(--blue);color:var(--blue)}
table.fl-tbl th.gf{border-top:2px solid var(--cyan);color:var(--cyan)}
table.fl-tbl th.gb{border-top:2px solid var(--green);color:var(--green)}
table.fl-tbl tbody tr{border-bottom:1px solid var(--border);transition:background .1s}
table.fl-tbl tbody tr:hover{background:rgba(255,255,255,.012)}
table.fl-tbl tbody tr.r-ok{background:rgba(61,220,132,.03)}
table.fl-tbl tbody tr.r-rej{background:rgba(255,107,107,.03);opacity:.55}
table.fl-tbl tbody tr.r-skipped{background:rgba(120,120,140,.06)}
table.fl-tbl tbody tr.r-pending{background:transparent}
table.fl-tbl td{padding:8px 10px;vertical-align:middle;border-right:1px solid var(--border);
  font-family:var(--mono);font-size:11px;color:var(--text)}
table.fl-tbl td:last-child{border-right:none}
.cx{color:var(--cyan)} .cb{color:var(--blue)} .cg{color:var(--green)} .cd{color:var(--dim2)}
.horo-ind{font-size:9px;margin-top:2px}
.hi-ok{color:var(--green)} .hi-gap{color:var(--red)}
.t3{display:flex;border:1px solid var(--border2);border-radius:2px;overflow:hidden;width:fit-content}
.t3 button{font-family:var(--mono);font-size:9px;padding:4px 8px;background:transparent;
  border:none;border-right:1px solid var(--border2);cursor:pointer;color:var(--dim);transition:all .15s}
.t3 button:last-child{border-right:none}
.t3 button.tp{background:rgba(255,195,67,.15);color:var(--yellow)}
.t3 button.tok{background:rgba(61,220,132,.15);color:var(--green)}
.t3 button.tr{background:rgba(255,107,107,.15);color:var(--red)}
.t3 button:hover:not(.tp):not(.tok):not(.tr){color:var(--text);background:var(--s3)}
.t3 button:disabled{opacity:.3;cursor:not-allowed}
.btn-edit-r{font-family:var(--mono);font-size:9px;padding:4px 8px;background:transparent;
  border:1px solid var(--border2);color:var(--dim2);cursor:pointer;border-radius:2px;transition:all .15s}
.btn-edit-r:hover{border-color:var(--cyan);color:var(--cyan)}
.btn-edit-r:disabled{opacity:.3;cursor:not-allowed}
.sum-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;margin-bottom:20px}
.action-bar{background:var(--s1);border:1px solid var(--border);padding:14px 16px;
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:20px}
.action-note{font-family:var(--mono);font-size:10px;color:var(--dim);margin-left:auto}
.wf-bar{background:var(--s1);border:1px solid var(--border);border-left:3px solid var(--border2);
  padding:0 16px;display:flex;align-items:center;gap:0;overflow-x:auto;margin-bottom:16px}
.wf-step{display:flex;align-items:center;gap:8px;padding:10px 12px;
  font-family:var(--mono);font-size:10px;letter-spacing:1px;text-transform:uppercase;
  color:var(--dim);white-space:nowrap;border-bottom:2px solid transparent;transition:all .2s}
.wf-step.done{color:var(--green)} .wf-step.active{color:var(--cyan);border-bottom-color:var(--cyan)}
.wf-step.locked{color:var(--dim);opacity:.55}
.wf-dot{width:7px;height:7px;border-radius:50%;border:1px solid currentColor;flex-shrink:0}
.wf-step.done .wf-dot{background:var(--green);border-color:var(--green)}
.wf-step.active .wf-dot{background:var(--cyan);border-color:var(--cyan);animation:pulse 1.5s infinite}
.wf-cta-step{border:1px solid var(--border2);margin-left:8px;padding:7px 18px}
.wf-cta-step.active{cursor:pointer;border-color:var(--cyan)}
.wf-cta-step.active:hover{background:rgba(65,209,255,.12)}
.wf-arrow{color:var(--border2);padding:0 2px;font-size:10px}
.audit-wrap{max-height:300px;overflow-y:auto}
.ae{display:flex;align-items:flex-start;gap:12px;padding:9px 14px;border-bottom:1px solid var(--border);font-size:12px}
.ae:last-child{border-bottom:none}
.ae:hover{background:rgba(255,255,255,.01)}
.ae-ts{font-family:var(--mono);font-size:9px;color:var(--dim);white-space:nowrap;padding-top:1px;min-width:110px}
.ae-body{flex:1;line-height:1.5}
.ae-actor{font-family:var(--display);font-weight:600;color:var(--cyan);margin-right:4px}
.ae-action{color:var(--dim2)}
.ae-diff{font-family:var(--mono);font-size:9px;color:var(--dim);background:var(--s2);
  padding:2px 6px;border-radius:2px;margin-top:3px;display:inline-block}
.audit-empty{padding:20px;text-align:center;font-family:var(--mono);font-size:11px;color:var(--dim)}

/* SETTINGS TAB */
.settings-section{max-width:600px}
.settings-card{background:var(--s1);border:1px solid var(--border);border-top:2px solid var(--violet);padding:24px;margin-bottom:16px}
.settings-card-title{font-family:var(--display);font-weight:700;font-size:15px;color:var(--violet);margin-bottom:16px;display:flex;align-items:center;gap:8px}
.api-status{font-family:var(--mono);font-size:10px;padding:4px 10px;border-radius:2px;border:1px solid;display:inline-flex;align-items:center;gap:5px}
.api-ok{color:var(--green);border-color:rgba(61,220,132,.4);background:rgba(61,220,132,.08)}
.api-ok::before{content:'●';font-size:7px}
.api-missing{color:var(--yellow);border-color:rgba(255,195,67,.4);background:rgba(255,195,67,.08)}
.api-missing::before{content:'○';font-size:7px}
.settings-hint{font-family:var(--mono);font-size:10px;color:var(--dim);margin-top:8px;line-height:1.6}

/* COMING SOON */
.coming-soon{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:350px;gap:12px;text-align:center}
.cs-icon{font-size:40px;opacity:.3}
.cs-title{font-family:var(--display);font-weight:700;font-size:18px;color:var(--dim2)}
.cs-sub{font-family:var(--mono);font-size:10px;color:var(--dim);letter-spacing:2px;text-transform:uppercase}

/* BUTTONS */
.btn-primary{font-family:var(--display);font-weight:700;font-size:12px;letter-spacing:1px;
  text-transform:uppercase;padding:10px 22px;background:var(--cyan);color:#000;
  border:none;cursor:pointer;border-radius:2px;transition:all .2s}
.btn-primary:hover{background:#7be8ff;transform:translateY(-1px)}
.btn-ghost{font-family:var(--mono);font-size:11px;padding:8px 16px;background:transparent;
  border:1px solid var(--border2);color:var(--dim2);cursor:pointer;border-radius:2px;transition:all .15s}
.btn-ghost:hover{border-color:var(--text);color:var(--text)}
.btn-ghost:disabled{opacity:.3;cursor:not-allowed}
.btn-success{font-family:var(--display);font-weight:700;font-size:12px;letter-spacing:1px;
  text-transform:uppercase;padding:10px 20px;background:var(--green);color:#000;
  border:none;cursor:pointer;border-radius:2px;transition:all .2s}
.btn-success:hover:not(:disabled){background:#6fffa8;transform:translateY(-1px)}
.btn-success:disabled{opacity:.25;cursor:not-allowed}
.btn-warn{font-family:var(--display);font-weight:700;font-size:12px;letter-spacing:1px;
  text-transform:uppercase;padding:10px 20px;background:var(--yellow);color:#000;
  border:none;cursor:pointer;border-radius:2px;transition:all .2s}
.btn-warn:hover:not(:disabled){background:#ffd166}
.btn-warn:disabled{opacity:.25;cursor:not-allowed}
.btn-danger{font-family:var(--display);font-weight:700;font-size:12px;letter-spacing:1px;
  text-transform:uppercase;padding:10px 20px;background:var(--red);color:#fff;
  border:none;cursor:pointer;border-radius:2px;transition:all .2s}
.btn-danger:hover{background:#ff8f8f}

/* MODALS */
.mbd{display:none;position:fixed;inset:0;background:rgba(0,0,0,.78);backdrop-filter:blur(4px);
  z-index:200;align-items:center;justify-content:center;padding:20px}
.mbd.open{display:flex}
.mbox{background:var(--s1);border:1px solid var(--border2);width:100%;max-height:90vh;overflow-y:auto;animation:up .2s ease}
.mbox.user-box{max-width:540px;border-top:2px solid var(--cyan)}
.mbox.co-box{max-width:520px;border-top:2px solid var(--yellow)}
.mbox.fl-box{max-width:620px;border-top:2px solid var(--cyan)}
.mbox.role-rights-box{max-width:820px;border-top:2px solid var(--violet)}
.mbox.confirm-box{max-width:460px;border-top:2px solid var(--green)}
.mbox.exc-box{max-width:440px;border-top:2px solid var(--yellow)}
.mbox.req-box{max-width:400px;border-top:2px solid var(--violet)}
.mbox.del-box{max-width:420px;border-top:2px solid var(--red)}
.mhdr{display:flex;align-items:center;justify-content:space-between;padding:15px 20px;border-bottom:1px solid var(--border)}
.mhdr-t{font-family:var(--display);font-weight:700;font-size:15px}
.mhdr-t.ct{color:var(--cyan)} .mhdr-t.cy{color:var(--yellow)} .mhdr-t.cg{color:var(--green)}
.mhdr-t.cv{color:var(--violet)} .mhdr-t.cr{color:var(--red)}
.m-x{background:none;border:none;color:var(--dim);font-size:18px;cursor:pointer;padding:4px;line-height:1;transition:color .15s}
.m-x:hover{color:var(--text)}
.mbody{padding:20px}
.role-rights-head{display:flex;align-items:flex-start;gap:14px;padding:12px 14px;border:1px solid var(--border);
  background:var(--s2);margin-bottom:14px}
.role-rights-icon{width:34px;height:34px;border:1px solid var(--border2);display:flex;align-items:center;
  justify-content:center;background:var(--s1);font-size:18px;flex-shrink:0}
.role-rights-role{font-family:var(--display);font-weight:700;font-size:16px;color:var(--text);margin-bottom:4px}
.role-rights-desc{font-size:13px;color:var(--dim2);line-height:1.5}
.role-rights-user{font-family:var(--mono);font-size:10px;color:var(--cyan);margin-top:6px;letter-spacing:.6px}
.role-rights-mode{margin-left:auto;font-family:var(--mono);font-size:9px;letter-spacing:1.2px;text-transform:uppercase;
  color:var(--green);border:1px solid rgba(61,220,132,.5);padding:6px 10px;background:rgba(61,220,132,.08);white-space:nowrap}
.role-rights-mode.custom{color:var(--yellow);border-color:rgba(255,192,67,.55);background:rgba(255,192,67,.09)}
.role-rights-note{font-family:var(--mono);font-size:10px;line-height:1.5;color:var(--dim2);margin-bottom:12px}
.role-rights-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.25fr);gap:12px}
.role-rights-panel{border:1px solid var(--border);background:rgba(20,24,36,.65);padding:12px}
.role-rights-sub{font-family:var(--mono);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--dim2);
  margin-bottom:10px}
.role-rights-current{display:grid;gap:10px}
.role-rights-current-group{display:grid;gap:6px}
.role-rights-current-title,.role-rights-group-title{font-family:var(--mono);font-size:9px;letter-spacing:1.8px;
  text-transform:uppercase;color:var(--dim);padding-bottom:4px;border-bottom:1px solid var(--border)}
.role-rights-pills{display:flex;flex-wrap:wrap;gap:6px}
.role-rights-pill{font-family:var(--mono);font-size:9px;color:var(--text);border:1px solid rgba(65,209,255,.38);
  background:rgba(65,209,255,.08);padding:5px 7px}
.role-rights-empty{font-family:var(--mono);font-size:10px;color:var(--dim);padding:10px;border:1px dashed var(--border)}
.role-rights-select{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.role-rights-group{display:grid;gap:6px;align-content:start}
.role-rights-check{display:flex;align-items:center;gap:8px;border:1px solid var(--border);background:var(--s2);
  padding:7px 8px;font-family:var(--mono);font-size:10px;color:var(--text);cursor:pointer;min-height:34px}
.role-rights-check input{accent-color:var(--cyan);width:15px;height:15px;flex:0 0 auto}
.role-rights-check:hover{border-color:rgba(65,209,255,.55)}
.role-rights-check.disabled{cursor:default;opacity:.7}
.role-rights-check.disabled:hover{border-color:var(--border)}
@media(max-width:760px){
  .role-rights-grid,.role-rights-select{grid-template-columns:1fr}
  .role-rights-head{flex-wrap:wrap}
  .role-rights-mode{margin-left:48px}
}
.mftr{padding:14px 20px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}
.frow{display:grid;gap:10px;margin-bottom:12px}
.fc1{grid-template-columns:1fr} .fc2{grid-template-columns:1fr 1fr} .fc3{grid-template-columns:1fr 1fr 1fr}
.fg-title{font-family:var(--mono);font-size:9px;letter-spacing:2px;text-transform:uppercase;
  color:var(--dim);margin:14px 0 10px;padding-bottom:5px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:6px}
.fg-dot{width:6px;height:6px;border-radius:50%;display:inline-block}
.calc-prev{background:var(--s2);border:1px solid var(--border);padding:12px 14px;margin-top:12px;
  display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:10px}
.cp-l{font-family:var(--mono);font-size:9px;color:var(--dim);text-transform:uppercase;letter-spacing:1px;margin-bottom:3px}
.cp-v{font-family:var(--mono);font-size:13px;color:var(--cyan);font-weight:500}
.cp-v.bill{color:var(--green)}
.cstats{background:var(--s2);border:1px solid var(--border);padding:12px 14px;margin-top:12px;
  font-family:var(--mono);font-size:11px;line-height:2}
.cs-ok{color:var(--green)} .cs-w{color:var(--yellow)} .cs-c{color:var(--cyan)} .cs-d{color:var(--dim2);font-size:10px;margin-top:4px}
.exc-warn{background:rgba(255,195,67,.08);border:1px solid rgba(255,195,67,.3);border-left:3px solid var(--yellow);
  padding:12px 14px;font-family:var(--mono);font-size:12px;color:var(--yellow);margin-bottom:12px}
.exc-detail{font-family:var(--mono);font-size:11px;color:var(--dim2);line-height:1.8}
.del-warn{background:rgba(255,107,107,.08);border:1px solid rgba(255,107,107,.3);
  border-left:3px solid var(--red);padding:12px 14px;font-size:13px;line-height:1.7;color:var(--text)}
.del-warn strong{color:var(--red);font-family:var(--mono)}
.pwd-hint{font-family:var(--mono);font-size:9px;color:var(--dim);margin-top:4px}
.section-divider{font-family:var(--mono);font-size:9px;letter-spacing:2px;text-transform:uppercase;
  color:var(--dim);margin:16px 0 10px;padding-bottom:6px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:6px}
.req-textarea{background:var(--s2);border:1px solid var(--border2);color:var(--text);
  font-family:var(--body);font-size:13px;padding:10px 12px;border-radius:2px;outline:none;
  width:100%;resize:vertical;min-height:100px;transition:border-color .15s}
.req-textarea:focus{border-color:var(--violet)}
.req-label{font-family:var(--mono);font-size:9px;letter-spacing:1px;text-transform:uppercase;
  color:var(--dim2);display:block;margin-bottom:6px}

/* TOAST */
.toast{position:fixed;bottom:20px;right:20px;background:var(--s2);border:1px solid var(--border2);
  border-left:3px solid var(--green);padding:10px 16px;font-family:var(--mono);font-size:11px;
  color:var(--text);z-index:9999;transform:translateX(130%);transition:transform .3s ease;max-width:300px;border-radius:2px}
.toast.on{transform:translateX(0)}
.toast.warn{border-left-color:var(--yellow)}
.toast.err{border-left-color:var(--red)}
.toast.info{border-left-color:var(--blue)}

/* EXTRACTION TERMINAL */
.upload-terminal{display:none;position:fixed;top:72px;left:72px;z-index:400;
  width:min(760px,calc(100vw - 96px));height:min(520px,calc(100vh - 120px));
  min-width:360px;min-height:220px;background:#050b0f;border:1px solid rgba(52,211,153,.65);
  border-radius:3px;box-shadow:0 10px 34px rgba(0,0,0,.55);flex-direction:column;
  resize:both;overflow:hidden}
.upload-terminal-hdr{display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:10px 12px;background:#050b0f;border-bottom:1px solid rgba(52,211,153,.45);
  flex-shrink:0;cursor:move}
.upload-terminal-title{font-family:var(--mono);font-size:11px;color:var(--green);
  letter-spacing:1px;font-weight:700}
.upload-terminal-actions{display:flex;gap:8px;align-items:center}
.upload-terminal-btn{background:rgba(52,211,153,.08);border:1px solid rgba(52,211,153,.6);
  color:var(--green);font-family:var(--mono);font-size:10px;padding:5px 10px;
  cursor:pointer;border-radius:2px}
.upload-terminal-btn:hover{background:rgba(52,211,153,.18);color:var(--text)}
.upload-terminal-body{flex:1;overflow:auto;padding:12px 16px;font-family:var(--mono);
  font-size:10px;color:var(--green);line-height:1.75;min-height:0}
.upload-terminal-body::-webkit-scrollbar-thumb{background:rgba(52,211,153,.65)}
.upload-terminal-body::-webkit-scrollbar-track{background:#050b0f}

::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:var(--s1)}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}
@media(max-width:768px){
  /* M1 — Topbar: hide user info text, compress layout */
  .topbar{padding:0 12px;height:48px}
  .tb-logo{font-size:13px;padding-right:12px}
  .tb-user-info{display:none}
  .tb-right{gap:8px}
  .btn-so{font-size:9px;padding:5px 8px}

  /* M2 — Tab nav: smaller padding, scroll indicator fade */
  .tab-nav{padding:0 8px;-webkit-overflow-scrolling:touch}
  .tab-nav.sticky-tabs{top:48px}
  .tab-nav::after{content:'';position:sticky;right:0;width:24px;flex-shrink:0;
    background:linear-gradient(to right,transparent,var(--s1));pointer-events:none}
  .tab-btn{padding:0 10px;font-size:10px;letter-spacing:.5px;height:40px;gap:5px}
  .tab-icon{font-size:12px}

  /* M3 — Table: reduce min-width, smaller cells */
  .fl-tbl{min-width:800px}
  table.fl-tbl td{padding:6px 7px;font-size:10px}
  table.fl-tbl thead th{padding:7px 7px;font-size:8px}
  .fl-tbl-wrap.sticky-active{max-height:calc(100vh - 280px)!important}

  /* M4 — Side panel: full width on mobile */
  .side-panel{width:100%!important;min-width:unset!important}

  /* M5 — srcBar: wrap items */
  .src-bar{grid-template-columns:1fr}
  .src-dash-left,.src-dash-workflow{grid-template-columns:1fr}
  .src-card{border-right:none;border-bottom:1px solid var(--border2)}
  .src-card:last-child{border-bottom:none}

  /* M6 — Page header */
  .page-hdr{margin-bottom:14px;gap:8px}
  .page-title{font-size:18px}

  /* M7 — Review controls: wrap cleanly */
  .toolbar{gap:6px}
  .f-select{min-width:120px;font-size:10px}
  .btn-ghost{font-size:10px;padding:7px 10px}
  .btn-primary{font-size:11px;padding:8px 14px}

  /* M8 — Modals: full width, single column */
  .mbd{padding:10px}
  .mbox{max-width:100%!important;max-height:95vh}
  .fc2,.fc3{grid-template-columns:1fr}
  .mbody{padding:14px}
  .mhdr{padding:12px 14px}
  .mftr{padding:10px 14px}

  /* M9 — Sticky headers offset */
  .fl-tbl-wrap.sticky-active{max-height:calc(100vh - 240px)!important}

  /* M10 — Float dialogs: touch-friendly, JS-centered and draggable */
  .float-dialog{min-width:min(300px,calc(100vw - 56px))!important;
    max-width:calc(100vw - 32px)!important;width:min(420px,calc(100vw - 56px))!important}

  /* M11 — Touch targets: minimum 44px height on action buttons */
  .btn-primary,.btn-ghost,.btn-success,.btn-warn,.btn-danger{min-height:44px}
  .t3 button{padding:8px 10px;min-height:36px}

  /* M12 — Settings */
  .settings-section{max-width:100%}
  .settings-card{padding:16px}

  /* M13 — Role badge bar */
  .rb-perms{gap:4px}
  .perm-tag{font-size:8px;padding:2px 6px}

  /* M14 — Batch selector */
  #batchSelector{max-width:100%!important;width:100%}
  .page-hdr .f-wrap{width:100%}
  .page-hdr .f-wrap .f-select{width:100%;min-width:unset}

  /* M15 — WF Bar steps */
  .wf-bar{flex-wrap:wrap;padding:0 8px}
  .wf-step{padding:8px 8px;font-size:9px}

  /* General spacing */
  .tab-content{padding:12px}
  .stats-row{grid-template-columns:1fr 1fr}
  .co-grid{grid-template-columns:1fr}
  .sum-grid{grid-template-columns:1fr 1fr}
  .role-banner{margin:12px 12px 0}
  .panel-content{border-left:none;border-right:none}
}

/* BATCH CONSTANTS */
.batch-constants{background:var(--s2);border:1px solid var(--border);
  border-left:3px solid var(--violet);padding:14px 16px;margin-bottom:14px;
  display:flex;align-items:flex-end;gap:12px;flex-wrap:wrap}
.bc-title{font-family:var(--mono);font-size:9px;letter-spacing:2px;
  text-transform:uppercase;color:var(--violet);margin-bottom:8px}
.bc-field{display:flex;flex-direction:column;gap:4px;min-width:140px}
.bc-field label{font-family:var(--mono);font-size:9px;letter-spacing:1px;
  text-transform:uppercase;color:var(--dim2)}
.bc-field select,.bc-field input{background:var(--s1);border:1px solid var(--border2);
  color:var(--text);font-family:var(--mono);font-size:12px;padding:7px 10px;
  border-radius:2px;outline:none;transition:border-color .15s;width:100%}
.bc-field select:focus,.bc-field input:focus{border-color:var(--violet)}
.bc-field select option{background:var(--s2)}
.bc-locked{border-color:rgba(192,132,252,.4) !important;color:var(--violet) !important}
.bc-hint{font-family:var(--mono);font-size:9px;color:var(--dim);
  margin-top:12px;align-self:flex-end;padding-bottom:2px}

/* SOURCE IMAGE SIDE PANEL */
.side-panel{position:fixed;top:0;right:0;width:420px;height:100vh;
  background:var(--s1);border-left:1px solid var(--border2);
  z-index:100;transition:transform .3s cubic-bezier(.16,1,.3,1);
  display:flex;flex-direction:column;overflow:hidden;
  transform:translateX(100%);user-select:none;-webkit-user-select:none}
.side-panel input,.side-panel textarea,.side-panel select,.side-panel option{
  user-select:text;-webkit-user-select:text}
.side-panel button{user-select:none;-webkit-user-select:none}
.side-panel.open{transform:translateX(0)}
.sp-header{padding:14px 16px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.sp-title{font-family:var(--mono);font-size:11px;letter-spacing:1px;
  text-transform:uppercase;color:var(--cyan)}
.sp-close{background:none;border:none;color:var(--dim);font-size:18px;
  cursor:pointer;padding:4px;transition:color .15s}
.sp-close:hover{color:var(--text)}
.sp-meta{padding:10px 16px;border-bottom:1px solid var(--border);
  font-family:var(--mono);font-size:10px;color:var(--dim2);flex-shrink:0}
.sp-img-wrap{overflow:hidden;padding:8px;display:flex;
  align-items:center;justify-content:center;position:relative;
  min-height:150px;flex-shrink:0;touch-action:pan-y}
.sp-img-wrap img{max-width:100%;max-height:100%;object-fit:contain;
  border:1px solid var(--border);border-radius:2px;display:block}
.sp-img-wrap{cursor:grab}
.sp-img-wrap:active{cursor:grabbing}
.sp-swipe-cue{position:absolute;top:50%;transform:translateY(-50%) scale(.92);
  width:82px;height:82px;border-radius:50%;background:rgba(10,18,28,.58);
  border:1px solid rgba(65,209,255,.38);color:rgba(220,246,255,.88);
  display:flex;align-items:center;justify-content:center;font-size:70px;
  line-height:1;font-family:var(--mono);font-weight:300;opacity:0;
  pointer-events:none;z-index:7;text-shadow:0 0 18px rgba(65,209,255,.55)}
.sp-swipe-cue.prev{left:22px}
.sp-swipe-cue.next{right:22px}
.sp-swipe-cue.show{animation:spSwipeCueFlash .32s ease-out}
@keyframes spSwipeCueFlash{
  0%{opacity:0;transform:translateY(-50%) scale(.82)}
  28%{opacity:1;transform:translateY(-50%) scale(1)}
  100%{opacity:0;transform:translateY(-50%) scale(1.08)}
}
.sp-overlay{position:fixed;inset:0;background:transparent;
  z-index:99;display:none;pointer-events:none;transition:background .15s ease,backdrop-filter .15s ease}
.sp-overlay.open{display:block}
.sp-context-rail{display:none}

/* PER-FILE PROGRESS */
.fq-progress-label{font-family:var(--mono);font-size:9px;color:var(--cyan);
  margin-top:3px;min-height:13px}
.fq-view-btn{font-family:var(--mono);font-size:9px;padding:3px 8px;
  background:transparent;border:1px solid var(--border2);color:var(--dim2);
  cursor:pointer;border-radius:2px;transition:all .15s;flex-shrink:0}
.fq-view-btn:hover{border-color:var(--cyan);color:var(--cyan)}

/* FLAGGED ROW */
.r-flagged{background:rgba(255,192,67,.06) !important}
.r-flagged td{border-bottom-color:rgba(255,192,67,.2) !important}
.tf{color:var(--yellow);border-color:rgba(255,192,67,.5);background:rgba(255,192,67,.12)}

/* FLAG NOTE INLINE */
.flag-note-inp{background:transparent;border:none;border-bottom:1px solid rgba(255,192,67,.4);
  color:var(--yellow);font-family:var(--mono);font-size:9px;width:100%;outline:none;
  padding:2px 4px;min-width:80px}
.flag-note-inp::placeholder{color:rgba(255,192,67,.4)}

/* DIFF ALERT STRIP IN MODAL */
.diff-alert{background:rgba(255,192,67,.1);border:1px solid rgba(255,192,67,.4);
  border-left:3px solid var(--yellow);padding:10px 14px;margin-bottom:14px;
  font-family:var(--mono);font-size:11px;color:var(--yellow);display:none;
  border-radius:2px}
.diff-alert.on{display:block}

/* VIEW-AS TOGGLE (Admin only) */
.view-as-wrap{display:flex;align-items:center;gap:6px;padding:0 12px;
  border-right:1px solid var(--border);margin-right:4px}
.view-as-label{font-family:var(--mono);font-size:9px;color:var(--dim);letter-spacing:1px}
.view-as-sel{background:var(--s2);border:1px solid var(--border2);color:var(--cyan);
  font-family:var(--mono);font-size:10px;padding:4px 8px;border-radius:2px;
  outline:none;cursor:pointer}

/* COLLAPSIBLE PANEL STANDARD */
.cpanel{border:1px solid var(--border2);margin-bottom:12px;overflow:hidden}
.cpanel-hdr{display:flex;align-items:center;justify-content:space-between;
  padding:8px 14px;cursor:pointer;user-select:none;flex-shrink:0}
.cpanel-hdr:hover{background:rgba(255,255,255,.03)}
.cpanel-toggle{background:none;border:none;color:var(--dim2);cursor:pointer;
  font-size:12px;padding:2px 6px;transition:transform .2s;flex-shrink:0}
.cpanel-body{overflow-y:auto;transition:max-height .25s ease}
.cpanel-body.collapsed{max-height:0;overflow:hidden}
.cpanel-copy{background:none;border:1px solid rgba(0,255,65,.3);color:#00ff41;
  cursor:pointer;font-family:var(--mono);font-size:9px;padding:2px 8px;
  border-radius:2px;transition:all .15s}
.cpanel-copy:hover{background:rgba(0,255,65,.1)}

/* HORO ALERT — COMPACT COLLAPSIBLE */
.al-horo-hdr{display:flex;align-items:center;justify-content:space-between;
  padding:8px 14px;cursor:pointer}
.al-horo-body{max-height:120px;overflow-y:auto;padding:0 14px 10px;
  transition:max-height .25s ease}
.al-horo-body.collapsed{max-height:0;overflow:hidden;padding:0 14px}

/* DEBUG PANEL — UPDATED */
.debug-panel{position:fixed;bottom:0;left:0;right:0;z-index:200;
  background:#001a00;border-top:2px solid #00ff41;
  font-family:var(--mono);font-size:11px;color:#00ff41;display:none}
.debug-panel.on{display:flex;flex-direction:column}
.debug-hdr{display:flex;align-items:center;gap:8px;
  padding:6px 14px;border-bottom:1px solid #00ff4133;flex-shrink:0}
.debug-hdr-title{font-size:10px;letter-spacing:2px;text-transform:uppercase;flex:1}
.debug-body{max-height:150px;overflow-y:auto;padding:8px 14px;
  transition:max-height .25s ease}
.debug-body.collapsed{max-height:0;overflow:hidden;padding:0}

/* SIDE PANEL — adjust bottom when debug open */
.side-panel{bottom:0;transition:bottom .2s}
.side-panel.debug-open{bottom:180px}
.debug-line{padding:2px 0;border-bottom:1px solid #00ff4115;font-size:10px}
.debug-line.err{color:#ff6b6b}
.debug-line.ok{color:#3ddc84}
.debug-line.info{color:#41d1ff}

/* SIDE PANEL EDIT FIELDS */
.sp-edit-section{border-top:1px solid var(--border2);display:flex;flex-direction:column;flex:1;overflow:hidden;min-height:0}
.sp-edit-hdr{display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:10px 16px;cursor:default;background:var(--s2);
  user-select:none;-webkit-user-select:none;touch-action:manipulation}
.sp-edit-hdr:hover{background:var(--s3)}
.sp-edit-title{font-family:var(--mono);font-size:10px;letter-spacing:1px;
  text-transform:uppercase;color:var(--cyan)}
.sp-edit-actions{display:flex;align-items:center;gap:12px;flex-shrink:0;
  user-select:none;-webkit-user-select:none;touch-action:manipulation}
#spEditToggle{min-width:28px;min-height:28px;user-select:none;-webkit-user-select:none;touch-action:manipulation}
.sp-edit-body{padding:14px 16px;overflow:hidden;flex:1;min-height:0;
  transition:none;display:flex;flex-direction:column;gap:12px}
.sp-edit-body.collapsed{display:none}
.sp-zone{border:1px solid rgba(65,84,118,.58);background:rgba(16,24,38,.45);
  padding:10px;border-radius:2px;flex-shrink:0;user-select:none;-webkit-user-select:none}
.sp-zone-data{flex:1 1 auto;
  min-height:0;overflow-y:auto}
.sp-zone-review{border-color:rgba(255,196,59,.28);border-top:2px solid rgba(255,196,59,.62);
  border-bottom:2px solid rgba(255,196,59,.62);background:rgba(255,196,59,.04);
  height:180px;min-height:82px;max-height:45%;overflow-y:auto}
.sp-zone-review.is-hidden{display:none}
.sp-zone-review.is-collapsed{display:none}
.sp-zone-review #spThreadBody{max-height:none!important;overflow-y:visible!important}
.sp-zone-summary{border-top:2px solid rgba(137,163,255,.72);
  background:var(--s2);padding:8px;flex-shrink:0;box-shadow:0 18px 0 0 var(--s2)}
.sp-review-resize{height:16px;position:relative;display:flex;align-items:center;
  justify-content:center;flex-shrink:0;cursor:row-resize;background:rgba(255,196,59,.10);
  border-top:1px solid rgba(255,196,59,.25);border-bottom:1px solid rgba(255,196,59,.25);
  touch-action:none;user-select:none;-webkit-user-select:none}
.sp-review-resize.is-hidden{display:none}
.sp-review-resize.dragging{background:rgba(255,196,59,.28)}
.sp-review-grip{width:34px;height:3px;border-top:1px solid rgba(255,196,59,.65);
  border-bottom:1px solid rgba(255,196,59,.45)}
.sp-review-toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);
  width:22px;height:22px;padding:0;border:1px solid rgba(255,196,59,.45);
  background:var(--s2);color:var(--yellow);font-size:12px;line-height:18px;
  cursor:pointer;border-radius:2px;touch-action:manipulation;user-select:none;-webkit-user-select:none}
.sp-review-toggle:hover{border-color:var(--yellow);color:var(--text)}
.sp-frow{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}
.sp-zone .sp-frow:last-child{margin-bottom:0}
.sp-frow.fc3{grid-template-columns:1fr 1fr 1fr}
.sp-frow.fc1{grid-template-columns:1fr}
.sp-field label{font-family:var(--mono);font-size:9px;letter-spacing:1px;
  text-transform:uppercase;color:var(--dim2);display:block;margin-bottom:4px}
.sp-field input,.sp-field select,.sp-field textarea{
  background:var(--s3);border:1px solid var(--border2);color:var(--text);
  font-family:var(--body);font-size:12px;padding:7px 10px;width:100%;
  border-radius:2px;outline:none;transition:border-color .15s}
.sp-field input:focus,.sp-field select:focus{border-color:var(--cyan)}
.sp-field input[readonly]{color:var(--dim2);cursor:default}
.sp-calc{display:flex;gap:10px;background:var(--s3);border:1px solid var(--border);
  padding:10px 12px;flex-wrap:wrap}
.sp-calc-item{display:flex;flex-direction:column;align-items:center;gap:2px}
.sp-calc-l{font-family:var(--mono);font-size:8px;color:var(--dim);text-transform:uppercase}
.sp-calc-v{font-family:var(--mono);font-size:13px;font-weight:700}
.sp-save-bar{display:flex;gap:8px;padding:0 0 4px}

/* AIRCRAFT MODAL */
.ac-box{max-width:560px;width:100%}

/* REMEMBER ME */
.remember-row{display:flex;align-items:center;gap:8px;margin-bottom:14px;
  font-family:var(--mono);font-size:11px;color:var(--dim2);cursor:pointer}
.remember-row input{accent-color:var(--cyan);cursor:pointer}

/* SIDEBAR TOGGLE ICON BUTTON */
.sp-toggle-btn{background:var(--s2);border:1px solid var(--border2);border-radius:6px;
  padding:5px 7px;cursor:pointer;color:var(--dim2);display:inline-flex;
  align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}
.sp-toggle-btn:hover{border-color:var(--cyan);color:var(--cyan)}
.sp-toggle-btn svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:1.8}

/* sp-zoom-bar removed — replaced by sp-img-toolbar */
.sp-nav{display:flex;align-items:center;gap:8px;padding:8px 16px;
  border-bottom:1px solid var(--border2);background:var(--s2);flex-shrink:0}
.sp-nav-btn{background:var(--s3);border:1px solid var(--border2);color:var(--text);
  padding:4px 14px;cursor:pointer;font-size:20px;font-weight:700;border-radius:2px;
  transition:all .15s;line-height:1}
.sp-nav-btn:hover{border-color:var(--cyan);color:var(--cyan)}
.sp-nav-pos{font-family:var(--mono);font-size:12px;color:var(--text);flex:1;
  text-align:center;letter-spacing:.5px;font-weight:600}

/* SIDE PANEL HORIZONTAL RESIZE (image/data divider) */
.sp-vresize{height:10px;cursor:row-resize;background:var(--border2);flex-shrink:0;
  position:relative;transition:background .15s;touch-action:none;
  user-select:none;-webkit-user-select:none}
.sp-vresize:hover,.sp-vresize.dragging{background:var(--cyan)}
.sp-vresize::after{content:'';position:absolute;left:50%;top:50%;
  transform:translate(-50%,-50%);width:24px;height:2px;
  border-top:1px solid var(--dim);border-bottom:1px solid var(--dim)}
body.sp-resizing{user-select:none;-webkit-user-select:none;touch-action:none}

/* SIDE PANEL LEFT RESIZE (width) */
/* STICKY HEADERS */
table.fl-tbl.sticky-headers thead th{position:sticky;top:0;z-index:5;background:var(--s2)}
table.fl-tbl.sticky-headers thead tr:nth-child(1) th{box-shadow:0 -8px 0 0 var(--s2)}
table.fl-tbl.sticky-headers thead tr:nth-child(2) th{top:34px;box-shadow:0 -8px 0 0 var(--s2)}
.fl-tbl-wrap.sticky-active{overflow-y:auto!important;max-height:calc(100vh - 320px)!important}
/* DUPLICATE LOG MARKER */
.log-dup-gap{border-left:3px solid var(--red)!important}
/* VOID ROW */
.r-void{background:rgba(120,120,140,.08)!important;opacity:.5}
/* LEFT RESIZE HANDLE */
.sp-resize-handle{position:absolute;left:0;top:0;bottom:0;width:5px;cursor:col-resize;
  background:transparent;z-index:10;transition:background .15s;touch-action:none}
.sp-resize-handle:hover,.sp-resize-handle.dragging{background:var(--cyan)}
@media (min-width:769px) and (max-width:1100px), (min-width:769px) and (max-height:800px){
  :root{--compact-rail-w:88px}
  html,body{max-width:100%;overflow-x:hidden}
  .src-bar{
    grid-template-columns:1fr;
    gap:10px;
    background:var(--bg);
  }
  .src-dash-workflow{
    grid-template-columns:minmax(250px,.62fr) minmax(360px,1.38fr);
    gap:6px;
    background:var(--s1);
  }
  .src-dash-left,
  .src-card,
  .src-work-card,
  .src-history-card,
  .src-assist-bar{
    background:var(--s1);
  }
  .panel-tabs > div[style*="flex:1"]{
    display:none!important;
  }
  .src-history-card{
    min-height:104px;
  }
  .src-assist-bar{
    min-height:24px;
    padding:4px 10px;
  }
  .src-assist-bar span{
    white-space:nowrap;
  }
  .sp-context-rail.on{
    position:fixed;
    left:0;
    top:0;
    bottom:0;
    width:var(--compact-rail-w);
    z-index:101;
    display:flex;
    align-items:center;
    justify-content:flex-end;
    background:var(--bg);
    border-right:1px solid var(--border2);
    pointer-events:auto;
    padding-right:6px;
  }
  .sp-rail-card{
    width:74px;
    border:1px solid var(--cyan);
    border-left:3px solid var(--cyan);
    background:var(--s2);
    padding:9px 6px;
    font-family:var(--mono);
    text-align:center;
    box-sizing:border-box;
  }
  .sp-rail-label{
    color:var(--dim2);
    font-size:8px;
    letter-spacing:1.4px;
    text-transform:uppercase;
    margin-bottom:5px;
  }
  .sp-rail-num{
    color:var(--cyan);
    font-size:12px;
    font-weight:700;
    overflow:hidden;
    text-overflow:ellipsis;
  }
  .sp-rail-entry{
    color:var(--text);
    font-size:10px;
    margin-top:4px;
  }
  .sp-rail-meta,.sp-rail-state{
    color:var(--dim2);
    font-size:8px;
    line-height:1.35;
    margin-top:6px;
    text-transform:uppercase;
    overflow:hidden;
    text-overflow:ellipsis;
  }
  .side-panel.sp-review-layout{
    width:calc(100vw - var(--compact-rail-w))!important;
    min-width:0!important;
    max-width:none!important;
    right:0!important;
    left:auto!important;
    display:grid;
    grid-template-columns:minmax(260px,43%) minmax(300px,57%);
    grid-template-rows:auto auto auto minmax(0,1fr) auto;
    overflow:hidden;
    background:var(--s1);
  }
  .side-panel.sp-review-layout .sp-resize-handle{display:none}
  .side-panel.sp-review-layout .sp-header,
  .side-panel.sp-review-layout .sp-nav,
  .side-panel.sp-review-layout .sp-meta{
    grid-column:1 / -1;
    background:var(--s2);
  }
  .side-panel.sp-review-layout .sp-header{
    padding:10px 12px;
  }
  .side-panel.sp-review-layout .sp-nav{
    display:grid!important;
    grid-template-columns:42px minmax(0,1fr) 42px;
    align-items:center;
    gap:8px;
    padding:6px 10px;
    overflow:hidden;
  }
  .side-panel.sp-review-layout .sp-nav-pos{
    min-width:0;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
  }
  .side-panel.sp-review-layout .sp-nav-btn{
    width:42px;
    min-width:42px;
    padding:4px 0;
    text-align:center;
  }
  .side-panel.sp-review-layout .sp-img-wrap{
    grid-column:1;
    grid-row:4;
    height:auto!important;
    min-height:0;
    padding:6px 8px 6px 6px;
    align-self:stretch;
    justify-content:flex-start;
    background:var(--bg);
    border-right:1px solid var(--border2);
  }
  .side-panel.sp-review-layout .sp-img-toolbar{
    grid-column:1;
    grid-row:5;
    padding:5px 8px;
    background:var(--s2);
    border-right:1px solid var(--border2);
  }
  .side-panel.sp-review-layout .sp-img-toolbar button{
    padding:3px 6px;
    min-height:26px;
  }
  .side-panel.sp-review-layout .sp-vresize{
    display:none;
  }
  .side-panel.sp-review-layout .sp-edit-section{
    grid-column:2;
    grid-row:4 / span 2;
    display:flex!important;
    min-height:0;
    border-top:0;
    border-left:1px solid var(--border2);
    background:var(--s1);
  }
  .side-panel.sp-review-layout .sp-edit-hdr{
    padding:8px 10px;
    background:var(--s2);
  }
  .side-panel.sp-review-layout .sp-edit-body{
    display:grid;
    grid-template-rows:minmax(0,1fr) minmax(76px,.34fr) auto;
    gap:0;
    overflow:hidden;
    padding:10px;
    min-height:0;
    background:var(--s1);
    isolation:isolate;
  }
  .side-panel.sp-review-layout .sp-zone{
    background:var(--s2);
    border-color:var(--border2);
  }
  .side-panel.sp-review-layout .diff-alert{
    background:var(--s3);
  }
  .side-panel.sp-review-layout .sp-zone-data{
    max-height:100%;
    min-height:0;
    overflow-y:auto;
    border-bottom:0;
    position:relative;
    z-index:1;
  }
  .side-panel.sp-review-layout .sp-zone-data .sp-frow.fc3{
    grid-template-columns:1fr 1fr;
  }
  .side-panel.sp-review-layout .sp-review-resize{
    display:none!important;
  }
  .side-panel.sp-review-layout .sp-zone-review{
    height:auto!important;
    min-height:76px;
    max-height:none;
    overflow:hidden;
    border-top:1px solid rgba(255,196,59,.62);
    border-bottom:0;
    background:var(--s2);
    position:relative;
    z-index:2;
  }
  .side-panel.sp-review-layout .sp-zone-review #spCommentRow,
  .side-panel.sp-review-layout .sp-zone-review .sp-field,
  .side-panel.sp-review-layout #spReviewThread{
    height:100%;
    min-height:0;
  }
  .side-panel.sp-review-layout #spReviewThread{
    display:flex;
    flex-direction:column;
    background:var(--s2)!important;
    border-color:var(--border2)!important;
  }
  .side-panel.sp-review-layout #spReviewThread > div{
    background:var(--s2)!important;
    border-color:var(--border2)!important;
  }
  .side-panel.sp-review-layout #spColReviewer,
  .side-panel.sp-review-layout #spColOperator{
    background:var(--s2)!important;
    border-color:var(--border2)!important;
  }
  .side-panel.sp-review-layout #spThreadBody{
    flex:1 1 auto;
    min-height:80px;
    overflow-y:auto!important;
    background:var(--s2)!important;
  }
  .side-panel.sp-review-layout #spThreadInput,
  .side-panel.sp-review-layout #spThreadFooter{
    background:var(--s2)!important;
    border-color:var(--border2)!important;
  }
  .side-panel.sp-review-layout #spThreadTextarea{
    background:var(--s3)!important;
    border-color:var(--border2)!important;
  }
  .side-panel.sp-review-layout #spThreadInput textarea{
    height:62px;
  }
  .side-panel.sp-review-layout .sp-zone-summary{
    align-self:end;
    box-shadow:none;
    border-top:2px solid rgba(137,163,255,.72);
    border-bottom:1px solid var(--border2);
    background:var(--s2);
    position:relative;
    z-index:5;
  }
  .side-panel.sp-review-layout .sp-calc{
    padding:7px 8px;
    gap:8px;
    background:var(--s3);
    position:relative;
    z-index:6;
  }
}
@media (max-width:800px), (max-height:600px){
  body.hpf-sidepanel-dim-backdrop .tab-content,
  body.hpf-sidepanel-dim-backdrop .src-bar,
  body.hpf-sidepanel-dim-backdrop .fl-tbl-wrap{
    filter:brightness(.42) contrast(.9);
  }
  body.hpf-sidepanel-dim-backdrop .side-panel{
    box-shadow:-18px 0 40px rgba(0,0,0,.72);
  }
  body.hpf-sidepanel-dim-backdrop .side-panel.open .sp-header,
  body.hpf-sidepanel-dim-backdrop .side-panel.open .sp-nav,
  body.hpf-sidepanel-dim-backdrop .side-panel.open .sp-meta,
  body.hpf-sidepanel-dim-backdrop .side-panel.open .sp-img-toolbar,
  body.hpf-sidepanel-dim-backdrop .side-panel.open .sp-edit-hdr,
  body.hpf-sidepanel-dim-backdrop .side-panel.open .sp-zone,
  body.hpf-sidepanel-dim-backdrop .side-panel.open #spReviewThread,
  body.hpf-sidepanel-dim-backdrop .side-panel.open #spReviewThread > div,
  body.hpf-sidepanel-dim-backdrop .side-panel.open #spThreadBody,
  body.hpf-sidepanel-dim-backdrop .side-panel.open #spThreadInput,
  body.hpf-sidepanel-dim-backdrop .side-panel.open #spThreadFooter{
    background:var(--s2)!important;
    border-color:var(--border2)!important;
  }
  body.hpf-sidepanel-dim-backdrop .side-panel.open .sp-edit-body{
    background:var(--s1)!important;
    isolation:isolate;
  }
  body.hpf-sidepanel-dim-backdrop .side-panel.open .sp-edit-section{
    background:var(--s1)!important;
  }
  body.hpf-sidepanel-dim-backdrop .side-panel.open .sp-img-wrap{
    background:var(--bg)!important;
  }
  body.hpf-sidepanel-dim-backdrop .side-panel.open .diff-alert,
  body.hpf-sidepanel-dim-backdrop .side-panel.open .sp-calc,
  body.hpf-sidepanel-dim-backdrop .side-panel.open .sp-field input,
  body.hpf-sidepanel-dim-backdrop .side-panel.open .sp-field select,
  body.hpf-sidepanel-dim-backdrop .side-panel.open .sp-field textarea,
  body.hpf-sidepanel-dim-backdrop .side-panel.open #spThreadTextarea{
    background:var(--s3)!important;
  }
  body.hpf-sidepanel-dim-backdrop .side-panel.open .sp-zone-data{position:relative;z-index:1}
  body.hpf-sidepanel-dim-backdrop .side-panel.open .sp-zone-review{position:relative;z-index:2}
  body.hpf-sidepanel-dim-backdrop .side-panel.open .sp-zone-summary{position:relative;z-index:5}
  body.hpf-sidepanel-dim-backdrop .side-panel.open .sp-calc{position:relative;z-index:6}
}
@media (pointer:coarse){
  .sp-vresize{height:18px}
  .sp-review-resize{height:24px}
  .sp-review-toggle{width:30px;height:30px;right:10px;font-size:15px}
  .sp-resize-handle{width:12px}
}

/* IMAGE TOOLBAR */
.sp-img-toolbar{display:flex;align-items:center;gap:4px;padding:5px 10px;
  background:var(--s2);border-top:1px solid var(--border2);flex-shrink:0;flex-wrap:wrap}
.sp-img-toolbar button{background:transparent;border:1px solid var(--border2);color:var(--dim2);
  font-family:var(--mono);font-size:10px;padding:4px 8px;cursor:pointer;border-radius:2px;
  transition:all .15s;white-space:nowrap;display:inline-flex;align-items:center;gap:4px}
.sp-img-toolbar button svg{width:13px;height:13px;fill:none;stroke:currentColor;stroke-width:1.8;flex-shrink:0}
.sp-img-toolbar button:hover{border-color:var(--text);color:var(--text)}
.sp-img-toolbar button.active{border-color:var(--text);color:var(--text);background:rgba(255,255,255,.06)}
.sp-zoom-level{font-family:var(--mono);font-size:10px;color:var(--dim2);
  min-width:36px;text-align:center;user-select:none}
.sp-toolbar-sep{width:1px;height:16px;background:var(--border2);margin:0 2px;flex-shrink:0}
.sp-toolbar-right{margin-left:auto;display:flex;align-items:center;gap:4px}

/* WHATSAPP CONFIRM DIALOG */
.wa-confirm-box{max-width:420px;width:100%}
.wa-confirm-body{padding:16px;font-size:14px;color:var(--dim2);line-height:1.6}
.wa-recipient{font-family:var(--mono);font-size:12px;color:var(--green);
  background:var(--s3);padding:8px 12px;border-radius:2px;margin:10px 0;
  border-left:3px solid var(--green)}

/* PRE-INVOICE READY STATE */
.pi-ready{padding:32px;text-align:center}
.pi-ready-icon{font-size:48px;margin-bottom:16px}
.pi-ready-title{font-family:var(--display);font-size:22px;font-weight:700;
  color:var(--green);margin-bottom:8px}
.pi-ready-sub{color:var(--dim2);font-size:14px;margin-bottom:24px}
.pi-stats{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-bottom:24px}
.pi-stat{background:var(--s2);border:1px solid var(--border2);border-top:3px solid var(--cyan);
  padding:16px 24px;text-align:center}
.pi-stat-v{font-family:var(--display);font-size:24px;font-weight:700;color:var(--cyan)}
.pi-stat-l{font-family:var(--mono);font-size:9px;color:var(--dim);text-transform:uppercase;
  margin-top:4px}

/* REVIEW COMMENT INDICATOR */
.rc-indicator{color:var(--yellow);font-size:11px;cursor:help}

/* BNUM COLUMN */
.bnum-cell{font-family:var(--mono);font-size:10px;color:var(--violet)}

/* COLLAPSED SECTION */
.collapsed-section{display:none!important}

/* SIDE PANEL ACTIVE ROW */
.sp-active-row{outline:2px solid var(--cyan)!important;background:rgba(65,209,255,.06)!important}
.r-skipped td{color:var(--dim)!important}

/* TABLE HORIZONTAL SCROLL */
.fl-tbl-wrap{overflow-x:auto;width:100%}
.fl-tbl{min-width:1100px}

/* WORKFLOW BAR — fixed state colors */
.wf-step.done .wf-dot{background:var(--green);box-shadow:none}
.wf-step.done{color:var(--green)}
.wf-step.active .wf-dot{background:var(--cyan);animation:pulse 1.5s infinite}
.wf-step.active{color:var(--cyan)}
.wf-step.pending .wf-dot{background:var(--border2);box-shadow:none}
.wf-step.pending{color:var(--dim)}

/* HORO SEQUENCE GAP — cell left border only */
.horo-seq-gap{border-left:3px solid var(--yellow)!important}

/* sp-zoom-btn / sp-rotate-btn / sp-reextract-btn — now part of sp-img-toolbar */
.sp-reextract-btn{background:rgba(41,209,255,.15);border:1px solid var(--cyan);color:var(--cyan);
  padding:4px 10px;border-radius:4px;cursor:pointer;font-size:11px;font-family:var(--mono);
  transition:all .15s}
.sp-reextract-btn:hover{background:rgba(41,209,255,.3)}

/* PRE-INVOICE */
.pi-invoice{background:var(--s1);border:1px solid var(--border2);max-width:860px;margin:0 auto;padding:32px}
.pi-inv-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid var(--cyan)}
.pi-inv-from{font-size:13px;line-height:1.7}
.pi-inv-from strong{font-size:16px;color:var(--cyan);font-family:var(--display)}
.pi-inv-meta{text-align:right;font-family:var(--mono);font-size:11px;color:var(--dim2)}
.pi-inv-meta div{margin-bottom:4px}
.pi-inv-meta strong{color:var(--text)}
.pi-bill-to{background:var(--s2);border:1px solid var(--border);padding:14px 18px;margin-bottom:20px}
.pi-bill-label{font-family:var(--mono);font-size:9px;color:var(--dim);text-transform:uppercase;letter-spacing:1px;margin-bottom:6px}
.pi-bill-name{font-size:15px;font-weight:700;color:var(--text);margin-bottom:4px}
.pi-bill-detail{font-size:12px;color:var(--dim2);line-height:1.6}
.pi-period{display:flex;gap:24px;margin-bottom:20px;font-family:var(--mono);font-size:11px;color:var(--dim2)}
.pi-period span{color:var(--text)}
.pi-tbl{width:100%;border-collapse:collapse;margin-bottom:16px;font-size:12px}
.pi-tbl th{background:var(--s3);padding:8px 12px;text-align:left;font-family:var(--mono);font-size:9px;text-transform:uppercase;letter-spacing:1px;color:var(--dim);border-bottom:1px solid var(--border2)}
.pi-tbl td{padding:8px 12px;border-bottom:1px solid var(--border);vertical-align:middle}
.pi-tbl tr:last-child td{border-bottom:none}
.pi-tbl .pi-amt{text-align:right;font-family:var(--mono);font-weight:600;color:var(--green)}
.pi-tbl .pi-zero{color:var(--dim2)}
#pi_last_row_tbl{display:none}
.pi-line-cols col:nth-child(1){width:7%}
.pi-line-cols col:nth-child(2){width:20%}
.pi-line-cols col:nth-child(3){width:20%}
.pi-line-cols col:nth-child(4){width:24%}
.pi-line-cols col:nth-child(5){width:14%}
.pi-line-cols col:nth-child(6){width:15%}
.pi-subtotal{padding:10px 0;border-top:1px solid var(--border2);margin-bottom:12px;display:table;width:100%}
.pi-subtotal-row{display:table-row;font-family:var(--mono);font-size:12px}
.pi-subtotal-row span:first-child{display:table-cell;color:var(--dim2);padding:3px 12px;width:60%}
.pi-subtotal-row span:last-child{display:table-cell;text-align:right;padding:3px 12px}
.pi-charges{margin-bottom:20px}
.pi-charges-title{font-family:var(--mono);font-size:10px;color:var(--dim);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}
.pi-charge-row{display:table;width:100%;margin-bottom:4px}
.pi-charge-row>*{display:table-cell;vertical-align:middle;padding:4px 12px}
.pi-charge-row input{background:var(--s3);border:1px solid var(--border2);color:var(--text);padding:6px 10px;font-size:12px;border-radius:2px;outline:none}
.pi-total{background:var(--s2);border:2px solid var(--cyan);padding:14px 20px;display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}
.pi-total-label{font-family:var(--display);font-weight:700;font-size:14px;color:var(--dim2)}
.pi-total-amt{font-family:var(--display);font-weight:700;font-size:22px;color:var(--green);letter-spacing:1px}
/* When prompt payment exists: de-emphasize TOTAL AMOUNT DUE */
.pi-total-amt.has-pronto{font-size:17px;color:var(--dim2)}
.pi-total-label.has-pronto{font-size:12px;font-weight:400;color:var(--dim)}
.pi-signoff{display:flex;gap:12px;align-items:center}
.pi-signed{background:rgba(61,220,132,.1);border:1px solid var(--green);padding:10px 16px;font-family:var(--mono);font-size:11px;color:var(--green)}

/* NON-BILLABLE */
.log-seq-gap{border-left:3px solid var(--red)!important}
.r-nonbillable{background:rgba(255,107,107,0.24)!important}
.r-nonbillable td{color:inherit!important}
.r-observed-history{background:rgba(255,192,67,.30)!important}
.r-observed-history td{color:inherit!important}
.r-observed-active{background:rgba(255,192,67,0.18)!important}
.r-observed-active td{color:inherit!important}
.r-observed-active td:first-child{border-left:4px solid var(--yellow)!important}
.r-observed-reviewing{background:rgba(255,192,67,0.14)!important}
.r-observed-reviewing td{color:inherit!important}
.r-observed-reviewing td:first-child{border-left:4px solid var(--yellow)!important}

button.sp-nonbill-btn{background:transparent;border:1px solid var(--red)!important;color:var(--red)!important;
  font-family:var(--mono);font-size:10px;padding:4px 8px;cursor:pointer;border-radius:2px;
  white-space:nowrap;line-height:1.2;user-select:none;-webkit-user-select:none;touch-action:manipulation}
button.sp-nonbill-btn.active{background:var(--red)!important;color:#000!important;font-weight:700}
button.sp-nonbill-btn:hover{opacity:.85}
@media (pointer:coarse){
  button.sp-nonbill-btn{min-height:32px;padding:7px 10px}
}

/* FLOATING DETAIL DIALOG */
.float-dialog{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);
  background:var(--s1);border:1px solid var(--border2);
  border-radius:4px;z-index:200;min-width:320px;max-width:480px;
  min-height:150px;max-height:calc(100vh - 24px);
  box-shadow:0 8px 32px rgba(0,0,0,.5);display:none;flex-direction:column;overflow:hidden}
.float-dialog.open{display:flex}
.float-dialog-hdr{display:flex;align-items:center;justify-content:space-between;
  padding:10px 14px;background:var(--cyan);cursor:move;flex-shrink:0;border-radius:3px 3px 0 0;
  touch-action:none;user-select:none}
.float-dialog-hdr.dragging{filter:brightness(1.08)}
.float-dialog-title{font-family:var(--mono);font-size:11px;letter-spacing:.5px;color:#000;font-weight:700}
.float-dialog-close{background:none;border:none;color:#000;cursor:pointer;font-size:16px;padding:0 4px;opacity:.7}
.float-dialog-close:hover{opacity:1}
.float-dialog-body{padding:12px 14px 22px;overflow-y:auto;max-height:none;flex:1 1 auto;min-height:0;
  font-family:var(--mono);font-size:10px;color:var(--dim2);line-height:1.8}
.float-dialog-resize{position:absolute;right:0;bottom:0;width:28px;height:28px;
  cursor:nwse-resize;touch-action:none;z-index:3}
.float-dialog-resize::after{content:'';position:absolute;right:6px;bottom:6px;
  width:12px;height:12px;border-right:2px solid var(--cyan);border-bottom:2px solid var(--cyan);
  opacity:.7}
.float-dialog-resize.dragging::after{opacity:1}

/* DEBUG TOGGLE SLIDER */
.dbg-slider{position:relative;display:inline-block;width:40px;height:22px;flex-shrink:0}
.dbg-slider input{opacity:0;width:0;height:0}
.dbg-slider-track{position:absolute;cursor:pointer;inset:0;background:var(--border2);border-radius:22px;transition:background .2s}
.dbg-slider-track::before{content:"";position:absolute;width:16px;height:16px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:transform .2s}
.dbg-slider input:checked+.dbg-slider-track{background:var(--cyan)}
.dbg-slider input:checked+.dbg-slider-track::before{transform:translateX(18px)}
@media print{
  @page{margin:1cm;marks:none}
  body{background:#fff!important;color:#111!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  /* Hide all chrome */
  .topbar,.tab-nav,#roleBanner,.debug-panel,.sp-overlay,#sidePanel,
  #panel-users,#panel-companies,#panel-flightlog,#panel-aircraft,#panel-settings,
  #piComingSoon,.page-hdr,#pi_signoff_btn,#pi_add_charge2,#pi_export_pdf,
  [data-del-charge],button,.toast,#undoBtn,.float-dialog,.modal-backdrop{display:none!important}
  /* Show billing panel */
  #panel-preinvoice{display:block!important;padding:0}
  .pi-invoice{background:#fff!important;border:none!important;box-shadow:none!important;max-width:100%;padding:8px}
  /* Header */
  .pi-inv-from strong{color:#0099bb!important}
  .pi-inv-meta,#pi_inv_num,#pi_inv_date,#pi_inv_aircraft{color:#333!important}
  /* Bill To box */
  .pi-bill-to{background:#f5f5f5!important;border-color:#ccc!important}
  .pi-bill-name{color:#111!important}
  .pi-bill-detail,.pi-bill-label{color:#555!important}
  /* Period bar */
  .pi-period{color:#555!important}
  .pi-period span{color:#111!important}
  #pi_rate_display{color:#cc8800!important}
  /* Table headers — black text on light bg */
  .pi-tbl th{background:#f0f0f0!important;color:#111!important;border-color:#ccc!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .pi-tbl td{border-color:#ddd!important;color:#111!important}
  .pi-tbl .pi-amt{color:#1a9955!important}
  .pi-tbl .pi-zero{color:#999!important}
  .pi-line-table{table-layout:fixed!important}
  #pi_line_items tr:last-child{display:none!important}
  #pi_last_row_tbl{display:table!important}
  /* Subtotal row */
  #pi_sub_hrs{color:#111!important}
  #pi_sub_amt{color:#1a9955!important}
  /* Charges */
  .pi-charges-title{color:#888!important}
  .pi-charges input{display:none!important}
  .pi-charges .pi-desc-print{display:inline!important}
  /* Keep charges amount visible after hiding inputs */
  .pi-tbl .pi-amt{color:#1a9955!important}
  /* Summary block stays together */
  .pi-summary-block{page-break-inside:avoid!important;break-inside:avoid!important}
  .pi-charges,.pi-total,.pi-signoff{page-break-inside:avoid;break-inside:avoid}
  .pi-total{background:#f5f5f5!important;border-color:#0099bb!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .pi-total-label{color:#333!important}
  .pi-total-amt{color:#1a9955!important}
  /* Approval stamp — force visible */
  #pi_signed_badge:not(:empty){display:flex!important;background:rgba(26,153,85,.08)!important;border-color:#1a9955!important;color:#1a9955!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  #pi_signed_badge:empty{display:none!important}
  /* Keep summary block together — no page break inside charges+total+stamp */
  .pi-charges,.pi-total,.pi-signoff{page-break-inside:avoid;break-inside:avoid}
  .pi-total{page-break-before:avoid;break-before:avoid}
  /* Discount breakdown and pronto pago block */
  #pi_discount_block{display:block!important;color:#333!important}
  #pi_discount_block span{color:#333!important}
  #pi_pronto_block{display:block!important}
  .pi-pronto-label{color:#333!important;font-weight:700}
  .pi-pronto-amt{color:#1a9955!important;font-weight:700}
  .pi-pronto-footer{color:#555!important;font-size:9px!important}
}
.pi-charges input[type=number]::-webkit-inner-spin-button,
.pi-charges input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}
.pi-charges input[type=number]{-moz-appearance:textfield}
#co_rules_list input[type=number]::-webkit-inner-spin-button,
#co_rules_list input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}
#co_rules_list input[type=number]{-moz-appearance:textfield}
.pi-summary-block{page-break-inside:avoid;break-inside:avoid}
.pi-charges .pi-desc-print{display:none}
