*{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#111111;--bg2:#1c1c1c;--bg3:#242424;--bg4:#2e2e2e;--bg5:#383838;
  --gold:#A0773A;--gold2:#C49A4E;--gold3:#F5E486;--gdim:rgba(160,119,58,.13);
  --text:#f0ece4;--text2:#b8b2a8;--text3:#6e6860;
  --bdr:rgba(160,119,58,.16);--bdra:rgba(245,228,134,.3);
  --r:8px;--r2:13px;
  --ok:#6dbb80;--warn:#e5b84a;--err:#e06b6b;--info:#70a9d4;
  --ok-bg:rgba(109,187,128,.12);--warn-bg:rgba(229,184,74,.12);--err-bg:rgba(224,107,107,.12);--info-bg:rgba(112,169,212,.12);
}
body{font-family:'Segoe UI',system-ui,sans-serif;background:var(--bg);color:var(--text);font-size:13px;line-height:1.5;height:100vh;overflow:hidden}
#main_app{display:none !important}
#main_app.active{display:flex !important}
.app{display:flex;height:100vh}

/* SIDEBAR */
.sb{width:210px;background:#0d0d0d;border-right:1px solid var(--bdr);display:flex;flex-direction:column;flex-shrink:0;transition:width .22s cubic-bezier(.4,0,.2,1);overflow:hidden}
.brand{height:58px;padding:0 13px;border-bottom:1px solid var(--bdr);display:flex;align-items:center;flex-shrink:0;box-sizing:border-box}
.brand-name{font-size:.9rem;font-weight:700;letter-spacing:-.01em}
.brand-name span{background:linear-gradient(135deg,var(--gold),var(--gold3));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.brand-sub{font-size:.52rem;color:var(--text3);margin-top:1px;text-transform:uppercase;letter-spacing:.1em}
.nav{flex:1;overflow-y:auto;padding:6px 0}
.nav-section{font-size:.5rem;font-weight:700;color:var(--text3);letter-spacing:.14em;text-transform:uppercase;padding:10px 13px 3px}
.nav-item{display:flex;align-items:center;gap:7px;padding:7px 13px;color:var(--text2);font-size:.74rem;font-weight:500;cursor:pointer;border-left:2px solid transparent;transition:all .12s;position:relative;white-space:nowrap;overflow:hidden}
.nav-item:hover{color:var(--text);background:var(--bg3)}
.nav-item.active{color:var(--gold3);background:var(--gdim);border-left-color:var(--gold)}
.nav-item svg{width:14px;height:14px;flex-shrink:0;opacity:.55}.nav-item.active svg,.nav-item:hover svg{opacity:1}
.nav-badge{margin-left:auto;background:var(--gold);color:#111;font-size:.5rem;font-weight:800;padding:1px 5px;border-radius:8px;min-width:16px;text-align:center}
.nav-badge.green{background:var(--ok)}
.sb-footer{padding:9px 13px;border-top:1px solid var(--bdr);display:flex;align-items:center;gap:8px;box-sizing:border-box;position:relative;z-index:1;transition:padding .22s}
.av{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold3));display:flex;align-items:center;justify-content:center;font-size:.6rem;font-weight:800;color:#111;flex-shrink:0}
.av-name{font-size:.7rem;font-weight:600;color:var(--text)}.av-role{font-size:.56rem;color:var(--text3)}

/* MAIN */
.main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}
.topbar{height:52px;background:linear-gradient(180deg,#141414,#0d0d0d);border-bottom:1px solid var(--bdr);display:flex;align-items:center;justify-content:space-between;padding:0 18px;flex-shrink:0;gap:12px}
.page-title{font-size:.88rem;font-weight:700;color:var(--gold3);letter-spacing:-.01em}
.content{flex:1;overflow-y:auto;padding:13px}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border-radius:var(--r);font-size:.72rem;font-weight:600;cursor:pointer;border:none;transition:all .12s;white-space:nowrap;font-family:inherit}
.btn-primary{background:linear-gradient(135deg,var(--gold),var(--gold2));color:#111}.btn-primary:hover{opacity:.88}
.btn-ghost{background:transparent;color:var(--text2);border:1px solid var(--bdr)}.btn-ghost:hover{background:var(--bg4);color:var(--text)}
.btn-danger{background:var(--err-bg);color:var(--err);border:1px solid rgba(224,107,107,.2)}
.btn-info{background:var(--info-bg);color:var(--info);border:1px solid rgba(112,169,212,.2)}
.btn-success{background:var(--ok-bg);color:var(--ok);border:1px solid rgba(109,187,128,.2)}
.btn-sm{padding:3px 8px;font-size:.66rem}

/* CARDS */
.card{background:var(--bg2);border:1px solid var(--bdr);border-radius:var(--r2);padding:13px}
.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:11px;gap:8px;flex-wrap:wrap}
.card-title{font-size:.82rem;font-weight:700;color:var(--gold3)}

/* STATS */
.stats-grid{display:grid;gap:7px;margin-bottom:10px}
.stat-card{background:var(--bg2);border:1px solid var(--bdr);border-radius:var(--r2);padding:10px 13px}
.stat-val{font-size:1.4rem;font-weight:800;line-height:1;color:var(--gold3)}
.stat-lbl{font-size:.58rem;color:var(--text3);margin-top:2px;text-transform:uppercase;letter-spacing:.05em}

/* BADGES */
.badge{display:inline-flex;align-items:center;padding:2px 7px;border-radius:8px;font-size:.57rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.badge-new{background:rgba(112,169,212,.15);color:var(--info)}
.badge-contacted{background:rgba(229,184,74,.12);color:var(--warn)}
.badge-scheduled{background:rgba(91,184,176,.15);color:#5bb8b0}
.badge-interviewed{background:rgba(109,187,128,.12);color:var(--ok)}
.badge-evaluated{background:rgba(160,119,58,.18);color:var(--gold2)}
.badge-approved{background:rgba(245,228,134,.12);color:var(--gold3)}
.badge-rejected{background:rgba(224,107,107,.12);color:var(--err)}
.badge-follow_up{background:rgba(180,130,70,.12);color:#c19256}
.badge-active{background:rgba(109,187,128,.15);color:var(--ok)}
.badge-inactive{background:rgba(224,107,107,.12);color:var(--err)}
.badge-pending_entry{background:rgba(91,143,212,.12);color:var(--info)}
.badge-pending_docs{background:rgba(229,120,30,.12);color:#e5781e}
.badge-on_leave{background:rgba(184,92,184,.12);color:#b85cb8}
.badge-signed{background:rgba(245,228,134,.15);color:var(--gold3)}
.badge-generated{background:rgba(91,184,176,.15);color:#5bb8b0}
.badge-pending{background:rgba(112,169,212,.12);color:var(--info)}

/* TABLE */
.tbl{width:100%;border-collapse:collapse}
.tbl th{font-size:.57rem;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.08em;padding:5px 8px;text-align:left;border-bottom:1px solid var(--bdr)}
.tbl td{padding:7px 8px;font-size:.73rem;border-bottom:1px solid rgba(160,119,58,.06);vertical-align:middle}
.tbl tbody tr{cursor:pointer;transition:background .1s}.tbl tbody tr:hover{background:var(--bg3)}
.tbl-wrap{overflow-x:auto}

/* FORMS */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-bottom:10px}
.form-group{display:flex;flex-direction:column;gap:3px}
.form-group.full{grid-column:1/-1}
.form-label{font-size:.59rem;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.07em}
.req{color:var(--gold);margin-left:2px}
.form-control{background:var(--bg4);border:1px solid var(--bdr);border-radius:var(--r);color:var(--text);padding:6px 9px;font-size:.75rem;width:100%;font-family:inherit;transition:border-color .12s;-webkit-appearance:none}
.form-control:focus{outline:none;border-color:var(--gold)}
select.form-control{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%23A0773A' d='M5 6L0 0h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;padding-right:24px;cursor:pointer}
textarea.form-control{resize:vertical;min-height:58px}
.form-section{font-size:.6rem;font-weight:700;color:var(--gold);text-transform:uppercase;letter-spacing:.1em;padding-bottom:5px;border-bottom:1px solid rgba(160,119,58,.22);margin:4px 0 9px}

/* TOGGLE GROUPS */
.toggle-group{display:flex;flex-wrap:wrap;gap:5px}
.toggle-opt{display:flex;align-items:center;gap:5px;background:var(--bg4);border:1px solid var(--bdr);border-radius:7px;padding:4px 9px;cursor:pointer;font-size:.68rem;transition:all .12s;user-select:none}
.toggle-opt:hover,.toggle-opt.sel{border-color:var(--gold);color:var(--gold3)}.toggle-opt.sel{background:var(--gdim)}

/* ALERTS */
.alert{padding:8px 11px;border-radius:var(--r);font-size:.71rem;font-weight:500;margin-bottom:8px;border:1px solid;display:flex;align-items:flex-start;gap:7px}
.alert-success{background:var(--ok-bg);border-color:rgba(109,187,128,.22);color:var(--ok)}
.alert-danger{background:var(--err-bg);border-color:rgba(224,107,107,.22);color:var(--err)}
.alert-info{background:var(--info-bg);border-color:rgba(112,169,212,.22);color:var(--info)}
.alert-gold{background:var(--gdim);border-color:var(--bdr);color:var(--gold2)}

/* SEARCH */
.search-wrap{position:relative;flex:1;max-width:240px}
.search-wrap input{width:100%;background:var(--bg4);border:1px solid var(--bdr);border-radius:var(--r);color:var(--text);padding:5px 9px 5px 26px;font-size:.72rem;font-family:inherit}
.search-wrap input:focus{outline:none;border-color:var(--gold)}
.search-icon{position:absolute;left:8px;top:50%;transform:translateY(-50%);color:var(--text3);font-size:11px;pointer-events:none}

/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.8);display:flex;align-items:center;justify-content:center;z-index:1000}
.modal{background:var(--bg2);border:1px solid var(--bdr);border-radius:var(--r2);display:flex;flex-direction:column;overflow:hidden}
/* Dynamic modals — desktop */
.modal-dynamic {
  border-radius: var(--r2);
  overflow: hidden;
}
.modal-dynamic .modal-body {
  overflow-y: auto;
  overflow-x: hidden;
  max-height: calc(88vh - 52px);
  -webkit-overflow-scrolling: touch;
}
.modal-dynamic .modal-inner {
  max-width: 100%;
  overflow-x: hidden;
  word-wrap: break-word;
  overflow-wrap: break-word;
}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 11px;border-bottom:1px solid var(--bdr);position:sticky;top:0;background:var(--bg2);z-index:1}
.modal-title{font-size:.86rem;font-weight:700;color:var(--gold3)}
.modal-close{background:none;border:none;color:var(--text2);cursor:pointer;font-size:1.1rem;padding:6px 10px;border-radius:4px;font-family:inherit;min-width:36px;min-height:36px;display:flex;align-items:center;justify-content:center}.modal-close:hover{background:var(--bg4)}
.modal-body{max-height:calc(85vh - 60px);overflow-y:auto;-webkit-overflow-scrolling:touch;padding:14px 16px}
.modal-foot{padding:10px 16px;border-top:1px solid var(--bdr);display:flex;justify-content:flex-end;gap:7px}

/* FLOW TABS */
.flow-tabs{display:flex;border-bottom:1px solid var(--bdr);margin-bottom:12px}
.flow-tab{padding:6px 11px;font-size:.68rem;font-weight:600;color:var(--text3);border-bottom:2px solid transparent;white-space:nowrap;transition:all .12s}
.flow-tab.active{color:var(--gold);border-bottom-color:var(--gold)}
.flow-tab.done{color:var(--ok)}

/* QUIZ */
.quiz-option{display:flex;align-items:flex-start;gap:7px;padding:7px 10px;border-radius:8px;border:1px solid var(--bdr);cursor:pointer;font-size:.73rem;transition:all .12s;background:var(--bg3);margin-bottom:5px}
.quiz-option:hover{border-color:var(--gold)}.quiz-option.sel{border-color:var(--gold);background:var(--gdim);color:var(--gold3)}
.quiz-letter{width:18px;height:18px;border-radius:50%;background:var(--bdr);display:flex;align-items:center;justify-content:center;font-size:.6rem;font-weight:700;flex-shrink:0;margin-top:1px}
.quiz-option.sel .quiz-letter{background:var(--gold);color:#111}

/* EVAL */
.eval-cat{margin-bottom:12px}
.eval-cat-head{display:flex;align-items:center;justify-content:space-between;padding:8px 11px;background:var(--bg3);border-radius:var(--r);margin-bottom:7px;cursor:pointer;user-select:none}
.eval-cat-title{font-size:.76rem;font-weight:700}
.eval-cat-weight{font-size:.64rem;color:var(--gold);background:var(--gdim);padding:2px 8px;border-radius:5px;font-weight:700}
.eval-crit{display:flex;align-items:center;gap:8px;padding:6px 9px;border-radius:7px;margin-bottom:4px;background:var(--bg3);border:1px solid var(--bdr)}
.eval-crit-name{font-size:.71rem;font-weight:500;flex:1}
.eval-crit-desc{font-size:.59rem;color:var(--text3)}
.star-btn{width:25px;height:25px;border-radius:5px;display:flex;align-items:center;justify-content:center;font-size:.68rem;font-weight:700;cursor:pointer;border:1px solid var(--bdr);background:var(--bg2);transition:all .1s;color:var(--text3)}
.star-btn:hover{border-color:var(--gold);transform:scale(1.08)}
.star-btn.s1.on{background:var(--err-bg);border-color:var(--err);color:var(--err)}
.star-btn.s2.on{background:var(--warn-bg);border-color:var(--warn);color:var(--warn)}
.star-btn.s3.on{background:var(--ok-bg);border-color:var(--ok);color:var(--ok)}
.star-btn.s4.on{background:var(--gdim);border-color:var(--gold);color:var(--gold3)}

/* ARCH RESULT */
.result-card{border-radius:var(--r2);padding:16px;text-align:center;margin-bottom:12px}
.result-mb{background:linear-gradient(135deg,rgba(109,187,128,.1),rgba(109,187,128,.03));border:1px solid rgba(109,187,128,.25)}
.result-b{background:linear-gradient(135deg,rgba(229,184,74,.1),rgba(229,184,74,.03));border:1px solid rgba(229,184,74,.25)}
.result-m{background:linear-gradient(135deg,rgba(224,107,107,.1),rgba(224,107,107,.03));border:1px solid rgba(224,107,107,.25)}

/* PHOTO GRID */
.photo-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:7px;margin-bottom:8px}
.photo-slot{position:relative;aspect-ratio:1;background:var(--bg3);border:1.5px dashed var(--bdr);border-radius:var(--r);overflow:hidden;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;transition:border-color .14s,background .14s}
.photo-slot:hover{border-color:var(--gold);background:var(--gdim)}
.photo-slot.filled{border-style:solid;border-color:rgba(160,119,58,.5);background:var(--bg2)}
.photo-slot.filled:hover{border-color:var(--gold)}
.photo-slot img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;pointer-events:none}
.photo-slot .slot-lbl{font-size:.55rem;color:var(--text3);text-align:center;padding:0 4px;z-index:1;pointer-events:none}
.photo-slot .slot-ico{font-size:1.1rem;z-index:1;pointer-events:none}
.photo-slot .slot-req{font-size:.5rem;color:var(--gold);font-weight:700;z-index:1;pointer-events:none}
.photo-slot .slot-ov{position:absolute;inset:0;background:rgba(0,0,0,.65);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s;z-index:2}
.photo-slot.filled:hover .slot-ov{opacity:1}
.photo-slot .slot-rm{color:#fff;border:none;border-radius:4px;padding:3px 9px;font-size:.6rem;cursor:pointer;font-family:inherit;background:var(--err)}
.photo-slot .slot-rm:hover{filter:brightness(1.2)}

/* CONTRACT */
.contract-preview{background:#fff;color:#111;border-radius:var(--r2);padding:22px;font-size:.76rem;line-height:1.75;max-height:440px;overflow-y:auto}
.contract-preview h1{font-size:.95rem;text-align:center;font-weight:800;text-transform:uppercase;letter-spacing:.04em;margin-bottom:2px}
.contract-preview h2{font-size:.77rem;font-weight:700;margin:13px 0 5px;text-transform:uppercase;border-bottom:1px solid #e0e0e0;padding-bottom:2px;color:#333}
.contract-preview .clause{margin-bottom:9px;color:#444}
.contract-field{border-bottom:1px solid #444;display:inline-block;min-width:100px;color:#222;font-weight:600}
.sign-area{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:20px;padding-top:16px;border-top:1px solid #ccc}
.sign-box{text-align:center}.sign-line{border-bottom:1px solid #333;height:40px;margin-bottom:5px}

/* EXT FORM */
.ext-wrap{
  background:linear-gradient(160deg,#0d0d0d 0%,#111a00 60%,#0d0d0d 100%);
  min-height:100dvh;
  display:flex;
  align-items:flex-start;
  justify-content:center;
  padding:env(safe-area-inset-top,16px) 12px env(safe-area-inset-bottom,24px);
  box-sizing:border-box;
}
.ext-card{
  background:var(--bg2);
  border:1px solid var(--bdr);
  border-radius:14px;
  width:100%;
  max-width:560px;
  padding:22px 18px;
  margin:16px 0;
  box-shadow:0 8px 40px rgba(0,0,0,.5);
}
/* Mobile ext form */
@media (max-width:480px){
  .ext-card{
    border-radius:12px;
    padding:18px 14px;
    margin:8px 0;
  }
  .ext-wrap{
    padding:8px 8px;
    align-items:flex-start;
  }
}

/* PROGRESS BAR */
.progress-bar{height:4px;background:var(--bdr);border-radius:2px;overflow:hidden;margin-bottom:2px}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--gold),var(--gold3));transition:width .4s}

/* DETAILS GRID */
.details-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.detail-key{font-size:.57rem;color:var(--text3);font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.detail-val{font-size:.72rem;color:var(--text);margin-top:1px}

/* ARCH BADGE */
.arch-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:9px;font-size:.58rem;font-weight:700;background:var(--gdim);color:var(--gold3);border:1px solid rgba(160,119,58,.28)}

/* SIDEBAR LINK */
.ext-link-bar{padding:6px 11px;border-radius:7px;font-size:.65rem;color:var(--gold3);display:flex;align-items:center;justify-content:space-between;gap:7px;background:var(--gdim);border:1px solid var(--bdra);margin-bottom:10px}

/* TOAST */
#toast{position:fixed;top:54px;right:14px;z-index:9999;pointer-events:none}
.toast-msg{padding:8px 13px;border-radius:var(--r);font-size:.72rem;font-weight:600;margin-bottom:5px;border:1px solid;animation:fadeIn .2s ease}
.toast-s{background:var(--ok-bg);border-color:rgba(109,187,128,.28);color:var(--ok)}
.toast-e{background:var(--err-bg);border-color:rgba(224,107,107,.28);color:var(--err)}
.toast-i{background:var(--gdim);border-color:var(--bdr);color:var(--gold2)}
@keyframes fadeIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}

::-webkit-scrollbar{width:3px;height:3px}
/* Notification bell */
.timeline{display:flex;flex-direction:column;gap:0;position:relative}
.timeline::before{content:'';position:absolute;left:13px;top:8px;bottom:8px;width:1.5px;background:linear-gradient(to bottom,var(--gold)40%,var(--bdr));z-index:0}
.tl-item{display:flex;gap:9px;position:relative;z-index:1;padding-bottom:14px}
.tl-item:last-child{padding-bottom:0}
.tl-dot{width:27px;height:27px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;flex-shrink:0;border:2px solid var(--bg2);z-index:2}
.tl-content{flex:1;min-width:0}
.tl-label{font-size:.74rem;font-weight:600;color:var(--text);line-height:1.3}
.tl-detail{font-size:.64rem;color:var(--text2);margin-top:1px;line-height:1.4}
.tl-meta{font-size:.58rem;color:var(--text3);margin-top:2px;display:flex;gap:7px;flex-wrap:wrap}
.guide-box{background:var(--bg3);border-left:3px solid var(--gold);border-radius:0 var(--r) var(--r) 0;padding:7px 10px;margin:5px 0 7px;font-size:.68rem;color:var(--text2);line-height:1.55;display:none}
.eval-crit:hover .guide-box{display:block}
.guide-type-badge{display:inline-flex;align-items:center;gap:3px;font-size:.54rem;font-weight:700;padding:1px 6px;border-radius:8px;text-transform:uppercase;letter-spacing:.06em;margin-bottom:3px}
.gt-observe{background:rgba(112,169,212,.15);color:#5b8fd4}
.gt-ask{background:rgba(160,119,58,.15);color:var(--gold2)}
.gt-test{background:rgba(184,92,184,.15);color:#b85cb8}
.rubric-row{display:flex;gap:5px;margin-top:6px;flex-wrap:wrap}
.rubric-item{flex:1;min-width:110px;background:var(--bg4);border-radius:5px;padding:4px 7px;font-size:.58rem;color:var(--text3);line-height:1.4}
.rubric-item strong{display:block;margin-bottom:1px}
.rubric-item.r1 strong{color:var(--err)} .rubric-item.r2 strong{color:var(--warn)} .rubric-item.r3 strong{color:var(--ok)} .rubric-item.r4 strong{color:var(--gold)}
.sched-card{background:var(--bg2);border:1px solid var(--bdr);border-radius:var(--r);padding:11px 13px;transition:border-color .14s}
.sched-card:hover{border-color:rgba(160,119,58,.35)}
.sched-card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:9px}
.day-toggle{display:flex;gap:4px;flex-wrap:wrap}
.day-btn{width:32px;height:32px;border-radius:50%;border:1.5px solid var(--bdr);background:var(--bg3);color:var(--text3);font-size:.6rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .12s;font-family:inherit}
.day-btn.active{background:var(--gold);border-color:var(--gold);color:#111}
.day-btn.rest{background:rgba(226,75,74,.12);border-color:var(--err);color:var(--err)}
.day-btn:disabled{opacity:.35;cursor:default}
.sched-grid{border-collapse:collapse;width:100%}
.sched-grid th,.sched-grid td{border:1px solid var(--bdr);padding:4px 5px;font-size:.62rem;text-align:center}
.sched-grid th{background:var(--bg3);font-weight:700;color:var(--text2)}
.sched-cell-model{border-radius:4px;padding:3px 5px;font-size:.6rem;font-weight:700;white-space:nowrap}
.sched-cell-empty{color:var(--text3);font-size:.55rem}
.sched-cell-rest{background:rgba(142,142,142,.1);color:var(--text3);font-style:italic;font-size:.55rem}
.eval-progress-bar{height:4px;background:var(--bdr);border-radius:2px;overflow:hidden;margin-bottom:10px}
.eval-progress-fill{height:100%;background:linear-gradient(90deg,var(--gold),var(--gold3));border-radius:2px;transition:width .3s}
.na-btn{padding:2px 7px;border:1px solid var(--bdr);border-radius:4px;background:none;color:var(--text3);font-size:.58rem;cursor:pointer;font-family:inherit}
.na-btn.active{background:var(--bg4);color:var(--text2);border-color:var(--text3)}
.op30{opacity:.3} .op50{opacity:.5}
.iv-locked{background:var(--bg3);border:1px solid var(--bdr);border-radius:var(--r);padding:10px 12px}
.iv-locked-badge{display:inline-flex;align-items:center;gap:4px;background:rgba(160,119,58,.12);border:1px solid rgba(160,119,58,.25);color:var(--gold2);font-size:.6rem;font-weight:700;padding:2px 8px;border-radius:10px;margin-bottom:7px}
@keyframes spin{to{transform:rotate(360deg)}}
.scanner-modal{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:1000;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:0}
.scanner-topbar{width:100%;display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:rgba(0,0,0,.7);flex-shrink:0}
.scanner-body{flex:1;width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0 12px;gap:10px;overflow:hidden}
.scanner-canvas-wrap{position:relative;width:100%;max-width:560px;border-radius:10px;overflow:hidden;background:#000}
.scanner-canvas-wrap canvas{display:block;width:100%;height:auto}
.scanner-canvas-wrap video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;pointer-events:none}
.scanner-hint{font-size:.72rem;color:rgba(255,255,255,.75);text-align:center;padding:0 20px;line-height:1.5}
.scanner-guide{position:absolute;inset:0;pointer-events:none;display:flex;align-items:center;justify-content:center}
.scanner-guide-frame{width:75%;height:55%;border:2px solid rgba(255,255,255,.25);border-radius:6px;box-shadow:0 0 0 9999px rgba(0,0,0,.35)}
.scanner-guide-frame.landscape{width:82%;height:52%;border-radius:8px}
.scanner-guide-label{position:absolute;bottom:-22px;left:50%;transform:translateX(-50%);font-size:.6rem;color:rgba(255,255,255,.7);white-space:nowrap;background:rgba(0,0,0,.4);padding:2px 8px;border-radius:4px}
.scanner-btn-row{display:flex;gap:10px;align-items:center;justify-content:center;flex-wrap:wrap;padding:10px 0 16px}
.scanner-capture-btn{width:66px;height:66px;border-radius:50%;background:#fff;border:4px solid rgba(160,119,58,.8);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.4rem;transition:transform .1s;flex-shrink:0}
.scanner-capture-btn:active{transform:scale(.93)}
.scanner-status{font-size:.65rem;padding:4px 12px;border-radius:20px;font-weight:600}
.scanner-preview-wrap{width:100%;max-width:560px;background:#111;border-radius:10px;overflow:hidden;display:flex;flex-direction:column;gap:10px;padding:14px}
.cv-status{position:absolute;top:8px;left:0;right:0;text-align:center;font-size:.62rem;color:rgba(255,255,255,.7);pointer-events:none}
.notif-bell{position:relative;background:none;border:none;cursor:pointer;padding:6px 8px;border-radius:var(--r);color:var(--text2);transition:all .12s;display:flex;align-items:center;justify-content:center}
.notif-bell:hover{background:var(--bg3);color:var(--text)}
.notif-badge{position:absolute;top:2px;right:2px;background:var(--err);color:#fff;font-size:.48rem;font-weight:800;min-width:14px;height:14px;border-radius:7px;display:flex;align-items:center;justify-content:center;padding:0 3px;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.15)}}
.notif-panel{position:fixed;top:44px;right:0;width:320px;max-height:calc(100vh - 44px);background:var(--bg2);border-left:1px solid var(--bdr);border-bottom:1px solid var(--bdr);overflow-y:auto;z-index:500;box-shadow:-4px 4px 20px rgba(0,0,0,.4)}
.notif-item{display:flex;align-items:flex-start;gap:9px;padding:10px 13px;border-bottom:1px solid var(--bdr);cursor:pointer;transition:background .1s}
.notif-item:hover{background:var(--bg3)}
.notif-item.unread{background:var(--gdim)}
.notif-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:4px}
/* Mini charts */
.sparkbar{display:inline-flex;align-items:flex-end;gap:2px;height:32px}
.sparkbar span{display:inline-block;background:var(--gold);border-radius:1px;min-width:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--gold);border-radius:2px}

/* ================================================================
   RESPONSIVE SYSTEM
   ================================================================ */

/* Hamburger — hidden on desktop */
#mob_menu_btn {
  display: none;
  align-items: center;
  justify-content: center;
  background: none;
  border: 1px solid transparent;
  border-radius: var(--r);
  cursor: pointer;
  padding: 5px;
  color: var(--text2);
  flex-shrink: 0;
  transition: all .15s;
}
#mob_menu_btn:hover, #mob_menu_btn:active {
  background: var(--bg3);
  border-color: var(--bdr);
  color: var(--text);
}

/* Overlay */
#sb_overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.55);
  z-index: 149;
}
#sb_overlay.visible { display: block; }

/* ── Tablet & Mobile < 1024px ─────────────────────────────── */
@media (max-width: 1023px) {
  #mob_menu_btn { display: flex; }

  .sb {
    position: fixed !important;
    top: 0;
    left: -220px;
    height: 100dvh;
    z-index: 150;
    transition: left .28s cubic-bezier(.4,0,.2,1);
    box-shadow: 4px 0 30px rgba(0,0,0,.5);
    width: 210px;
  }
  .sb.open { left: 0 !important; }

  .main { width: 100vw; }
  .topbar { padding: 0 10px !important; }
}

/* ── Mobile < 768px ───────────────────────────────────────── */
@media (max-width: 767px) {
  /* Prevent horizontal scroll */
  body, .app, .main, .content { max-width: 100vw; overflow-x: hidden; }

  .content { padding: 8px !important; }
  .card { padding: 10px !important; }

  /* Page title */
  .page-title { font-size: .75rem !important; }

  /* Topbar user — compact */
  #topbar_role { display: none !important; }
  #topbar_name { max-width: 90px !important; font-size: .65rem !important; }
  #topbar_user_btn { padding: 3px 6px 3px 3px !important; }

  /* Forms */
  .form-grid { grid-template-columns: 1fr !important; }
  .form-group.full { grid-column: 1 !important; }

  /* Dashboard stat cards — 2 columns */
  .stat-card-grid { grid-template-columns: repeat(2, 1fr) !important; }

  /* Generic grids */
  .grid-4 { grid-template-columns: repeat(2, 1fr) !important; }
  .grid-3 { grid-template-columns: repeat(2, 1fr) !important; }

  /* Tables scroll */
  .table-scroll { overflow-x: auto !important; -webkit-overflow-scrolling: touch; }
  .table-scroll table { min-width: 540px; }

  /* Modals */
orm-grid {
    grid-template-columns: 1fr !important;
  }

  /* Modal — mobile bottom sheet */
  .modal-overlay { align-items: flex-end !important; }
  .modal-dynamic {
    width: 100vw !important;
    max-width: 100vw !important;
    border-radius: 16px 16px 0 0 !important;
    position: fixed !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    margin: 0 !important;
    max-height: 90dvh !important;
  }
  .modal-dynamic .modal-body {
    max-height: calc(90dvh - 54px) !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch !important;
  }
  .modal-dynamic .modal-inner .form-grid {
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
  }
  .modal-dynamic .modal-inner .form-group {
    width: 100% !important;
  }

  /* Two-panel module layouts — stack on mobile */
  #biogen-grid,
  .two-panel-layout {
    grid-template-columns: 1fr !important;
    height: auto !important;
    overflow: visible !important;
  }
  #biogen-grid > div,
  .two-panel-layout > div {
    max-height: 60vh !important;
    overflow-y: auto !important;
  }

  /* Settings main grid — single column on mobile */
  .settings-grid {
    grid-template-columns: 1fr !important;
  }

  /* Contract preview in modals */
  .contract-preview {
    font-size: 9pt !important;
    padding: 10px !important;
    max-height: calc(80dvh - 80px) !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    word-wrap: break-word !important;
  }
  .contract-preview table {
    font-size: 8pt !important;
    display: block !important;
    overflow-x: auto !important;
  }
  .doc-sigs {
    grid-template-columns: 1fr !important;
    gap: 20px !important;
  }

  /* Buttons */
  .btn { font-size: .68rem !important; padding: 6px 10px !important; }
  .btn-sm { font-size: .6rem !important; padding: 3px 7px !important; }

  /* Hide on mobile */
  .hide-sm { display: none !important; }
}

/* ── Small phones < 480px ─────────────────────────────────── */
@media (max-width: 479px) {
  .sb { width: 82vw; left: -83vw; }
  .content { padding: 6px !important; }
  .card { padding: 8px !important; border-radius: 8px !important; }
  .stat-card-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .page-title { font-size: .7rem !important; max-width: 120px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  /* Modal full-screen on small phones */
  .modal-overlay { align-items: flex-end; }
  .modal-dynamic { width: 100vw !important; max-width: 100vw !important; border-radius: 14px 14px 0 0 !important; max-height: 92vh; }
  .modal-body { max-height: calc(92vh - 55px) !important; }
  /* Bigger time inputs for attendance on mobile */
  input[type="time"] { min-height: 40px; font-size: 15px !important; }
}

/* ── Prevent iOS zoom on inputs ───────────────────────────── */
@media (max-width: 767px) {
  input[type="text"],
  input[type="email"],
  input[type="password"],
  input[type="number"],
  input[type="tel"],
  input[type="date"],
  select,
  textarea { font-size: 16px !important; }
}

/* ── Touch targets ────────────────────────────────────────── */
@media (hover: none) {
  .nav-item { min-height: 44px !important; }
  .btn { min-height: 38px; }
  .form-control { min-height: 42px; }
}

/* ================================================================
   MOBILE APP ENHANCEMENTS
   ================================================================ */

/* Safe area for notch / home indicator */
.topbar { padding-top: env(safe-area-inset-top, 0); }
.content { padding-bottom: calc(env(safe-area-inset-bottom, 0) + 60px); }

/* Pull to Refresh indicator */
#ptr-indicator {
  position: fixed;
  top: -60px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--bg2);
  border: 1px solid var(--bdr);
  border-radius: 24px;
  padding: 8px 16px;
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: .68rem;
  color: var(--text2);
  z-index: 300;
  transition: top .2s ease;
  pointer-events: none;
  white-space: nowrap;
  box-shadow: 0 4px 16px rgba(0,0,0,.3);
}
#ptr-indicator.pulling { top: 12px; }
#ptr-indicator.refreshing { top: 12px; }
#ptr-spinner {
  width: 14px; height: 14px;
  border: 2px solid var(--bdr);
  border-top-color: var(--gold);
  border-radius: 50%;
}
#ptr-spinner.spin {
  animation: spin .7s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* Bottom Navigation Bar */
#bottom_nav {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  height: calc(56px + env(safe-area-inset-bottom, 0));
  padding-bottom: env(safe-area-inset-bottom, 0);
  background: #0d0d0d;
  border-top: 1px solid var(--bdr);
  z-index: 100;
  justify-content: space-around;
  align-items: center;
}
.bnav-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
  padding: 6px 12px;
  border: none;
  background: none;
  cursor: pointer;
  font-family: inherit;
  color: var(--text3);
  font-size: .52rem;
  font-weight: 600;
  transition: color .15s;
  min-width: 48px;
  min-height: 48px;
  border-radius: 10px;
  -webkit-tap-highlight-color: transparent;
}
.bnav-item svg { transition: transform .15s; }
.bnav-item.active { color: var(--gold); }
.bnav-item.active svg { transform: scale(1.1); }
.bnav-item:active { background: var(--bg3); }

/* Show bottom nav on mobile */
@media (max-width: 767px) {
  #bottom_nav { display: flex; }
  .content { padding-bottom: calc(env(safe-area-inset-bottom, 0) + 70px) !important; }
}

/* Swipe edge hint */
#swipe_edge {
  position: fixed;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 4px;
  height: 60px;
  background: var(--gold);
  border-radius: 0 4px 4px 0;
  opacity: 0;
  z-index: 99;
  transition: opacity .3s;
  pointer-events: none;
}

/* Page transition */
.content { transition: opacity .15s ease; }
.content.transitioning { opacity: 0; }

/* ── Topbar user widget text colors ─── */
#topbar_user_btn { color: var(--text) !important; }
#topbar_name { color: var(--text) !important; }
#topbar_role { color: var(--text3) !important; }
/* #topbar_avatar color is set dynamically by renderSessionBadge() */

/* ── Sidebar footer — contained width ─ */
.sb-footer {
  width: 100%;
  box-sizing: border-box;
  overflow: hidden;
}
.sb-footer .av-name,
.sb-footer .av-role {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--text);
}

/* ── User dropdown — never full width ─ */
#user_dropdown { max-width: 260px !important; }
#dd_user_name { color: var(--text) !important; }

/* ── Table horizontal scroll fix ─── */
@media (max-width: 767px) {
  .tbl-wrap {
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
    max-width: calc(100vw - 16px);
    border-radius: var(--r);
  }
  .tbl-wrap table {
    min-width: 480px;
    font-size: .62rem !important;
  }
  .tbl-wrap th,
  .tbl-wrap td {
    padding: 6px 8px !important;
    white-space: nowrap;
  }
  /* Hide less important columns on mobile */
  .tbl-wrap th:nth-child(7),
  .tbl-wrap td:nth-child(7) { display: none; }

  /* Prevent page-level horizontal scroll */
  html, body { overflow-x: hidden !important; max-width: 100vw; }
  .page { overflow-x: hidden; max-width: 100%; }

  /* Fix cards overflowing */
  .card { max-width: 100%; box-sizing: border-box; }

  /* Fix any element with inline width */
  [style*="width:"] { max-width: 100% !important; }
}


/* Collapsed state */
.sb.collapsed { width: 54px !important; }
/* Brand states */
.sb.collapsed 
.sb.collapsed 

.sb.collapsed .nav-section { opacity: 0; height: 0; padding: 0; overflow: hidden; }
.sb.collapsed .nav-item { padding: 9px 0; justify-content: center; gap: 0; border-left: none; border-bottom: none; }
.sb.collapsed .nav-item svg { flex-shrink: 0; }
.sb.collapsed .nav-item-label { display: none; }
.sb.collapsed .sb-footer { padding: 9px 0; justify-content: center; }
.sb.collapsed .sb-footer .av-name,
.sb.collapsed .sb-footer .av-role,
.sb.collapsed .sb-footer > svg:last-child { display: none; }
.sb.collapsed 

/* Tooltip on collapsed nav items */
.sb.collapsed .nav-item { position: relative; }
.sb.collapsed .nav-item::after {
  content: attr(data-label);
  position: absolute;
  left: calc(100% + 10px);
  top: 50%;
  transform: translateY(-50%);
  background: var(--bg3);
  color: var(--text);
  font-size: .65rem;
  font-weight: 600;
  padding: 4px 10px;
  border-radius: 6px;
  border: 1px solid var(--bdr);
  white-space: nowrap;
  pointer-events: none;
  opacity: 0;
  transition: opacity .15s;
  z-index: 300;
  box-shadow: 2px 2px 12px rgba(0,0,0,.4);
}
.sb.collapsed .nav-item:hover::after { opacity: 1; }

/* Active item indicator in collapsed mode */
.sb.collapsed .nav-item.active { 
  border-left: 2px solid var(--gold);
  color: var(--gold);
}
.sb.collapsed .nav-item.active svg { color: var(--gold); }

/* Hide on mobile — sidebar is always full width when open */
@media (max-width: 1023px) {
  .sb.collapsed { width: 210px !important; }
  .sb.collapsed .nav-section { opacity: 1; height: auto; padding: 10px 13px 3px; }
  .sb.collapsed .nav-item { padding: 7px 13px; justify-content: flex-start; gap: 7px; }
  .sb.collapsed .nav-item-label { display: inline; }
  .sb.collapsed .sb-footer { padding: 9px 13px; justify-content: flex-start; }
  .sb.collapsed .sb-footer .av-name,
  .sb.collapsed .sb-footer .av-role,
  .sb.collapsed .sb-footer > svg:last-child { display: flex; }
  
}

/* ================================================================
   COLLAPSIBLE SIDEBAR
   ================================================================ */

/* Brand area layout */
.brand {
  display: flex !important;
  align-items: center;
  justify-content: space-between;
  padding: 0 10px 0 16px !important;
  flex-shrink: 0;
}

/* Collapsed state */
.sb.collapsed {
  width: 56px !important;
}
.sb.collapsed .nav-item {
  justify-content: center !important;
  padding: 10px 0 !important;
  border-left: none !important;
  border-radius: 8px !important;
  margin: 1px 6px !important;
  position: relative;
}
.sb.collapsed .nav-item svg {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
}
.sb.collapsed .nav-item.active {
  background: var(--gold-dim, rgba(200,168,75,.12)) !important;
  color: var(--gold) !important;
}
.sb.collapsed .sb-footer {
  justify-content: center;
  padding: 10px 0 !important;
}
.sb.collapsed .sb-footer .av {
  width: 32px !important;
  height: 32px !important;
  font-size: .7rem !important;
}

/* Tooltip on collapsed items */
.sb.collapsed .nav-item::after {
  content: attr(data-label);
  position: absolute;
  left: calc(100% + 8px);
  top: 50%;
  transform: translateY(-50%);
  background: var(--bg2);
  color: var(--text);
  font-size: .65rem;
  font-weight: 600;
  padding: 4px 10px;
  border-radius: 6px;
  border: 1px solid var(--bdr);
  white-space: nowrap;
  pointer-events: none;
  opacity: 0;
  transition: opacity .15s;
  z-index: 500;
  box-shadow: 2px 2px 12px rgba(0,0,0,.4);
}
.sb.collapsed .nav-item:hover::after {
  opacity: 1;
}

/* Smooth transition */
.sb {
  transition: width .25s cubic-bezier(.4,0,.2,1) !important;
  overflow: hidden;
}
.sb * {
  transition: opacity .15s ease, display 0s;
}

/* Hide toggle button on mobile (hamburger handles it) */
@media (max-width: 1023px) {
  #sb_toggle_btn { display: none !important; }
  .sb.collapsed { width: 210px !important; }
}


/* Sidebar needs relative for absolute toggle */
.sb { position: relative; }

/* ── Collapsed state ─────────────────────────────────────── */
.sb.collapsed { width: 54px !important; }

/* Nav sections */
.sb.collapsed .nav-section {
  height: 4px; padding: 0; overflow: hidden; opacity: 0;
}

/* Nav items */
.sb.collapsed .nav-item {
  padding: 9px 0 !important;
  justify-content: center !important;
  gap: 0 !important;
}
.sb.collapsed .nav-item.active {
  border-left: 2px solid var(--gold) !important;
}
.sb.collapsed .nav-item-label { display: none !important; }

/* Tooltip */
.sb.collapsed .nav-item::after {
  content: attr(data-label);
  position: absolute;
  left: calc(100% + 16px);
  top: 50%;
  transform: translateY(-50%);
  background: var(--bg2);
  color: var(--text);
  font-size: .66rem;
  font-weight: 600;
  padding: 5px 10px;
  border-radius: 6px;
  border: 1px solid var(--bdr);
  white-space: nowrap;
  pointer-events: none;
  opacity: 0;
  z-index: 500;
  box-shadow: 2px 4px 16px rgba(0,0,0,.5);
  transition: opacity .12s;
}
.sb.collapsed .nav-item:hover::after { opacity: 1; }

/* Footer */
.sb.collapsed .sb-footer {
  padding: 9px 0 !important;
  justify-content: center !important;
}
.sb.collapsed .sb-footer .av-name,
.sb.collapsed .sb-footer .av-role,
.sb.collapsed .sb-footer > svg:last-child { display: none !important; }

/* ── Mobile — disable collapse ───────────────────────────── */
@media (max-width: 1023px) {
  .sb.collapsed { width: 210px !important; }
  .sb.collapsed .nav-section { height: auto; padding: 10px 13px 3px; opacity: 1; }
  .sb.collapsed .nav-item { padding: 7px 13px !important; justify-content: flex-start !important; gap: 7px !important; }
  .sb.collapsed .nav-item-label { display: inline !important; }
  .sb.collapsed .sb-footer { padding: 9px 13px !important; justify-content: flex-start !important; }
  .sb.collapsed .sb-footer .av-name,
  .sb.collapsed .sb-footer .av-role { display: block !important; }
}



/* ── Brand expanded/collapsed ──────────────────────────────────── */
.brand { height:52px; padding:0 13px; border-bottom:1px solid var(--bdr); display:flex; align-items:center; flex-shrink:0; box-sizing:border-box; }



/* Collapsed state */
.sb.collapsed 
.sb.collapsed 


/* Toggle buttons */




/* Mobile — always show expanded */
@media (max-width: 1023px) {
  
  .sb.collapsed 
  .sb.collapsed 
  
}


/* ================================================================
   BRAND — Single clean definition
   ================================================================ */
.brand-expanded {
  display: flex !important;
  flex-direction: column;
  justify-content: center;
  width: 100%;
  gap: 2px;
}
.brand-expanded-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
}
.brand-collapsed {
  display: none !important;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  width: 100%;
  overflow: hidden;
}

/* Collapsed sidebar */
.sb.collapsed .brand { justify-content: center; padding: 0; height: 56px; overflow: hidden; }
.sb.collapsed .brand-expanded { display: none !important; }
.sb.collapsed .brand-collapsed { display: flex !important; }

/* Toggle buttons */
#sb_toggle, .brand-expand-btn {
  width: 24px;
  height: 24px;
  background: var(--bg3);
  border: 1px solid var(--bdr);
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--text2);
  transition: all .18s;
  padding: 0;
  flex-shrink: 0;
}
#sb_toggle:hover, .brand-expand-btn:hover {
  background: var(--gold);
  color: #111;
  border-color: var(--gold);
}
#sb_toggle svg { transition: transform .25s; }

/* Mobile */
@media (max-width: 1023px) {
  #sb_toggle, .brand-expand-btn { display: none !important; }
  .sb.collapsed .brand-expanded { display: flex !important; }
  .sb.collapsed .brand-collapsed { display: none !important; }
  .sb.collapsed .brand { height: 58px !important; padding: 0 13px !important; justify-content: flex-start !important; }
}

/* ================================================================
   DETAIL VIEW — Responsive 2-column layout
   ================================================================ */
/* Model view grid — responsive */
.mview-grid {
  display: grid;
  grid-template-columns: 1fr 190px;
  gap: 9px;
  align-items: start;
}
.mview-grid > div {
  min-width: 0;
  overflow: hidden;
}
@media (max-width: 767px) {
  .mview-grid {
    grid-template-columns: 1fr !important;
  }
  .mview-grid > div:first-child { order: 1; }
  .mview-grid > div:last-child  { order: 2; }
}
@media (max-width: 479px) {
  .mview-grid > div:last-child .btn {
    width: 100%;
    justify-content: center;
  }
  .slot-lbl { font-size: .55rem !important; }
  .slot-hint { font-size: .5rem !important; }
}

/* Action buttons row — wrap nicely on mobile */
.action-row {
  display: flex;
  gap: 5px;
  margin-bottom: 10px;
  flex-wrap: wrap;
}
.action-row .btn {
  flex-shrink: 0;
}
@media (max-width: 600px) {
  .action-row .btn-sm { font-size: .65rem; padding: 4px 8px; }
}

/* Tablet: slightly narrower right panel */
@media (max-width: 1023px) {
  .detail-view-grid {
    grid-template-columns: 1fr 160px;
  }
}

/* Mobile: full-width stacked */
@media (max-width: 767px) {
  .detail-view-grid {
    grid-template-columns: 1fr !important;
  }
  .detail-view-grid > div:last-child {
    /* Right panel goes ABOVE on mobile (actions first) */
    order: -1;
  }

  /* Action buttons smaller on mobile */
  .action-row .btn-sm {
    font-size: .62rem !important;
    padding: 5px 8px !important;
  }
}

/* ── Info grids inside detail cards ─── */
@media (max-width: 479px) {
  /* Stack 2-col info grids on small phones */
  .card [style*="grid-template-columns:1fr 1fr"] {
    grid-template-columns: 1fr !important;
  }
  /* Right panel actions — make buttons full width */  
  .detail-view-grid > div:last-child .btn {
    width: 100%;
    justify-content: center;
  }
}

/* ── Card head / header on mobile ─── */
@media (max-width: 767px) {
  .card-head {
    flex-wrap: wrap;
    gap: 6px;
  }
  /* prospect/model name header */
  .detail-view-grid .card:first-child h2,
  .detail-view-grid .card:first-child [style*="font-size:1."] {
    font-size: .88rem !important;
  }
}

/* ── Photo grid responsive ─────────────────────────────────── */
@media (max-width: 767px) {
  /* 2 cols on mobile — slots are bigger and easier to tap */
  .photo-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 8px !important; }

  /* Bigger slot labels */
  .photo-slot .slot-lbl { font-size: .65rem !important; padding: 0 6px !important; }
  .photo-slot .slot-ico  { font-size: 1.4rem !important; }
  .photo-slot .slot-req  { font-size: .58rem !important; }

  /* Scan/gallery hint text */
  .photo-slot [style*="font-size:.48rem"] { font-size: .6rem !important; }

  /* Overlay buttons bigger for touch */
  .slot-rm { padding: 5px 12px !important; font-size: .65rem !important; }

  /* Slot min height for comfortable touch */
  .photo-slot { min-height: 100px; }
}

@media (max-width: 479px) {
  /* Still 2 cols on small phones but tighter gap */
  .photo-grid { gap: 6px !important; }
}

/* Tablet: 3 cols */
@media (min-width: 768px) and (max-width: 1023px) {
  .photo-grid { grid-template-columns: repeat(3, 1fr) !important; }
}

/* Slot upload hint */
.slot-hint {
  font-size: .48rem;
  color: var(--text3);
  text-align: center;
  padding: 0 4px;
}
@media (max-width: 767px) {
  .slot-hint { font-size: .6rem !important; }
}

/* ================================================================
   SCANNER — Mobile optimized
   ================================================================ */
@media (max-width: 767px) {
  .scanner-modal {
    padding: 0 !important;
    background: #000 !important;
  }
  .scanner-topbar {
    padding: 8px 12px !important;
    padding-top: calc(8px + env(safe-area-inset-top, 0)) !important;
    background: rgba(0,0,0,.85) !important;
    flex-shrink: 0;
  }
  .scanner-body {
    padding: 0 !important;
    gap: 0 !important;
    justify-content: flex-start !important;
    flex: 1;
    overflow: hidden;
  }
  /* Canvas wrap fills ALL remaining space */
  .scanner-canvas-wrap {
    max-width: 100% !important;
    width: 100% !important;
    border-radius: 0 !important;
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
  }
  /* Canvas fills the wrap */
  .scanner-canvas-wrap canvas {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover;
  }
  /* Video also fills the wrap */
  .scanner-canvas-wrap video {
    object-fit: cover !important;
  }

  /* Guide frame more visible */
  .scanner-guide-frame {
    border: 2.5px solid var(--gold) !important;
    border-radius: 10px !important;
    box-shadow: 0 0 0 9999px rgba(0,0,0,.45) !important;
  }

  /* Corner markers like a real scanner */
  .scanner-guide-frame::before,
  .scanner-guide-frame::after {
    content: '';
    position: absolute;
    width: 20px;
    height: 20px;
    border-color: var(--gold);
    border-style: solid;
  }
  .scanner-guide-frame::before {
    top: -2px; left: -2px;
    border-width: 3px 0 0 3px;
    border-radius: 4px 0 0 0;
  }
  .scanner-guide-frame::after {
    bottom: -2px; right: -2px;
    border-width: 0 3px 3px 0;
    border-radius: 0 0 4px 0;
  }

  /* Hint text */
  .scanner-hint {
    font-size: .68rem !important;
    padding: 6px 16px !important;
    background: rgba(0,0,0,.6);
    width: 100%;
  }

  /* Bottom controls bar */
  .scanner-btn-row {
    padding: 12px 0 calc(16px + env(safe-area-inset-bottom, 0)) !important;
    background: rgba(0,0,0,.7);
    width: 100%;
    gap: 20px !important;
  }

  /* Bigger capture button for thumb */
  .scanner-capture-btn {
    width: 76px !important;
    height: 76px !important;
    font-size: 1.8rem !important;
    border-width: 5px !important;
    box-shadow: 0 0 0 3px rgba(160,119,58,.3);
  }

  /* Flip/gallery buttons bigger */
  .scanner-btn-row .btn {
    min-height: 44px !important;
    padding: 8px 16px !important;
    font-size: .72rem !important;
  }
}

/* Landscape phone scanner */
@media (max-width: 767px) and (orientation: landscape) {
  .scanner-canvas-wrap {
    aspect-ratio: 4/3 !important;
    max-height: 60vh;
  }
  .scanner-btn-row {
    padding: 8px 0 calc(8px + env(safe-area-inset-bottom, 0)) !important;
  }
  .scanner-capture-btn {
    width: 60px !important;
    height: 60px !important;
  }
}

/* ================================================================
   CONTRACT / DOCUMENT PREVIEW — Word-like formatting
   ================================================================ */
.contract-preview {
  background: #fff;
  color: #111;
  font-family: 'Times New Roman', Times, serif;
  font-size: 11pt;
  line-height: 1.5;
  padding: 72px 80px;          /* 1-inch margins approx */
  max-width: 820px;
  margin: 0 auto;
  box-shadow: 0 2px 20px rgba(0,0,0,.15);
  border-radius: 4px;
}

/* Title block */
.contract-preview .doc-title {
  font-size: 15pt;
  font-weight: 800;
  text-align: center;
  margin: 0 0 4px 0;
  text-transform: uppercase;
}
.contract-preview .doc-subtitle {
  font-size: 13pt;
  font-weight: 700;
  text-align: center;
  margin: 0 0 4px 0;
}
.contract-preview .doc-sub2 {
  font-size: 11.5pt;
  font-weight: 700;
  text-align: center;
  margin: 0 0 4px 0;
}
.contract-preview .doc-ref {
  font-size: 10.5pt;
  text-align: center;
  margin: 10px 0 24px 0;
}

/* Section headings */
.contract-preview .doc-section {
  font-size: 12pt;
  font-weight: 700;
  text-align: left;
  margin: 18px 0 6px 0;
  text-transform: uppercase;
}

/* Annex headings */
.contract-preview .doc-annex {
  font-size: 13pt;
  font-weight: 700;
  text-align: left;
  margin: 28px 0 8px 0;
  padding-top: 10px;
  border-top: 2px solid #333;
  text-transform: uppercase;
}

/* Body text — justified */
.contract-preview p {
  text-align: justify;
  font-size: 11pt;
  margin: 0 0 6px 0;
  line-height: 1.6;
}

/* List items — bullet with hanging indent */
.contract-preview ul {
  margin: 0 0 6px 0;
  padding-left: 28px;
  list-style: disc;
}
.contract-preview ul li {
  text-align: justify;
  font-size: 11pt;
  margin-bottom: 5px;
  line-height: 1.6;
}

/* Parágrafo style */
.contract-preview .doc-para {
  text-align: justify;
  font-size: 11pt;
  margin: 0 0 6px 0;
  line-height: 1.6;
}

/* Signature block */
.contract-preview .doc-sigs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 50px;
  margin-top: 50px;
}
.contract-preview .doc-sig-box {
  border-top: 2px solid #333;
  padding-top: 10px;
  font-size: 11pt;
  line-height: 1.8;
}

/* Field highlight (filled data) */
.contract-preview .doc-field {
  background: rgba(200,168,75,.12);
  color: #7a5c00;
  padding: 0 3px;
  border-radius: 2px;
  font-weight: 600;
}

/* Print styles */
@media print {
  /* Hide everything except the document being printed */
  body > *:not(#print_root) { display: none !important; }
  #print_root { display: block !important; }
  .modal-overlay, .sidebar, .bottom-nav, .header-bar,
  .toast-container, #login_screen { display: none !important; }

  #print_root {
    position: fixed;
    inset: 0;
    background: white;
    z-index: 99999;
    padding: 20mm 25mm;
    overflow: visible;
  }
  #print_root .contract-preview {
    padding: 0;
    box-shadow: none;
    font-size: 10.5pt;
    color: #000 !important;
    background: white !important;
    max-height: none !important;
    overflow: visible !important;
  }
  #print_root * { color: #000 !important; background: transparent !important; }
  #print_root a { text-decoration: none !important; color: #000 !important; }
}

/* ── Document Tables (Word-style, B&W) ─────────────────────────── */
.contract-preview .doc-table {
  width: 100%;
  border-collapse: collapse;
  margin: 10px 0 14px 0;
  font-size: 10.5pt;
  font-family: 'Times New Roman', Times, serif;
}
.contract-preview .doc-table th {
  background: #000;
  color: #fff;
  font-weight: 700;
  text-align: center;
  padding: 7px 10px;
  border: 1px solid #000;
  font-size: 10pt;
}
.contract-preview .doc-table td {
  border: 1px solid #333;
  padding: 6px 10px;
  text-align: left;
  vertical-align: top;
  line-height: 1.5;
}
.contract-preview .doc-table tr:nth-child(even) td {
  background: #f5f5f5;
}
.contract-preview .doc-table tr:hover td {
  background: #efefef;
}

/* Signature table — no zebra stripes */
.contract-preview .doc-sig-table {
  margin-top: 50px;
}
.contract-preview .doc-sig-table td {
  vertical-align: top;
  padding: 12px 16px;
  border-top: 2px solid #000;
  border-left: none;
  border-right: none;
  border-bottom: none;
  background: transparent !important;
  font-size: 11pt;
  line-height: 2;
  width: 50%;
}

/* ── Document status badges ────────────────────────────────────── */
.doc-badge {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  font-size: .6rem;
  font-weight: 700;
  padding: 3px 8px;
  border-radius: 10px;
  white-space: nowrap;
}
.doc-badge-none    { background: var(--bg3);                color: var(--text3); }
.doc-badge-signed  { background: rgba(34,197,94,.15);       color: #22c55e; }
.doc-badge-sent    { background: rgba(99,179,237,.15);      color: #63b3ed; }
.doc-badge-pending { background: rgba(234,179,8,.15);       color: var(--warn); }

/* ================================================================
   PRINT STYLES
   ================================================================ */
@media print {
  /* Hide everything */
  body > *:not(#print_container) { display: none !important; }

  /* Show only print container */
  #print_container {
    display: block !important;
    font-family: 'Times New Roman', Times, serif !important;
    font-size: 11pt !important;
    line-height: 1.65 !important;
    color: #111 !important;
    background: #fff !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  /* Document styles for print */
  #print_container .doc-title    { font-size:15pt; font-weight:800; text-align:center; text-transform:uppercase; margin:0 0 4px; }
  #print_container .doc-subtitle { font-size:13pt; font-weight:700; text-align:center; margin:0 0 4px; }
  #print_container .doc-sub2     { font-size:11.5pt; font-weight:700; text-align:center; margin:0 0 4px; }
  #print_container .doc-ref      { font-size:10.5pt; text-align:center; margin:8px 0 20px; }
  #print_container .doc-section  { font-size:12pt; font-weight:700; text-transform:uppercase; margin:16px 0 5px; page-break-after:avoid; }
  #print_container .doc-annex    { font-size:13pt; font-weight:700; text-transform:uppercase; margin:24px 0 7px; padding-top:8px; border-top:2px solid #000; page-break-before:auto; }
  #print_container p             { text-align:justify; margin:0 0 5px; line-height:1.65; }
  #print_container ul            { margin:0 0 6px; padding-left:24px; }
  #print_container ul li         { text-align:justify; margin-bottom:4px; }
  #print_container table         { width:100%; border-collapse:collapse; margin:8px 0 12px; font-size:10.5pt; }
  #print_container th            { background:#000 !important; color:#fff !important; font-weight:700; text-align:center; padding:6px 8px; border:1px solid #000; -webkit-print-color-adjust:exact; print-color-adjust:exact; }
  #print_container td            { border:1px solid #333; padding:5px 8px; vertical-align:top; }
  #print_container tr:nth-child(even) td { background:#f5f5f5 !important; -webkit-print-color-adjust:exact; print-color-adjust:exact; }
  #print_container .doc-sigs     { display:grid; grid-template-columns:1fr 1fr; gap:40px; margin-top:40px; }
  #print_container .doc-sig-box  { border-top:2px solid #000; padding-top:8px; line-height:1.9; }
  #print_container table.doc-sig-table { margin-top:40px; }
  #print_container table.doc-sig-table td { border-top:2px solid #000; border-left:none; border-right:none; border-bottom:none; background:transparent !important; padding:10px 12px; }
  #print_container .doc-field    { font-weight:600; color:#000; background:none !important; padding:0; }

  @page { margin: 2.5cm 2.2cm; }
}

/* ── External form mobile ────────────────────────────────────── */
@media (max-width:480px) {
  /* Form grid stacks on small phones */
  .ext-card .form-grid { grid-template-columns: 1fr !important; }
  .ext-card .form-group.full { grid-column: 1 !important; }

  /* Bigger inputs for touch */
  .ext-card .form-control {
    font-size: 16px !important;   /* prevents iOS zoom */
    min-height: 44px;
    padding: 10px 12px;
  }
  .ext-card select.form-control { min-height: 44px; }
  .ext-card textarea.form-control { min-height: 80px; }

  /* Submit button full width */
  .ext-card .btn-primary { width: 100%; justify-content: center; min-height: 48px; font-size: .82rem; }

  /* Auth checkbox area */
  #e_auth_box label { font-size: .7rem !important; }
}
