@import "https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600&family=DM+Mono:wght@400;500&display=swap";
:root{--navy:#0f1b2d;--navy-mid:#1a2d47;--navy-light:#243d5c;--slate:#4a6380;--mid:#8fa8c0;--pale:#d4e2ef;--off-white:#f0f5fa;--white:#fff;--amber:#e8942a;--amber-light:#fdf3e3;--green:#1a8a5a;--green-light:#e6f6ee;--red:#c0392b;--red-light:#fdecea;--blue:#1a6aaf;--blue-light:#e8f2fb;--purple:#6b3fa0;--purple-light:#f0eaf8;--status-awaiting-bg:#fff8e6;--status-awaiting-col:#960;--status-0-bg:#f5f5f5;--status-0-col:#555;--status-1-bg:#e8f2fb;--status-1-col:#1a5a96;--status-2-bg:#e8f0fb;--status-2-col:#1a3d96;--status-charged-bg:#e6f6ee;--status-charged-col:#1a6a4a;--status-rent-bg:#f0eaf8;--status-rent-col:#5a2a88;--status-upfront-bg:#fff0e6;--status-upfront-col:#8a4000;--sidebar-w:240px;--radius:6px;--shadow:0 2px 8px #0f1b2d1a;--shadow-lg:0 4px 20px #0f1b2d26;--font-body:"DM Sans", sans-serif;--font-mono:"DM Mono", monospace}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-size:15px}body{font-family:var(--font-body);background:var(--off-white);color:var(--navy);min-height:100vh;line-height:1.5}a{color:var(--blue);text-decoration:none}a:hover{text-decoration:underline}.app-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);background:var(--navy);color:var(--pale);z-index:100;flex-direction:column;flex-shrink:0;display:flex;position:fixed;top:0;bottom:0;left:0;overflow-y:auto}.sidebar-brand{border-bottom:1px solid var(--navy-light);padding:1.5rem 1.25rem 1.25rem}.sidebar-brand h1{color:var(--white);letter-spacing:.01em;font-size:1.05rem;font-weight:600}.sidebar-brand p{color:var(--mid);margin-top:.15rem;font-size:.72rem;font-weight:300}.sidebar-region{font-size:.7rem;font-family:var(--font-mono);color:var(--amber);letter-spacing:.05em;background:#e8942a1f;border-radius:3px;margin-top:.4rem;padding:.15rem .5rem;font-weight:500;display:inline-block}.sidebar-nav{flex:1;padding:1rem 0}.sidebar-nav-section{letter-spacing:.1em;color:var(--slate);text-transform:uppercase;padding:.75rem 1.25rem .35rem;font-size:.65rem;font-weight:500}.sidebar-nav a{color:var(--pale);border-left:3px solid #0000;align-items:center;gap:.6rem;padding:.55rem 1.25rem;font-size:.875rem;font-weight:400;text-decoration:none;transition:background .15s,border-color .15s,color .15s;display:flex}.sidebar-nav a:hover{background:var(--navy-light);color:var(--white);text-decoration:none}.sidebar-nav a.active{background:var(--navy-mid);border-left-color:var(--amber);color:var(--white);font-weight:500}.sidebar-nav a .nav-icon{opacity:.7;text-align:center;flex-shrink:0;justify-content:center;align-items:center;width:1.5rem;min-width:1.5rem;font-size:1rem;line-height:1;display:inline-flex}.sidebar-footer{border-top:1px solid var(--navy-light);padding:1rem 1.25rem;font-size:.8rem}.sidebar-footer .user-name{color:var(--white);font-weight:500}.sidebar-footer .user-role{color:var(--mid);text-transform:capitalize;font-size:.72rem}.sidebar-footer a{color:var(--mid);margin-top:.5rem;font-size:.75rem;display:inline-block}.sidebar-footer a:hover{color:var(--pale)}.logout-btn{cursor:pointer;color:var(--mid);background:0 0;border:none;margin-top:.5rem;padding:0;font-family:inherit;font-size:.75rem;display:inline-block}.logout-btn:hover{color:var(--pale)}.main-content{margin-left:var(--sidebar-w);min-width:0;max-width:calc(100vw - var(--sidebar-w));flex-direction:column;flex:1;display:flex}.page-header{background:var(--white);border-bottom:1px solid var(--pale);flex-wrap:nowrap;justify-content:space-between;align-items:center;gap:1rem;padding:1.25rem 2rem;display:flex}.page-header h2{color:var(--navy);text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:1.25rem;font-weight:600;overflow:hidden}.page-header .header-meta{color:var(--slate);margin-top:.1rem;font-size:.8rem}.page-body{box-sizing:border-box;flex:1;width:100%;min-width:0;padding:1.75rem 2rem}.card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.card-header{border-bottom:1px solid var(--pale);justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.25rem;display:flex}.card-header h3{color:var(--navy);font-size:.95rem;font-weight:600}.card-body{padding:1.25rem}.card-footer{background:var(--off-white);border-top:1px solid var(--pale);color:var(--slate);padding:.85rem 1.25rem;font-size:.8rem}.status-badge{white-space:nowrap;letter-spacing:.02em;border-radius:20px;align-items:center;padding:.2rem .6rem;font-size:.75rem;font-weight:600;display:inline-flex}.status-awaiting{background:var(--status-awaiting-bg);color:var(--status-awaiting-col)}.status-0{background:var(--status-0-bg);color:var(--status-0-col)}.status-1{background:var(--status-1-bg);color:var(--status-1-col)}.status-2{background:var(--status-2-bg);color:var(--status-2-col)}.status-charged{background:var(--status-charged-bg);color:var(--status-charged-col)}.status-rent{background:var(--status-rent-bg);color:var(--status-rent-col)}.status-upfront{background:var(--status-upfront-bg);color:var(--status-upfront-col)}.data-table{border-collapse:collapse;width:100%;min-width:0;font-size:.875rem}.table-scroll,.table-wrap{-webkit-overflow-scrolling:touch;width:100%;overflow-x:auto}.data-table th{background:var(--off-white);color:var(--slate);text-transform:uppercase;letter-spacing:.07em;text-align:left;border-bottom:1px solid var(--pale);white-space:nowrap;padding:.6rem 1rem;font-size:.72rem;font-weight:600}.data-table td{border-bottom:1px solid var(--pale);vertical-align:middle;padding:.75rem 1rem}.data-table td.nowrap{white-space:nowrap;max-width:none}.data-table td.status-col{white-space:nowrap;max-width:none;overflow:visible}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:#f7fafd}.data-table .amount{font-family:var(--font-mono);text-align:right;white-space:nowrap;font-size:.875rem}.data-table .totals-row td{background:var(--off-white);border-top:2px solid var(--pale);font-weight:600}.form-group{margin-bottom:1.1rem}.form-label{color:var(--navy);letter-spacing:.01em;margin-bottom:.35rem;font-size:.8rem;font-weight:600;display:block}.form-label .required{color:var(--red);margin-left:.15rem}.form-control{width:100%;font-size:.9rem;font-family:var(--font-body);color:var(--navy);background:var(--white);border:1.5px solid var(--pale);border-radius:var(--radius);outline:none;padding:.55rem .8rem;transition:border-color .15s,box-shadow .15s;display:block}.form-control:focus{border-color:var(--blue);box-shadow:0 0 0 3px #1a6aaf1f}.form-control.is-invalid{border-color:var(--red)}.form-hint{color:var(--slate);margin-top:.3rem;font-size:.75rem}.form-error{color:var(--red);margin-top:.3rem;font-size:.75rem}.form-row{gap:1rem;display:grid}.form-row.cols-2{grid-template-columns:1fr 1fr}.form-row.cols-3{grid-template-columns:1fr 1fr 1fr}.form-row.cols-4{grid-template-columns:1fr 1fr 1fr 1fr}.extras-stack{flex-direction:column;gap:0;display:flex}select.form-control{cursor:pointer}textarea.form-control{resize:vertical;min-height:80px}.form-section{border-top:1px solid var(--pale);margin-top:1.25rem;padding-top:1.25rem}.form-section-title{color:var(--slate);text-transform:uppercase;letter-spacing:.08em;margin-bottom:1rem;font-size:.8rem;font-weight:600}.btn{font-size:.875rem;font-family:var(--font-body);border-radius:var(--radius);cursor:pointer;white-space:nowrap;border:none;align-items:center;gap:.4rem;padding:.5rem 1rem;font-weight:500;text-decoration:none;transition:opacity .15s,box-shadow .15s,transform .1s;display:inline-flex;position:relative}.btn:hover{opacity:.9;text-decoration:none;transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn-primary{background:var(--navy);color:var(--white)}.btn-secondary{background:var(--pale);color:var(--navy)}.btn-success{background:var(--green);color:var(--white)}.btn-danger{background:var(--red);color:var(--white)}.btn-amber{background:var(--amber);color:var(--white)}.btn-sm{padding:.3rem .7rem;font-size:.8rem}.btn-xs{padding:.2rem .5rem;font-size:.72rem}.btn-group{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.alert{border-radius:var(--radius);flex-wrap:wrap;align-items:baseline;gap:.25rem .4rem;margin-bottom:1.25rem;padding:.85rem 1.1rem;font-size:.875rem;line-height:1.6;display:flex}.alert-success{background:var(--green-light);color:#145a3d;border-left:4px solid var(--green)}.alert-error{background:var(--red-light);color:#8b1a12;border-left:4px solid var(--red)}.alert-info{background:var(--blue-light);color:#0f3f6f;border-left:4px solid var(--blue)}.alert-warning{background:var(--amber-light);color:#7a4400;border-left:4px solid var(--amber)}.jobs-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1rem;display:grid}.job-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);border-left:4px solid var(--pale);color:var(--navy);padding:1.1rem 1.25rem;text-decoration:none;transition:box-shadow .15s,transform .15s;display:block}.job-card:hover{box-shadow:var(--shadow-lg);color:var(--navy);text-decoration:none;transform:translateY(-2px)}.job-card.status-awaiting{border-left-color:var(--status-awaiting-col)}.job-card.status-0{border-left-color:var(--mid)}.job-card.status-1{border-left-color:var(--blue)}.job-card.status-2{border-left-color:var(--purple)}.job-card.status-charged{border-left-color:var(--green)}.job-card.status-rent{border-left-color:var(--purple)}.job-card-address{color:var(--navy);margin-bottom:.2rem;font-size:.95rem;font-weight:600}.job-card-meta{color:var(--slate);margin-bottom:.6rem;font-size:.78rem}.job-card-footer{justify-content:space-between;align-items:center;margin-top:.75rem;display:flex}.job-card-value{font-family:var(--font-mono);color:var(--navy);font-size:.95rem;font-weight:500}.finance-summary{background:var(--pale);border-radius:var(--radius);box-shadow:var(--shadow);grid-template-columns:1fr 1fr 1fr;gap:1px;display:grid;overflow:hidden}.finance-panel{background:var(--white);padding:1.25rem}.finance-panel-title{text-transform:uppercase;letter-spacing:.1em;color:var(--slate);margin-bottom:.85rem;font-size:.7rem;font-weight:600}.finance-row{border-bottom:1px solid var(--off-white);justify-content:space-between;align-items:baseline;padding:.3rem 0;font-size:.875rem;display:flex}.finance-row:last-child{border-bottom:none}.finance-row.total{border-top:2px solid var(--pale);margin-top:.3rem;padding-top:.6rem;font-size:.95rem;font-weight:600}.finance-row .label{color:var(--slate)}.finance-row .value{font-family:var(--font-mono)}.profit-figure{font-size:1.5rem;font-weight:600;font-family:var(--font-mono);color:var(--green);margin-top:.25rem}.profit-figure.negative{color:var(--red)}.profit-percent{color:var(--slate);margin-top:.15rem;font-size:.85rem}.quote-item-row{grid-template-columns:1fr auto auto;align-items:center;gap:.6rem;margin-bottom:.5rem;display:grid}.quote-total-bar{border-top:2px solid var(--pale);color:var(--slate);justify-content:flex-end;align-items:baseline;gap:.6rem;margin-top:.5rem;padding:.75rem 0;font-size:.875rem;display:flex}.quote-total-bar .total-value{font-family:var(--font-mono);color:var(--navy);font-size:1.1rem;font-weight:600}.tabs{border-bottom:2px solid var(--pale);scrollbar-width:none;-ms-overflow-style:none;box-sizing:border-box;gap:0;width:100%;margin-bottom:1.5rem;display:flex;overflow:auto hidden}.tabs::-webkit-scrollbar{display:none}.tabs-wrapper{position:relative;overflow:visible}.tabs-wrapper:after{content:"";background:linear-gradient(to right, transparent, var(--white));pointer-events:none;z-index:1;width:48px;position:absolute;top:0;bottom:2px;right:0}.tab{color:var(--slate);cursor:pointer;white-space:nowrap;border-bottom:2px solid #0000;margin-bottom:-2px;padding:.6rem .75rem;font-size:.82rem;font-weight:500;text-decoration:none;transition:color .15s,border-color .15s}.tab:hover{color:var(--navy);text-decoration:none}.tab.active{color:var(--navy);border-bottom-color:var(--amber);font-weight:600}.note-item{background:var(--off-white);border-radius:var(--radius);border-left:3px solid var(--pale);margin-bottom:.6rem;padding:.85rem 1rem;font-size:.875rem}.note-item.type-general{border-left-color:var(--mid)}.note-item.type-payment{border-left-color:var(--amber)}.note-item.type-recommendation{border-left-color:var(--purple)}.note-item.type-contractor_ref{border-left-color:var(--blue)}.note-item.type-extra{border-left-color:var(--green)}.note-item.type-whatsapp_summary{border-left-color:#25d366}.note-item.type-email_summary{border-left-color:var(--amber)}.note-meta{color:var(--slate);margin-bottom:.35rem;font-size:.72rem}.note-content{white-space:pre-wrap;color:var(--navy);font-size:.875rem;line-height:1.4}.note-history{border-top:1px dashed var(--pale);margin-top:.6rem;padding-top:.5rem}.note-history-entry{border-left:2px solid var(--pale);border-radius:0 var(--radius) var(--radius) 0;background:#f7fafd;margin-bottom:.4rem;padding:.5rem .75rem;font-size:.8rem}.note-history-meta{color:var(--slate);margin-bottom:.2rem;font-size:.7rem}.note-history-content{color:var(--navy);white-space:pre-wrap;opacity:.75}.note-history-toggle{margin-top:.4rem}.activity-log{padding:0 .25rem}.activity-entry{border-bottom:1px solid var(--pale);align-items:flex-start;gap:.85rem;padding:.85rem 1.25rem;display:flex}.activity-entry:last-child{border-bottom:none}.activity-icon{text-align:center;flex-shrink:0;width:1.5rem;padding-top:.05rem;font-size:1.1rem}.activity-body{flex:1;min-width:0}.activity-action{color:var(--navy);margin-bottom:.15rem;font-size:.875rem;font-weight:500}.activity-meta{color:var(--slate);font-size:.75rem}.activity-detail{color:var(--slate);margin-top:.2rem;font-size:.75rem;font-style:italic}.activity-value-old{color:var(--navy);opacity:.6}.payment-stages{background:var(--pale);border-radius:var(--radius);grid-template-columns:repeat(3,1fr);gap:1px;display:grid;overflow:hidden}.payment-stage{background:var(--white);text-align:center;padding:1rem}.payment-stage-label{text-transform:uppercase;letter-spacing:.08em;color:var(--slate);margin-bottom:.3rem;font-size:.7rem;font-weight:600}.payment-stage-amount{font-size:1.1rem;font-weight:600;font-family:var(--font-mono);color:var(--navy)}.payment-stage-percent{color:var(--mid);font-size:.75rem}.payment-stage.received{background:var(--green-light)}.payment-stage.received .payment-stage-label{color:var(--green)}.payment-stage.requested{background:var(--amber-light)}.payment-stage.requested .payment-stage-label{color:#7a4400}.stats-row{box-sizing:border-box;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.75rem;width:100%;margin-bottom:1.75rem;display:grid}.stat-box{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.1rem 1.25rem}.stat-box-label{text-transform:uppercase;letter-spacing:.1em;color:var(--slate);margin-bottom:.35rem;font-size:.72rem;font-weight:600}.stat-box-value{color:var(--navy);font-size:1.4rem;font-weight:600;font-family:var(--font-mono);word-break:break-all;overflow-wrap:anywhere;white-space:normal;-webkit-hyphens:none;hyphens:none;line-height:1.2;overflow:visible}.stat-box-sub{color:var(--slate);margin-top:.2rem;font-size:.75rem}.stat-box-link{cursor:pointer;color:inherit;transition:box-shadow .15s,transform .15s}.stat-box-link:hover{box-shadow:var(--shadow-lg);text-decoration:none;transform:translateY(-1px)}.stat-box-alert{border-left:3px solid var(--amber);background:var(--amber-light)}.stat-box-alert .stat-box-value,.stat-box-alert .stat-box-label{color:#7a4400}.filter-bar{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1.25rem;display:flex}.filter-bar input,.filter-bar select{font-family:var(--font-body);border:1.5px solid var(--pale);border-radius:var(--radius);color:var(--navy);background:var(--white);outline:none;padding:.45rem .8rem;font-size:.875rem}.filter-bar input:focus,.filter-bar select:focus{border-color:var(--blue)}.filter-bar input[type=search]{min-width:220px}.login-page{background:var(--navy);justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.login-box{background:var(--white);box-shadow:var(--shadow-lg);border-radius:10px;width:100%;max-width:380px;padding:2.5rem}.login-logo{text-align:center;margin-bottom:2rem}.login-logo h1{color:var(--navy);font-size:1.4rem;font-weight:600}.login-logo p{color:var(--slate);margin-top:.25rem;font-size:.8rem}.archived-badge{text-transform:uppercase;letter-spacing:.05em;color:var(--slate);background:var(--off-white);border:1px solid var(--pale);vertical-align:middle;border-radius:3px;margin-left:.4rem;padding:.1rem .4rem;font-size:.65rem;font-weight:600;display:inline-block}.maint-job-banner{background:var(--navy);color:var(--white);border-radius:var(--radius);margin-bottom:1rem;padding:.9rem 1.1rem}.maint-job-banner-address{margin-bottom:.3rem;font-size:1rem;font-weight:600}.maint-job-banner-meta{color:#ffffffbf;flex-wrap:wrap;align-items:center;gap:.4rem;font-size:.8rem;display:flex}@media (max-width:768px){.btn-xs,.btn-sm{justify-content:center;align-items:center;min-width:40px;min-height:40px;display:inline-flex}.btn-full-mobile{justify-content:center;width:100%;padding:.85rem;font-size:1rem}.maint-note-input{resize:none;min-height:120px;font-size:1rem;overflow:hidden}.notes-mobile-swap{flex-direction:column-reverse;gap:1rem;display:flex!important}.data-table td{text-overflow:ellipsis;white-space:nowrap;max-width:180px;overflow:hidden}.data-table td.status-col{white-space:nowrap;max-width:none;overflow:visible}.data-table td.nowrap{white-space:nowrap;max-width:none}}.mobile-header{background:var(--navy);z-index:200;justify-content:space-between;align-items:center;padding:.85rem 1.25rem;display:none;position:sticky;top:0}.mobile-header-title{color:var(--white);font-size:1rem;font-weight:600}.hamburger{cursor:pointer;background:0 0;border:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;min-width:44px;min-height:44px;padding:.75rem;display:flex}.hamburger span{background:var(--white);border-radius:2px;width:24px;height:2px;transition:all .25s;display:block}.sidebar-overlay{z-index:149;background:#00000080;display:none;position:fixed;inset:0}.sidebar-overlay.active{display:block}.show-mobile,.hide-narrow-show{display:none}.jobs-index-table{table-layout:fixed;width:100%}.jobs-index-table th,.jobs-index-table td{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.jobs-index-table th.col-status,.jobs-index-table td.col-status,.jobs-index-table th.col-plan,.jobs-index-table td.col-plan{overflow:visible}.jobs-index-table th.col-status,.jobs-index-table td.col-status{white-space:nowrap;width:88px}.jobs-index-table th.col-plan,.jobs-index-table td.col-plan{white-space:nowrap;text-align:center;width:72px}.jobs-index-table th.col-quote,.jobs-index-table td.col-quote{white-space:nowrap;text-align:right;width:110px}.jobs-index-table th.col-ref,.jobs-index-table td.col-ref{width:10%}.jobs-index-table th.col-landlord,.jobs-index-table td.col-landlord{width:18%}.jobs-index-table th.col-address,.jobs-index-table td.col-address{white-space:normal;width:30%}.jobs-index-table td.col-address a{white-space:nowrap;text-overflow:ellipsis;display:block;overflow:hidden}.jobs-index-table td.col-address>div{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.jobs-index-table td.col-landlord span{white-space:nowrap;text-overflow:ellipsis;cursor:default;display:block;overflow:hidden}.jobs-index-table td.col-status,.jobs-index-table td.col-plan{overflow:visible}@media (max-width:1300px){.col-ref{display:none!important}.jobs-index-table th.col-landlord,.jobs-index-table td.col-landlord{width:22%}.jobs-index-table th.col-address,.jobs-index-table td.col-address{width:36%}}@media (max-width:1100px){.col-landlord{display:none!important}.hide-narrow-show{display:block!important}.jobs-index-table th.col-address,.jobs-index-table td.col-address{width:55%}}@media (max-width:900px){.col-plan{display:none!important}.jobs-index-table th.col-address,.jobs-index-table td.col-address{width:70%}}@media (max-width:768px){.app-layout{flex-direction:column}.main-content{max-width:100vw;margin-left:0}.mobile-header{display:flex}.sidebar{z-index:150;width:260px;height:100%;transition:left .25s;position:fixed;top:0;left:-280px;overflow-y:auto}.sidebar.open{left:0}.page-body{padding:.85rem}.page-header{flex-direction:column;align-items:flex-start;gap:.6rem;padding:.85rem 1rem}.btn-group{flex-wrap:wrap}.page-header .btn-group{width:100%}.form-row.cols-2,.form-row.cols-3,.form-row.cols-4,.form-row[style*=align-items\:start],.form-row[style*="align-items: start"]{grid-template-columns:1fr}.extras-stack{display:block}.finance-summary{grid-template-columns:1fr}.payment-stages{grid-template-columns:1fr!important}.jobs-grid{grid-template-columns:1fr}.stats-row{grid-template-columns:1fr 1fr}.data-table{font-size:.8rem}.data-table th,.data-table td{padding:.45rem .5rem}.hide-mobile{display:none!important}.show-mobile{display:block!important}.status-badge{padding:.2rem .5rem;font-size:.7rem}.tabs{overflow-x:auto}.tab{white-space:nowrap;align-items:center;min-height:44px;padding:.75rem 1rem;font-size:.82rem;display:inline-flex}.page-header h2{white-space:normal;text-overflow:unset;word-break:break-word;font-size:1rem;overflow:visible}.page-header{align-items:flex-start}.page-header>div:first-child{flex:1;min-width:0}.page-header .btn-group{flex-wrap:wrap;gap:.4rem;width:100%}.page-header .btn-group .btn{flex:auto;min-width:80px;padding:.4rem .6rem;font-size:.78rem}.jobs-table-wrap{overflow-x:hidden}.payment-stages{overflow:visible;grid-template-columns:1fr!important}.payment-card{box-sizing:border-box;width:100%;min-width:0}.filter-bar form{flex-direction:column;align-items:stretch}.filter-bar input[type=search],.filter-bar select{width:100%;min-width:0}.filter-bar .btn{min-height:44px;padding:.65rem 1rem;font-size:.9rem}.card{border-radius:var(--radius)}.quote-item-row{grid-template-columns:1fr auto}.login-box{padding:1.5rem}.modal-box{max-width:calc(100vw - 1rem);margin:.5rem}}.text-right{text-align:right}.text-center{text-align:center}.text-small{font-size:.8rem}.text-mono{font-family:var(--font-mono)}.text-amber{color:var(--amber)}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.d-flex{display:flex}.gap-1{gap:.5rem}.gap-2{gap:1rem}.flex-wrap{flex-wrap:wrap}.align-center{align-items:center}.justify-between{justify-content:space-between}.empty-state{text-align:center;color:var(--slate);padding:2.5rem 1rem}.empty-state .empty-icon{opacity:.4;margin-bottom:.75rem;font-size:2.5rem}.empty-state p{font-size:.9rem}.divider{background:var(--pale);height:1px;margin:1.25rem 0}.badge{background:var(--pale);color:var(--slate);border-radius:20px;align-items:center;padding:.15rem .5rem;font-size:.7rem;font-weight:600;display:inline-flex}.vat-note{background:var(--amber-light);border-radius:var(--radius);color:#6b4400;border:1px solid #e8c070;padding:.6rem .85rem;font-size:.8rem}.route-badge{letter-spacing:.05em;border-radius:3px;align-items:center;padding:.15rem .5rem;font-size:.7rem;font-weight:700;display:inline-flex}.route-1{color:#0a4a8a;background:#e8f4ff}.route-2{color:#7a3a00;background:#fff3e8}.modal-overlay{z-index:1000;background:#0f1b2d8c;justify-content:center;align-items:center;display:none;position:fixed;inset:0}.modal-overlay.active{display:flex}.modal-box{background:var(--white);box-shadow:var(--shadow-lg);border-radius:10px;width:100%;max-width:420px;margin:1rem;overflow:hidden}.modal-header{border-bottom:1px solid var(--pale);justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.modal-header h3{color:var(--navy);font-size:1rem;font-weight:600}.modal-close{cursor:pointer;color:var(--slate);background:0 0;border:none;padding:.25rem;font-size:1.2rem;line-height:1}.modal-close:hover{color:var(--navy)}.modal-body{padding:1.25rem}.modal-footer{border-top:1px solid var(--pale);justify-content:flex-end;gap:.5rem;padding:.85rem 1.25rem;display:flex}.searchable-select{position:relative}.searchable-select .ss-input{width:100%}.ss-dropdown{z-index:200;background:var(--card-bg,#fff);border:1px solid var(--pale);border-radius:0 0 var(--radius) var(--radius);box-shadow:var(--shadow);border-top:none;max-height:220px;display:none;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.searchable-select.ss-open .ss-dropdown{display:block}.ss-option{cursor:pointer;color:var(--body);padding:.5rem .75rem;font-size:.875rem}.ss-option:hover,.ss-option.ss-focused{background:var(--pale)}.ss-option.ss-hidden{display:none}.ss-add-new{color:var(--amber);border-top:1px solid var(--pale);font-weight:600}.ss-add-new:hover{background:color-mix(in srgb, var(--amber) 10%, transparent)}.ss-no-results{color:var(--slate);padding:.5rem .75rem;font-size:.875rem;font-style:italic}.desc-autocomplete{position:relative}.desc-dropdown{z-index:300;background:var(--card-bg,#fff);border:1px solid var(--pale);border-radius:0 0 var(--radius) var(--radius);box-shadow:var(--shadow);border-top:none;max-height:200px;display:none;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.desc-dropdown.open{display:block}.desc-option{cursor:pointer;justify-content:space-between;align-items:center;gap:.5rem;padding:.45rem .75rem;font-size:.875rem;display:flex}.desc-option:hover{background:var(--pale)}.desc-save-row{border-top:1px solid var(--pale);justify-content:space-between;align-items:center;gap:.5rem;padding:.45rem .75rem;font-size:.8rem;display:flex}.desc-save-row span{color:var(--slate);text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.desc-save-btn{border:1px solid var(--amber);color:var(--amber);border-radius:var(--radius);cursor:pointer;white-space:nowrap;background:0 0;flex-shrink:0;padding:.15rem .5rem;font-size:.75rem;font-weight:600}.desc-save-btn:hover{background:var(--amber);color:#fff}.outstanding-summary{flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;display:flex}.summary-stat{border:1px solid var(--pale);border-radius:var(--radius);min-width:140px;box-shadow:var(--shadow);background:#fff;padding:.85rem 1.25rem}.summary-stat.summary-alert{background:#fff5f5;border-color:#f5c6cb}.summary-val{font-size:1.5rem;font-weight:600;font-family:var(--font-mono);color:var(--navy)}.summary-alert .summary-val{color:var(--red)}.summary-lbl{color:var(--slate);margin-top:.1rem;font-size:.72rem}.card-header-alert{background:#fff5f5;border-bottom-color:#f5c6cb}.card-header-alert h3{color:var(--red)}.card-body-note{color:var(--slate);background:var(--off-white);border-bottom:1px solid var(--pale);padding:.6rem 1.25rem;font-size:.8rem}tr.overdue-high td:first-child{border-left:3px solid var(--red)}tr.overdue-mid td:first-child{border-left:3px solid var(--amber)}tr.overdue-low td:first-child{border-left:3px solid var(--green)}.days-badge{font-size:.72rem;font-weight:600;font-family:var(--font-mono);border-radius:3px;padding:.15rem .5rem;display:inline-block}.days-high{color:var(--red);background:#fdecea}.days-mid{background:var(--amber-light);color:#7a4400}.days-low{background:var(--green-light);color:var(--green)}.stage-pill{background:var(--off-white);color:var(--slate);border:1px solid var(--pale);white-space:nowrap;border-radius:20px;padding:.2rem .6rem;font-size:.72rem;font-weight:500;display:inline-block}.stage-pill.stage-1{background:var(--blue-light);color:var(--blue);border-color:var(--blue-light)}.stage-pill.stage-2{background:var(--purple-light);color:var(--purple);border-color:var(--purple-light)}.stage-pill.stage-3{background:var(--green-light);color:var(--green);border-color:var(--green-light)}.job-link{color:var(--navy);font-weight:500}.job-link:hover{color:var(--blue);text-decoration:underline}.row-meta{color:var(--slate);margin-top:.1rem;font-size:.72rem}.text-muted{color:var(--mid)}.actions-cell{white-space:nowrap}.badge-red{color:var(--red);background:#fdecea}.badge-amber{background:var(--amber-light);color:#7a4400}.badge-slate{background:var(--off-white);color:var(--slate)}.btn-invoice{align-items:center;gap:.4rem;display:inline-flex}.reports-layout{grid-template-columns:220px 1fr;align-items:start;gap:1.5rem;min-width:0;display:grid}.reports-main{min-width:0;overflow:hidden}@media (max-width:900px){.reports-layout{grid-template-columns:1fr}}.reports-nav{border:1px solid var(--pale);border-radius:var(--radius);box-shadow:var(--shadow);background:#fff;position:sticky;top:1rem;overflow:hidden}.report-nav-item{color:var(--slate);border-bottom:1px solid var(--pale);align-items:center;gap:.6rem;padding:.7rem 1rem;font-size:.825rem;font-weight:500;text-decoration:none;transition:background .1s;display:flex}.report-nav-item:last-child{border-bottom:none}.report-nav-item:hover{background:var(--off-white);color:var(--navy);text-decoration:none}.report-nav-item.active{background:var(--navy);color:#fff}.report-nav-item.active:hover{background:var(--navy)}.report-nav-icon{width:1.4rem;height:1.4rem;font-size:.75rem;font-weight:700;font-family:var(--font-mono);background:#0000000f;border-radius:3px;flex-shrink:0;justify-content:center;align-items:center;line-height:1;display:inline-flex}.report-nav-item.active .report-nav-icon{background:#ffffff26}.report-nav-label{line-height:1.3}.reports-header{flex-wrap:nowrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem;display:flex}.reports-header-left{flex:1;min-width:0}.reports-header-actions{flex-shrink:0}.reports-title{color:var(--navy);margin-bottom:.2rem;font-size:1.15rem;font-weight:600}.reports-desc{color:var(--slate);font-size:.8rem}.reports-filters{margin-bottom:1.25rem;padding:1rem 1.25rem}.filter-row{flex-wrap:wrap;align-items:flex-end;gap:.75rem;display:flex}.filter-row .form-group{flex:1;min-width:140px;margin:0}.report-summary-bar{flex-wrap:wrap;gap:.75rem;margin-bottom:1rem;display:flex}.rsb-stat{border:1px solid var(--pale);border-radius:var(--radius);min-width:110px;box-shadow:var(--shadow);background:#fff;padding:.7rem 1rem}.rsb-val{font-size:1.2rem;font-weight:600;font-family:var(--font-mono);color:var(--navy)}.rsb-lbl{color:var(--slate);margin-top:.1rem;font-size:.7rem}.rsb-positive{border-color:var(--green-light)}.rsb-positive .rsb-val{color:var(--green)}.rsb-negative{border-color:var(--red-light)}.rsb-negative .rsb-val{color:var(--red)}.rsb-alert{background:#fff5f5;border-color:#f5c6cb}.rsb-alert .rsb-val{color:var(--red)}.rsb-note{background:#fffbf0;border-color:#ffe4a8;flex:1;min-width:200px}.rsb-note .rsb-lbl{color:#7a5a00;font-size:.75rem;line-height:1.4}.report-table th{white-space:nowrap}.text-success{color:var(--green)!important}.text-danger{color:var(--red)!important}.preview-banner{z-index:200;background:var(--amber);color:#1a1000;justify-content:space-between;align-items:center;gap:1rem;padding:.6rem 1.25rem;font-size:.85rem;font-weight:500;display:flex;position:sticky;top:0;box-shadow:0 2px 8px #00000040}.preview-banner-text{align-items:center;gap:.4rem;display:flex}.preview-banner-exit{color:#1a1000;border-radius:var(--radius);cursor:pointer;white-space:nowrap;background:#0000002e;border:1px solid #00000040;padding:.3rem .85rem;font-size:.8rem;font-weight:600;transition:background .15s}.preview-banner-exit:hover{background:#00000047}.btn-preview-toggle{color:#ffffffbf;border-radius:var(--radius);cursor:pointer;text-align:left;background:#ffffff14;border:1px solid #ffffff26;width:100%;margin-bottom:.4rem;padding:.4rem .75rem;font-family:inherit;font-size:.75rem;font-weight:500;transition:background .15s,color .15s;display:block}.btn-preview-toggle:hover{color:#fff;background:#ffffff26}.btn-preview-exit{color:var(--amber);background:#e8942a40;border-color:#e8942a66}.btn-preview-exit:hover{color:#ffd080;background:#e8942a59}.preview-role-badge{background:var(--amber);color:#1a1000;vertical-align:middle;text-transform:uppercase;letter-spacing:.03em;border-radius:3px;margin-left:.4rem;padding:.1rem .4rem;font-size:.65rem;font-weight:700;display:inline-block}.rating-good{color:#4ade80;background:#0d4a1f;border:1px solid #166534}.rating-attention{color:#fbbf24;background:#4a3000;border:1px solid #92400e}.rating-work{color:#f87171;background:#4a0d0d;border:1px solid #991b1b}.rating-na{background:var(--surface);color:var(--slate);border:1px solid var(--border)}.rating-badge{letter-spacing:.02em;white-space:nowrap;border-radius:4px;padding:.2rem .55rem;font-size:.72rem;font-weight:600;display:inline-block}.capture-rating-row{grid-template-columns:1fr 1fr;gap:.5rem;margin-bottom:.5rem;display:grid}.capture-rating-btn{border:2px solid var(--border);cursor:pointer;text-align:center;background:var(--surface);width:100%;color:var(--text);border-radius:6px;padding:.75rem .5rem;font-size:.82rem;font-weight:600;transition:all .15s;display:block}.capture-rating-btn.selected-good{color:#4ade80;background:#0d4a1f;border-color:#166534}.capture-rating-btn.selected-needs_attention{color:#fbbf24;background:#4a3000;border-color:#92400e}.capture-rating-btn.selected-requires_work{color:#f87171;background:#4a0d0d;border-color:#991b1b}.capture-rating-btn.selected-na{color:#9ca3af;background:#3a3f4d;border-color:#4b5563}.insp-pre-works{color:#60a5fa;background:#0f2744;border:1px solid #1e3a5f}.insp-mid-works{color:#86efac;background:#1e3a1e;border:1px solid #166534}.insp-snagging{color:#fbbf24;background:#4a3000;border:1px solid #92400e}.insp-sign-off{color:#4ade80;background:#1a3d1a;border:1px solid #166534}.insp-type-badge{letter-spacing:.02em;border-radius:4px;padding:.2rem .6rem;font-size:.72rem;font-weight:600;display:inline-block}.capture-progress{background:var(--border);border-radius:3px;height:6px;margin-bottom:1rem;overflow:hidden}.capture-progress-fill{background:var(--amber);border-radius:3px;height:100%;transition:width .3s}.area-list-item{border-bottom:1px solid var(--border);cursor:pointer;color:var(--text);align-items:center;gap:.75rem;padding:.9rem 1rem;text-decoration:none;display:flex}.area-list-item.completed{opacity:.65}.area-status-dot{background:var(--border);border-radius:50%;flex-shrink:0;width:10px;height:10px}.area-status-dot.done{background:#4ade80}.area-status-dot.partial{background:#fbbf24}.area-status-dot.pending{background:var(--border)}.photo-grid{grid-template-columns:repeat(3,1fr);gap:.5rem;margin-top:.75rem;display:grid}.photo-grid-item{aspect-ratio:1;background:var(--surface);border:1px solid var(--border);border-radius:6px;position:relative;overflow:hidden}.photo-grid-item img{object-fit:cover;width:100%;height:100%}.photo-delete{color:#fff;cursor:pointer;background:#000000b3;border:none;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:.7rem;display:flex;position:absolute;top:4px;right:4px}.td-tooltip{background:var(--navy);color:#fff;white-space:normal;word-break:break-word;z-index:9000;pointer-events:none;opacity:0;border-radius:6px;max-width:min(340px,90vw);padding:.5rem .85rem;font-size:.82rem;line-height:1.45;transition:opacity .12s;position:fixed;box-shadow:0 4px 16px #00000059}.td-tooltip.visible{opacity:1}.container{max-width:1100px;margin:0 auto}.muted{color:var(--slate);font-size:.85rem}.spacer{flex:1}.badge{background:var(--off-white);color:var(--slate);border:1px solid var(--pale);border-radius:3px;padding:.12rem .5rem;font-size:.72rem;font-weight:600;display:inline-block}.error{background:var(--red-light);color:var(--red);border-left:4px solid var(--red);border-radius:var(--radius);margin-bottom:.75rem;padding:.6rem .8rem;font-size:.85rem}.btn:not([class*=btn-]){background:var(--navy);color:var(--white)}.btn.secondary{background:var(--pale);color:var(--navy)}.card{padding:1.25rem}:is(.card:has(>.card-header),.card:has(>.table-wrap),.card:has(>.jobs-grid),.card:has(>.empty-state)){padding:0}.main-content table:not(.data-table){border-collapse:collapse;width:100%;font-size:.9rem}.main-content table:not(.data-table) th,.main-content table:not(.data-table) td{text-align:left;border-bottom:1px solid var(--pale);padding:.5rem .6rem}.main-content table:not(.data-table) th{color:var(--slate);text-transform:uppercase;letter-spacing:.03em;font-size:.74rem}.main-content label:not(.form-label){color:var(--navy);margin:.7rem 0 .25rem;font-size:.8rem;font-weight:600;display:block}.main-content input:not(.form-control):not([type=checkbox]):not([type=radio]):not([type=file]),.main-content select:not(.form-control),.main-content textarea:not(.form-control){border:1px solid var(--pale);border-radius:var(--radius);width:100%;font-size:.9rem;font-family:var(--font-body);background:var(--white);padding:.55rem .7rem}.main-content textarea:not(.form-control){resize:vertical;min-height:80px}
