:root{
  --navy:#0A1E3D;--dark:#1C3559;--lime:#9ADC02;--light:#C9D6E8;--white:#fff;
  --ink:#132033;--muted:#64748b;--line:#dbe5f2;--soft:#f4f8fc;--panel:#fff;--danger:#b42318;--warn:#b7791f;--ok:#147a44;--radius:8px;--shadow:0 18px 42px rgba(10,30,61,.14)
}
*{box-sizing:border-box}body{margin:0;min-height:100vh;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;color:var(--ink);background:var(--soft);letter-spacing:0}button,input,select,textarea{font:inherit}button{border:0;cursor:pointer}textarea{resize:vertical;min-height:84px}.sidebar{position:fixed;left:0;top:0;bottom:0;width:260px;background:linear-gradient(180deg,var(--navy),var(--dark));color:var(--white);padding:20px 14px;display:flex;flex-direction:column;gap:18px}.brand{display:grid;grid-template-columns:66px 1fr;gap:12px;align-items:center;padding-bottom:16px;border-bottom:1px solid rgba(255,255,255,.14)}.brand img{width:66px;height:66px;object-fit:contain;border-radius:8px;background:#061a35}.brand strong{display:block;font-size:18px;line-height:1.05;text-transform:uppercase}.brand span{display:block;color:var(--light);font-size:12px;margin-top:4px}.side-nav{display:grid;gap:6px}.side-nav button{height:42px;border-radius:var(--radius);padding:0 12px;text-align:left;background:transparent;color:#dbeafe}.side-nav button:hover,.side-nav button.active{background:rgba(154,220,2,.16);color:var(--white);box-shadow:inset 3px 0 0 var(--lime)}.operator-card{margin-top:auto;border:1px solid rgba(255,255,255,.15);border-radius:var(--radius);padding:12px;background:rgba(255,255,255,.08)}.operator-card span{font-size:12px;color:var(--light)}.operator-card strong{display:block;margin-top:4px}.main-shell{margin-left:260px;padding:22px 22px 96px}.topbar{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:16px;align-items:center;margin-bottom:18px}h1{margin:0;font-size:28px;line-height:1.1}h2,h3{margin:0}.quick-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.btn{min-height:40px;border-radius:var(--radius);padding:0 13px;border:1px solid var(--line);background:var(--white);color:var(--ink);display:inline-flex;align-items:center;justify-content:center;gap:7px}.btn:hover{border-color:var(--dark)}.btn.primary{background:var(--lime);border-color:var(--lime);color:var(--navy);font-weight:800}.btn.danger{background:#fff5f5;border-color:#f4b5b5;color:var(--danger)}.btn.small{min-height:32px;padding:0 10px;font-size:13px}.view{display:none}.view.active{display:block}.grid{display:grid;gap:14px}.grid.two{grid-template-columns:minmax(0,1.15fr) minmax(320px,.85fr)}.lower{margin-top:14px}.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:0 1px 2px rgba(10,30,61,.04);min-width:0}.panel-head{min-height:56px;padding:14px 16px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:10px}.panel-head h2{font-size:16px}.panel-body{padding:14px 16px}.metrics{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px;margin-bottom:14px}.metric{background:var(--white);border:1px solid var(--line);border-left:4px solid var(--lime);border-radius:var(--radius);padding:14px;min-height:104px}.metric span{display:block;color:var(--muted);font-size:12px}.metric strong{display:block;font-size:24px;margin:8px 0 2px}.metric small{color:var(--muted);font-size:12px}.filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:12px}input,select,textarea{width:100%;border:1px solid var(--line);border-radius:var(--radius);min-height:40px;padding:9px 10px;background:#fff;color:var(--ink);outline:none}input:focus,select:focus,textarea:focus{border-color:var(--dark);box-shadow:0 0 0 3px rgba(28,53,89,.12)}.cards-list,.list{display:grid;gap:10px}.record-card{border:1px solid var(--line);border-radius:var(--radius);background:#fff;padding:12px;display:grid;gap:10px}.record-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.record-title strong{display:block;font-size:15px}.record-title span{display:block;color:var(--muted);font-size:12px;margin-top:3px}.meta-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.meta{background:#f8fbfe;border:1px solid #e8eef7;border-radius:var(--radius);padding:8px;font-size:12px}.meta b{display:block;color:var(--dark);font-size:11px;text-transform:uppercase;margin-bottom:2px}.pill{display:inline-flex;align-items:center;min-height:24px;border-radius:999px;padding:0 8px;border:1px solid transparent;font-size:12px;white-space:nowrap}.pill.lead,.pill.estimate-sent{background:#eef6ff;color:#175985;border-color:#bfdbfe}.pill.approved,.pill.scheduled,.pill.in-progress{background:#f2ffe1;color:#426600;border-color:#d8f5a2}.pill.completed,.pill.paid{background:#ecfdf3;color:#087443;border-color:#b7e4c7}.pill.overdue,.pill.lost{background:#fff1f0;color:#b42318;border-color:#ffd1cc}.pill.unpaid,.pill.partial{background:#fff8e6;color:#96630b;border-color:#f9d48b}.actions{display:flex;gap:7px;flex-wrap:wrap;justify-content:flex-end}.calendar{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:6px}.day{min-height:112px;border:1px solid var(--line);border-radius:var(--radius);padding:8px;background:#fff;display:grid;align-content:start;gap:6px}.day b{font-size:12px;color:var(--muted)}.day span{font-size:12px;background:#edf7ff;border-left:3px solid var(--lime);border-radius:6px;padding:5px;overflow-wrap:anywhere}.photo-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.photo-card{border:1px solid var(--line);border-radius:var(--radius);background:#fff;padding:10px}.photo-card img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:var(--radius);background:#e9f0f8}.photo-card h3{font-size:14px;margin:8px 0 2px}.photo-card p{margin:0;color:var(--muted);font-size:12px}.pipeline,.breakdowns{display:grid;gap:10px}.bar-row{display:grid;grid-template-columns:120px 1fr 70px;align-items:center;gap:8px;font-size:13px}.bar-track{height:10px;background:#edf2f7;border-radius:99px;overflow:hidden}.bar-fill{height:100%;background:var(--lime)}.drawer-backdrop{position:fixed;inset:0;background:rgba(10,30,61,.42);opacity:0;pointer-events:none;transition:.18s ease;z-index:50}.drawer-backdrop.open{opacity:1;pointer-events:auto}.drawer{position:fixed;top:0;right:0;bottom:0;width:min(720px,100vw);background:#fff;box-shadow:var(--shadow);transform:translateX(102%);transition:.2s ease;z-index:51;display:grid;grid-template-rows:auto 1fr auto}.drawer.open{transform:translateX(0)}.drawer header,.drawer footer{padding:16px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:10px}.drawer footer{border-top:1px solid var(--line);border-bottom:0;justify-content:flex-end}.drawer-body{padding:16px;overflow:auto}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.field.full{grid-column:1/-1}.field label{display:block;font-size:12px;color:var(--muted);margin-bottom:5px}.line-items{display:grid;gap:8px}.line-row{display:grid;grid-template-columns:minmax(0,1fr) 80px 100px 100px 40px;gap:8px;align-items:center}.check-list{display:grid;gap:8px}.check-item{display:flex;gap:8px;align-items:center}.check-item input{width:auto;min-height:auto}.toast{position:fixed;left:50%;bottom:22px;transform:translateX(-50%) translateY(20px);opacity:0;background:var(--navy);color:#fff;border-radius:var(--radius);padding:11px 14px;box-shadow:var(--shadow);z-index:70;transition:.18s ease;pointer-events:none}.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}.bottom-nav{display:none}.empty{border:1px dashed var(--line);border-radius:var(--radius);padding:20px;text-align:center;color:var(--muted);background:#fbfdff}.invoice-preview{border:1px solid var(--line);border-radius:var(--radius);padding:14px;background:#fff}.invoice-preview h3{margin-bottom:8px}.invoice-preview table{width:100%;border-collapse:collapse}.invoice-preview td,.invoice-preview th{border-bottom:1px solid var(--line);padding:8px;text-align:left}.alert-box{position:fixed;right:18px;bottom:18px;width:min(390px,calc(100vw - 28px));background:#fff;border:1px solid var(--line);border-left:5px solid var(--lime);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px;z-index:60}.alert-box p{color:var(--muted);font-size:13px;margin:6px 0 0}
@media(max-width:1200px){.metrics{grid-template-columns:repeat(3,minmax(0,1fr))}.grid.two{grid-template-columns:1fr}.photo-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:760px){body{background:#fff}.sidebar{display:none}.main-shell{margin:0;padding:14px 12px 86px}.topbar{grid-template-columns:1fr;gap:10px}.quick-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));justify-content:stretch}.btn{min-height:44px}.metrics{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.metric{padding:12px;min-height:92px}.metric strong{font-size:20px}.panel{border-left:0;border-right:0;border-radius:0}.panel-head,.panel-body{padding-left:12px;padding-right:12px}.meta-grid{grid-template-columns:1fr}.record-top{display:grid}.actions{justify-content:flex-start}.calendar{grid-template-columns:repeat(2,minmax(0,1fr))}.photo-grid{grid-template-columns:1fr}.form-grid{grid-template-columns:1fr}.line-row{grid-template-columns:1fr 70px 82px 82px 40px}.bottom-nav{position:fixed;display:flex;overflow-x:auto;-webkit-overflow-scrolling:touch;left:0;right:0;bottom:0;background:#fff;border-top:1px solid var(--line);z-index:40}.bottom-nav button{flex:0 0 auto;min-width:74px;height:64px;background:#fff;color:var(--dark);font-size:12px;padding:0 10px}.bottom-nav button.active{color:var(--navy);box-shadow:inset 0 3px 0 var(--lime);font-weight:800}.drawer{width:100vw}.drawer footer{position:sticky;bottom:0;background:#fff}.bar-row{grid-template-columns:90px 1fr 54px}}
@media print{.sidebar,.topbar,.bottom-nav,.actions,.drawer-backdrop,.drawer,.toast{display:none!important}.main-shell{margin:0;padding:0}.view{display:block}.panel{box-shadow:none;border:0}.record-card{break-inside:avoid}}

/* V2 additions */
.global-search{position:relative;min-width:min(420px,42vw)}
.global-search input{height:42px;border:1px solid var(--line);border-radius:var(--radius);padding:0 12px;background:#fff;color:var(--ink)}
.global-results{display:none;position:absolute;right:0;top:calc(100% + 6px);width:min(560px,92vw);max-height:360px;overflow:auto;background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);z-index:80;padding:8px}.global-results.open{display:grid;gap:6px}.global-results button{display:grid;gap:2px;text-align:left;background:#f8fbfe;border:1px solid #e8eef7;border-radius:8px;padding:9px;color:var(--ink)}.global-results span{font-size:12px;color:var(--muted)}
.dropzone{border:2px dashed var(--light);border-radius:var(--radius);padding:18px;text-align:center;background:#f8fbfe;color:var(--dark);font-weight:800;margin-bottom:12px}.dropzone:hover{border-color:var(--lime);background:#fbfff3}
.line-row{grid-template-columns:minmax(150px,1fr) 72px 90px 80px 90px 40px;align-items:start}.line-row textarea{grid-column:1/-1;min-height:54px}
.compare-card{--split:50%}.compare-frame{position:relative;aspect-ratio:4/3;overflow:hidden;border-radius:var(--radius);background:#e9f0f8}.compare-frame img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}.compare-frame .after{clip-path:inset(0 0 0 var(--split))}.compare-frame:after{content:"";position:absolute;top:0;bottom:0;left:var(--split);width:2px;background:#fff;box-shadow:0 0 0 1px rgba(10,30,61,.25)}.compare-range{accent-color:var(--lime);margin-top:8px}
a{color:var(--dark);font-weight:800}.alert-box{position:fixed;right:18px;bottom:18px;width:min(420px,calc(100vw - 28px));background:#fff;border:1px solid var(--line);border-left:5px solid var(--lime);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px;z-index:75}.alert-box p{margin:6px 0 0;color:var(--muted);font-size:13px}.record-card p{margin:0;color:var(--muted);font-size:13px;line-height:1.45}.invoice-preview table{margin:10px 0}
.calc-panel{border:1px solid var(--line);border-radius:var(--radius);padding:12px;background:#f8fbfe;display:grid;gap:10px}
.calc-rows{display:grid;gap:8px}
.calc-row{display:grid;grid-template-columns:minmax(0,1fr) 110px 110px;gap:8px;align-items:center}
.calc-row label{font-size:13px;color:var(--ink)}
.calc-row label small{display:block;color:var(--muted);font-weight:400;font-size:11px}
.calc-override{opacity:.85}
.calc-discount{display:grid;grid-template-columns:120px 1fr;gap:8px}
.calc-totals{font-size:13px;color:var(--dark);display:grid;gap:4px;padding-top:4px;border-top:1px dashed var(--line)}
.calc-totals b{font-size:15px}
@media(max-width:760px){.calc-row{grid-template-columns:1fr 90px 90px}}
.login-screen{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,var(--navy),var(--dark));padding:20px}
.login-card{background:#fff;border-radius:var(--radius);padding:32px 28px;width:min(360px,100%);text-align:center;box-shadow:var(--shadow)}
.login-card img{width:64px;height:64px;object-fit:contain;border-radius:8px;background:#061a35;margin-bottom:12px}
.login-card h1{font-size:20px;margin-bottom:6px}
.login-card p{color:var(--muted);font-size:13px;margin-bottom:16px}
.login-card input{margin-bottom:12px;text-align:center}
.login-card .btn{width:100%}
.login-error{color:var(--danger);font-size:13px;min-height:18px;margin-top:10px}
@media(max-width:760px){.global-search{min-width:0;width:100%}.topbar{position:sticky;top:0;background:#fff;z-index:35;padding-bottom:10px}.quick-actions{grid-template-columns:repeat(2,minmax(0,1fr))}.quick-actions .btn,.bottom-nav button{touch-action:manipulation}.line-row{grid-template-columns:1fr 64px 78px;gap:7px}.line-row input[name=lineTax],.line-row input[name=lineDiscount]{grid-column:auto}.line-row .remove-line{grid-column:3}.line-row textarea{grid-column:1/-1}.metrics{grid-template-columns:1fr 1fr}.record-card{padding:14px}.photo-card img,.compare-frame{aspect-ratio:1/1}.alert-box{left:12px;right:12px;bottom:78px;width:auto}.bottom-nav button{font-size:11px;min-width:66px}}
