*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{
  --green:#CC0000;--green-light:#FDEAEA;--green-mid:#F4AAAA;--green-dark:#8B0000;--green-deep:#6B0000;
  --red:#E24B4A;--red-light:#FCEBEB;--red-dark:#A32D2D;
  --amber-light:#FAEEDA;--amber-dark:#633806;
  --blue-light:#E6F1FB;--blue-dark:#0C447C;
  --gray-50:#F8F8F7;--gray-100:#F1EFE8;--gray-200:#D3D1C7;--gray-400:#888780;--gray-600:#5F5E5A;--gray-800:#444441;--gray-900:#2C2C2A;
  --border:rgba(0,0,0,0.08);--border-mid:rgba(0,0,0,0.14);
  --radius-sm:6px;--radius-md:8px;--radius-lg:12px;
  --sidebar-w:220px;--topbar-h:90px;
  --font:'DM Sans',sans-serif;--mono:'DM Mono',monospace;
}
html,body{height:100%;}
body{font-family:var(--font);font-size:14px;color:var(--gray-900);background:var(--gray-50);-webkit-font-smoothing:antialiased;}
.layout{display:flex;height:100vh;overflow:hidden;}
.sidebar{width:var(--sidebar-w);flex-shrink:0;background:#fff;border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto;}
.sidebar-logo{padding:0;display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--border);font-size:15px;font-weight:600;letter-spacing:-0.3px;flex-shrink:0;}
.sidebar-logo span{color:var(--green);}
.sidebar-logo sub{font-size:9px;font-weight:400;color:var(--gray-400);font-family:var(--mono);margin-left:6px;letter-spacing:0.05em;}
.nav-section{padding:1.25rem 0.75rem 0.5rem;}
.nav-section-label{font-size:10px;font-weight:500;color:var(--gray-400);text-transform:uppercase;letter-spacing:0.08em;padding:0 0.5rem;margin-bottom:4px;}
.nav-item{display:flex;align-items:center;gap:9px;padding:7px 10px;border-radius:var(--radius-md);font-size:13px;color:var(--gray-600);cursor:pointer;transition:all 0.12s;margin-bottom:1px;user-select:none;}
.nav-item:hover{background:var(--gray-100);color:var(--gray-900);}
.nav-item.active{background:var(--green-light);color:var(--green-dark);font-weight:500;}
.nav-item svg{flex-shrink:0;opacity:0.7;}
.nav-item.active svg{opacity:1;}
.nav-badge{margin-left:auto;font-size:10px;font-weight:500;background:var(--green-light);color:var(--green-dark);padding:1px 6px;border-radius:20px;}
.sidebar-footer{margin-top:auto;padding:1rem 0.75rem;border-top:1px solid var(--border);}
.user-chip{display:flex;align-items:center;gap:9px;padding:7px 10px;border-radius:var(--radius-md);cursor:pointer;}
.user-chip:hover{background:var(--gray-100);}
.user-avatar{width:28px;height:28px;border-radius:50%;background:var(--green-light);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:var(--green-dark);flex-shrink:0;}
.user-name{font-size:13px;font-weight:500;}
.user-role{font-size:11px;color:var(--gray-400);}
.prop-del-btn:hover{color:var(--red-dark)!important;background:var(--red-light)!important;}
.main{flex:1;display:flex;flex-direction:column;overflow:hidden;}
.topbar{height:var(--topbar-h);background:#fff;border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 1.5rem;gap:12px;flex-shrink:0;}
.topbar-title{font-size:15px;font-weight:600;letter-spacing:-0.2px;}
.topbar-sub{font-size:12px;color:var(--gray-400);margin-left:2px;}
.topbar-right{margin-left:auto;display:flex;align-items:center;gap:8px;}
.page-body{flex:1;overflow-y:auto;padding:1.5rem;}
.btn{display:inline-flex;align-items:center;gap:6px;height:34px;padding:0 14px;border-radius:var(--radius-md);font-family:var(--font);font-size:13px;font-weight:500;cursor:pointer;border:1px solid transparent;transition:all 0.12s;white-space:nowrap;}
.btn-primary{background:var(--green);color:#fff;border-color:var(--green);}
.btn-primary:hover{background:var(--green-deep);border-color:var(--green-deep);}
.btn-secondary{background:#fff;color:var(--gray-800);border-color:var(--border-mid);}
.btn-secondary:hover{background:var(--gray-100);}
.btn-ghost{background:transparent;color:var(--gray-600);border-color:var(--border-mid);}
.btn-ghost:hover{background:var(--gray-100);}
.btn-sm{height:28px;padding:0 10px;font-size:12px;}
.btn-xs{height:24px;padding:0 8px;font-size:11px;border-radius:var(--radius-sm);}
.badge{display:inline-flex;align-items:center;font-size:11px;font-weight:500;padding:2px 8px;border-radius:20px;white-space:nowrap;}
.badge-green{background:var(--green-light);color:var(--green-dark);}
.badge-blue{background:var(--blue-light);color:var(--blue-dark);}
.badge-amber{background:var(--amber-light);color:var(--amber-dark);}
.badge-red{background:var(--red-light);color:var(--red-dark);}
.badge-gray{background:var(--gray-100);color:var(--gray-600);}
.card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);}
.progress-bar{height:5px;background:var(--gray-100);border-radius:3px;overflow:hidden;}
.progress-fill{height:100%;border-radius:3px;background:var(--green);transition:width 0.4s cubic-bezier(.4,0,.2,1);}
.tenancy-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px;margin-bottom:1.5rem;}
.tenancy-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:1rem 1.1rem;cursor:pointer;transition:all 0.15s;}
.tenancy-card:hover{border-color:var(--green-mid);box-shadow:0 2px 8px rgba(29,158,117,0.08);}
.tenancy-card.selected{border-color:var(--green);box-shadow:0 0 0 2px rgba(29,158,117,0.12);}
.tc-addr{font-size:13px;font-weight:600;margin-bottom:2px;letter-spacing:-0.1px;}
.tc-tenant{font-size:12px;color:var(--gray-400);margin-bottom:10px;}
.tc-progress-label{font-size:11px;color:var(--gray-400);margin-top:5px;display:flex;justify-content:space-between;}
.tc-pct{font-weight:500;color:var(--green-dark);}
.checklist-panel{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;}
.group-header{padding:6px 1.1rem;background:var(--gray-50);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px;}
.group-label{font-size:10px;font-weight:600;color:var(--gray-400);text-transform:uppercase;letter-spacing:0.08em;flex:1;}
.group-count{font-size:10px;color:var(--gray-400);font-family:var(--mono);}
.step-row{border-bottom:1px solid var(--border);}
.step-row:last-child{border-bottom:none;}
.step-header{display:flex;align-items:center;gap:12px;padding:12px 1.1rem;cursor:pointer;transition:background 0.1s;user-select:none;}
.step-header:hover:not(.is-locked){background:var(--gray-50);}
.step-header.is-locked{cursor:not-allowed;}
.step-check{width:20px;height:20px;border-radius:50%;border:1.5px solid var(--gray-200);flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all 0.2s;}
.step-check.done{background:var(--green);border-color:var(--green);}
.step-check.locked{background:var(--gray-100);border-color:var(--gray-200);}
.step-info{flex:1;min-width:0;}
.step-name{font-size:13px;font-weight:500;}
.step-name.locked-text{color:var(--gray-400);}
.step-completed-by{font-size:11px;color:var(--gray-400);margin-top:2px;}
.step-chevron{color:var(--gray-400);font-size:14px;transition:transform 0.2s;flex-shrink:0;line-height:1;}
.step-chevron.open{transform:rotate(90deg);}
.step-detail{padding:1rem 1.1rem 1.1rem 3rem;background:var(--gray-50);border-top:1px solid var(--border);}
.step-detail-label{font-size:11px;font-weight:600;color:var(--gray-400);text-transform:uppercase;letter-spacing:0.06em;margin-bottom:6px;margin-top:12px;}
.step-detail-label:first-child{margin-top:0;}
.step-hint{font-size:12px;color:var(--gray-600);background:#fff;border:1px solid var(--border);border-radius:var(--radius-md);padding:8px 10px;line-height:1.6;margin-bottom:2px;}
.doc-list{background:#fff;border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;}
.doc-item{display:flex;align-items:center;gap:8px;padding:7px 10px;border-bottom:1px solid var(--border);font-size:12px;}
.doc-item:last-child{border-bottom:none;}
.doc-icon{width:18px;height:18px;border-radius:3px;background:var(--blue-light);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.doc-name{flex:1;color:var(--gray-800);}
.doc-name.placeholder{color:var(--gray-400);font-style:italic;}
.step-notes{width:100%;min-height:64px;font-size:13px;padding:8px 10px;border-radius:var(--radius-md);border:1px solid var(--border-mid);font-family:var(--font);color:var(--gray-900);background:#fff;resize:vertical;transition:border-color 0.12s;line-height:1.6;}
.step-notes:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(29,158,117,0.1);}
.step-notes.error{border-color:var(--red);}
.complete-bar{display:flex;align-items:center;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border);}
.completed-stamp{font-size:11px;color:var(--green-dark);background:var(--green-light);padding:3px 9px;border-radius:20px;}
.field-hint{font-size:11px;color:var(--gray-400);}
.field-hint.error{color:var(--red-dark);}
.cert-upload-row{display:flex;align-items:flex-start;gap:10px;padding:9px 10px;border-bottom:1px solid var(--border);}
.cert-upload-row:last-child{border-bottom:none;}
.cert-file-row:last-child{border-bottom:none;}
.cert-info{flex:1;}
.cert-name-text{font-size:13px;font-weight:500;}
.cert-sub{font-size:11px;color:var(--gray-400);margin-top:2px;}
.cert-actions{display:flex;gap:6px;align-items:center;flex-shrink:0;padding-top:2px;}
.pack-item{display:flex;align-items:flex-start;gap:10px;padding:9px 10px;border-bottom:1px solid var(--border);}
.pack-item:last-child{border-bottom:none;}
.pack-info{flex:1;}
.pack-name-text{font-size:13px;font-weight:500;display:flex;align-items:center;gap:6px;flex-wrap:wrap;}
.pack-sub{font-size:11px;color:var(--gray-400);margin-top:2px;}
.pack-actions{display:flex;gap:6px;align-items:center;flex-shrink:0;padding-top:2px;}
.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,0.3);display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem;animation:fadeIn 0.15s ease;}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;animation:slideUp 0.18s ease;}
@keyframes slideUp{from{transform:translateY(12px);opacity:0}to{transform:translateY(0);opacity:1}}
.modal-header{padding:1.1rem 1.25rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
.modal-title{font-size:15px;font-weight:600;letter-spacing:-0.2px;}
.modal-body{padding:1.25rem;display:flex;flex-direction:column;gap:12px;}
.modal-footer{padding:1rem 1.25rem;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px;}
.modal-close{background:none;border:none;cursor:pointer;color:var(--gray-400);padding:4px;border-radius:var(--radius-sm);display:flex;align-items:center;}
.modal-close:hover{background:var(--gray-100);color:var(--gray-800);}
.field{display:flex;flex-direction:column;gap:4px;}
.field label{font-size:12px;font-weight:500;color:var(--gray-600);}
/* Missing required field — applied via flagMissing(ids) helper. Cleared
   automatically as soon as the user starts typing in the field. */
.field.is-missing label{color:var(--red-dark)!important;}
.field.is-missing input,.field.is-missing select,.field.is-missing textarea,
input.is-missing,select.is-missing,textarea.is-missing{
  border-color:var(--red)!important;
  box-shadow:0 0 0 1px var(--red)!important;
}
.field input,.field select,.field textarea{font-family:var(--font);font-size:13px;padding:7px 10px;border-radius:var(--radius-md);border:1px solid var(--border-mid);background:#fff;color:var(--gray-900);transition:border-color 0.12s;width:100%;}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(29,158,117,0.1);}
.form-grid{display:grid;gap:10px;}
.form-grid-2{grid-template-columns:1fr 1fr;}.form-grid-3{grid-template-columns:1fr 1fr 1fr;}
.section-sep{font-size:11px;font-weight:600;color:var(--gray-400);text-transform:uppercase;letter-spacing:0.07em;padding-top:4px;}
.pdf-preview{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;font-size:12px;}
.pdf-header-row{display:flex;justify-content:space-between;align-items:flex-start;border-bottom:1px solid var(--border);padding-bottom:1rem;margin-bottom:1rem;flex-wrap:wrap;gap:8px;}
.pdf-agency{font-size:14px;font-weight:600;color:var(--green-dark);}
.pdf-doc-title{font-size:13px;font-weight:600;margin-top:2px;}
.pdf-generated{font-size:11px;color:var(--gray-400);text-align:right;}
.pdf-section{margin-bottom:1rem;}
.pdf-section-title{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:0.06em;color:var(--gray-400);border-bottom:1px solid var(--border);padding-bottom:3px;margin-bottom:6px;}
.pdf-row{display:flex;gap:8px;padding:2px 0;font-size:12px;}
.pdf-key{color:var(--gray-400);min-width:110px;flex-shrink:0;}
.pdf-val{font-weight:500;}
.pdf-step{border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:6px;overflow:hidden;}
.pdf-step-head{display:flex;align-items:center;justify-content:space-between;padding:7px 10px;background:var(--gray-50);flex-wrap:wrap;gap:6px;}
.pdf-step-name{font-size:12px;font-weight:600;display:flex;align-items:center;gap:6px;}
.pdf-step-stamp{font-size:11px;color:var(--gray-400);}
.pdf-step-body{padding:7px 10px;font-size:12px;color:var(--gray-600);line-height:1.6;}
.pdf-footer-row{display:flex;justify-content:space-between;font-size:10px;color:var(--gray-400);border-top:1px solid var(--border);padding-top:8px;margin-top:1rem;flex-wrap:wrap;gap:4px;}
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--gray-900);color:#fff;font-size:13px;padding:9px 18px;border-radius:20px;z-index:200;animation:toastIn 0.2s ease;white-space:nowrap;pointer-events:none;}
@keyframes toastIn{from{opacity:0;transform:translateX(-50%) translateY(8px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
.toast.success{background:var(--green-dark);}
.toast.error{background:var(--red-dark);}
.tab-btn{padding:8px 16px;font-size:13px;font-weight:500;color:var(--gray-400);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all 0.12s;user-select:none;}
.tab-btn:hover{color:var(--gray-900);}
.tab-btn.tab-active{color:var(--green-dark);border-bottom-color:var(--green);}
::-webkit-scrollbar{width:5px;height:5px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--gray-200);border-radius:10px;}
::-webkit-scrollbar-thumb:hover{background:var(--gray-400);}
