@import "https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&display=swap";
:root{--blue:#003d7c;--blue-mid:#0056b3;--blue-light:#e8f0fb;--blue-pale:#f0f5ff;--teal:#00a693;--teal-light:#e6f6f4;--orange:#e8601a;--orange-lt:#fff3ee;--green:#2da84e;--red:#dc2626;--yellow:#f59e0b;--bg:#f4f7fb;--white:#fff;--border:#dde4ef;--text:#1a2540;--muted:#6b7fa3;--radius:14px;--shadow:0 2px 16px #003d7c14;--shadow-lg:0 8px 40px #003d7c1f}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:Plus Jakarta Sans,sans-serif;font-size:14px;line-height:1.6}.topbar{background:var(--white);border-bottom:1px solid var(--border);z-index:100;position:sticky;top:0;box-shadow:0 2px 12px #003d7c0f}.topbar-inner{justify-content:space-between;align-items:center;gap:12px;max-width:1280px;height:60px;margin:0 auto;padding:0 20px;display:flex}.logo img{height:32px;display:block}.logo-text{color:var(--blue);font-size:17px;font-weight:800}.nav-tabs{background:var(--blue-pale);border-radius:10px;gap:2px;padding:3px;display:flex}.nav-tab{color:var(--muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:7px;padding:6px 14px;font-family:inherit;font-size:12px;font-weight:500;text-decoration:none;transition:all .18s;display:inline-block}.nav-tab.active{background:var(--blue);color:#fff;box-shadow:0 2px 8px #003d7c40}.nav-tab:hover:not(.active){background:var(--blue-light);color:var(--blue)}.topbar-right{flex-shrink:0;align-items:center;gap:8px;display:flex}.user-pill{background:var(--blue-pale);color:var(--blue);border-radius:20px;align-items:center;gap:7px;padding:5px 12px 5px 6px;font-size:12px;font-weight:600;display:flex}.user-avatar{background:var(--blue);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;font-size:11px;font-weight:800;display:flex}.btn-sm{border:1.5px solid var(--border);cursor:pointer;background:var(--white);color:var(--text);border-radius:8px;padding:6px 13px;font-family:inherit;font-size:12px;font-weight:600;transition:all .15s}.btn-sm:hover{border-color:var(--blue);color:var(--blue)}.btn-primary{background:var(--blue);color:#fff;border-color:var(--blue);box-shadow:0 2px 8px #003d7c33}.btn-primary:hover{background:var(--blue-mid);color:#fff;border-color:var(--blue-mid)}.btn-primary:disabled{opacity:.7;pointer-events:none}.spin{animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.page{max-width:1280px;margin:0 auto;padding:28px 20px 60px}.hero-strip{background:linear-gradient(110deg,var(--blue),var(--blue-mid));border-radius:var(--radius);justify-content:space-between;align-items:center;gap:20px;margin-bottom:24px;padding:24px 32px;display:flex;position:relative;overflow:hidden}.hero-strip:after{content:"";background:#ffffff0d;border-radius:50%;width:200px;height:200px;position:absolute;top:-50px;right:-50px}.hero-title{color:#fff;font-size:19px;font-weight:800;line-height:1.2}.hero-sub{color:#fff9;margin-top:3px;font-size:12px}.hero-badge{text-align:center;z-index:1;background:#ffffff1f;border:1px solid #fff3;border-radius:10px;flex-shrink:0;padding:10px 20px}.hb-label{color:#fff9;text-transform:uppercase;letter-spacing:.08em;font-size:9px}.hb-val{color:#fff;font-size:24px;font-weight:800;line-height:1.1}.hb-unit{color:#ffffff80;font-size:10px}.main-grid{grid-template-columns:370px 1fr;align-items:start;gap:20px;display:grid}.right-col{flex-direction:column;gap:18px;display:flex}.card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px}.card-head{letter-spacing:.1em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--border);align-items:center;gap:8px;margin-bottom:18px;padding-bottom:12px;font-size:10px;font-weight:700;display:flex}.chd{background:var(--blue);border-radius:50%;flex-shrink:0;width:7px;height:7px}.field{margin-bottom:16px}.field:last-child{margin-bottom:0}.fl{color:var(--text);justify-content:space-between;align-items:baseline;margin-bottom:6px;font-size:12px;font-weight:600;display:flex}.fh{color:var(--muted);font-size:10px;font-weight:400}.field-row{align-items:center;gap:8px;display:flex}.sdiv{letter-spacing:.08em;text-transform:uppercase;color:var(--muted);border-top:1px solid var(--border);margin:20px 0 14px;padding-top:16px;font-size:10px;font-weight:700}input[type=range]{-webkit-appearance:none;background:linear-gradient(to right, var(--blue) 0%, var(--blue) var(--pct,15%), var(--border) var(--pct,15%));cursor:pointer;border-radius:5px;outline:none;flex:1;height:5px}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;background:var(--white);border:3px solid var(--blue);cursor:pointer;border-radius:50%;width:17px;height:17px;transition:border-color .15s;box-shadow:0 1px 6px #003d7c33}input[type=range]::-webkit-slider-thumb:hover{border-color:var(--teal)}.nw{flex-shrink:0;position:relative}.nw input[type=number]{border:1.5px solid var(--border);width:96px;color:var(--text);background:var(--bg);-moz-appearance:textfield;border-radius:9px;outline:none;padding:7px 32px 7px 10px;font-family:inherit;font-size:12px;font-weight:600;transition:border-color .15s}.nw input::-webkit-outer-spin-button{display:none}.nw input::-webkit-inner-spin-button{display:none}.nw input:focus{border-color:var(--blue);box-shadow:0 0 0 3px #003d7c1a}.nu{color:var(--muted);pointer-events:none;font-size:9px;font-weight:600;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.kpi-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.kpi-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px 18px;transition:transform .15s,box-shadow .15s;position:relative;overflow:hidden}.kpi-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.kpi-acc{height:3px;position:absolute;top:0;left:0;right:0}.kl{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:5px;font-size:10px;font-weight:600}.kv{color:var(--text);font-size:22px;font-weight:800;line-height:1}.ku{color:var(--muted);margin-top:3px;font-size:10px}.be-banner{background:linear-gradient(110deg,var(--teal-light),#e8f8f5);border-radius:var(--radius);border:1.5px solid #00a6934d;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:14px;padding:18px 22px;display:flex}.bel .bell{color:var(--teal);text-transform:uppercase;letter-spacing:.08em;font-size:10px;font-weight:700}.bel .belv{color:var(--teal);font-size:30px;font-weight:800;line-height:1.1}.bel .bels{color:var(--muted);margin-top:2px;font-size:11px}.ber{text-align:right}.ber .bell{color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-size:10px;font-weight:700}.ber .berv{color:var(--text);font-size:19px;font-weight:800}.ber .beru{color:var(--muted);font-size:11px}.chart-wrap{height:280px;margin-top:10px;position:relative}.chart-wrap canvas{background:#fff!important}.bar-compare{flex-direction:column;gap:12px;margin-top:10px;display:flex}.bar-lr{color:var(--muted);justify-content:space-between;margin-bottom:4px;font-size:11px;display:flex}.bar-lr strong{color:var(--text)}.bar-track{background:var(--bg);border-radius:6px;height:26px;overflow:hidden}.bar-fill{color:#fff;white-space:nowrap;border-radius:6px;align-items:center;height:100%;padding-left:10px;font-size:10px;font-weight:700;transition:width .6s cubic-bezier(.4,0,.2,1);display:flex;overflow:hidden}.bb{background:linear-gradient(90deg,var(--blue-mid),var(--blue))}.tb{background:linear-gradient(90deg,#00c9b0,var(--teal))}.dtable{border-collapse:collapse;width:100%}.dtable tr{border-bottom:1px solid var(--border)}.dtable tr:last-child{border-bottom:none}.dtable tr:hover td{background:var(--blue-pale)}.dtable td{color:var(--muted);padding:9px 4px;font-size:12px}.dtable td:last-child{text-align:right;color:var(--text);font-variant-numeric:tabular-nums;font-weight:700}.modal-bg{z-index:500;background:#0006;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:16px;width:100%;max-width:480px;padding:28px;box-shadow:0 24px 80px #0003}.modal-title{color:var(--blue);margin-bottom:20px;font-size:17px;font-weight:800}.mfield{margin-bottom:14px}.mfield label{color:var(--text);margin-bottom:5px;font-size:12px;font-weight:600;display:block}.mfield input,.mfield textarea,.mfield select{border:1.5px solid var(--border);width:100%;color:var(--text);background:var(--bg);border-radius:9px;outline:none;padding:9px 12px;font-family:inherit;font-size:13px;transition:border-color .15s}.mfield input:focus,.mfield textarea:focus,.mfield select:focus{border-color:var(--blue);background:#fff}.mfield textarea{resize:vertical;min-height:70px}.modal-actions{justify-content:flex-end;gap:10px;margin-top:20px;display:flex}.proj-table{border-collapse:collapse;width:100%}.proj-table th{background:var(--blue-pale);text-transform:uppercase;letter-spacing:.06em;color:var(--muted);text-align:left;border-bottom:2px solid var(--border);padding:10px 12px;font-size:11px;font-weight:700}.proj-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:12px;font-size:12px}.proj-table tr:last-child td{border-bottom:none}.proj-table tr:hover td{background:var(--blue-pale)}.proj-table .proj-name{color:var(--text);font-weight:700}.proj-table .proj-addr{color:var(--muted);font-size:11px}.status-badge{white-space:nowrap;border-radius:20px;align-items:center;gap:5px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-flex}.s-open{color:#92400e;background:#fef3c7}.s-no{color:#991b1b;background:#fee2e2}.s-yes,.s-approved{color:#065f46;background:#d1fae5}.s-paid{color:#1e40af;background:#dbeafe}.btn-proj-open{background:var(--blue-pale);color:var(--blue);cursor:pointer;border:none;border-radius:6px;padding:5px 10px;font-size:11px;font-weight:600}.btn-proj-open:hover{background:var(--blue-light)}.admin-grid{grid-template-columns:1fr 1fr;gap:20px;display:grid}.user-table{border-collapse:collapse;width:100%}.user-table th{background:var(--blue-pale);text-transform:uppercase;letter-spacing:.06em;color:var(--muted);text-align:left;border-bottom:2px solid var(--border);padding:9px 12px;font-size:11px;font-weight:700}.user-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:10px 12px;font-size:12px}.user-table tr:last-child td{border-bottom:none}select.status-sel{border:1.5px solid var(--border);color:var(--text);background:var(--white);cursor:pointer;border-radius:7px;outline:none;padding:4px 8px;font-family:inherit;font-size:11px;font-weight:600}select.status-sel:focus{border-color:var(--blue)}.tag-admin{background:var(--blue);color:#fff;border-radius:4px;padding:1px 7px;font-size:10px;font-weight:700}.tag-active{background:var(--green);color:#fff;border-radius:4px;padding:1px 7px;font-size:10px;font-weight:700}.btn-danger{color:var(--red);cursor:pointer;background:#fee2e2;border:1.5px solid #fecaca;border-radius:7px;padding:4px 10px;font-family:inherit;font-size:11px;font-weight:600}.btn-danger:hover{background:#fecaca}.btn-warn{color:#92400e;cursor:pointer;background:#fef3c7;border:1.5px solid #fde68a;border-radius:7px;padding:4px 10px;font-family:inherit;font-size:11px;font-weight:600}.btn-warn:hover{background:#fde68a}.chat-msg{flex-direction:column;max-width:80%;display:flex}.chat-msg.mine{align-self:flex-end;align-items:flex-end}.chat-msg.theirs{align-self:flex-start;align-items:flex-start}.chat-bubble{white-space:pre-wrap;word-break:break-word;border-radius:14px;padding:10px 14px;font-size:13px;line-height:1.5}.chat-msg.mine .chat-bubble{background:var(--blue);color:#fff;border-bottom-right-radius:4px}.chat-msg.theirs .chat-bubble{background:var(--white);border:1px solid var(--border);color:var(--text);border-bottom-left-radius:4px}.chat-meta{color:var(--muted);margin-top:3px;padding:0 4px;font-size:10px}.admin-sub-tab{color:#fff;cursor:pointer;white-space:nowrap;background:#ffffff1f;border:1.5px solid #ffffff4d;border-radius:8px;padding:7px 14px;font-family:inherit;font-size:12px;font-weight:600;transition:all .15s}.admin-sub-tab.active{color:var(--blue);background:#fff}.admin-sub-tab:hover:not(.active){background:#ffffff40}.vdetails{border:1.5px solid var(--border);border-radius:10px;margin-bottom:12px;overflow:hidden}.vdetails summary{color:var(--text);cursor:pointer;background:var(--bg);-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:13px 16px;font-size:13px;font-weight:700;list-style:none;display:flex}.vdetails summary::-webkit-details-marker{display:none}.vdetails summary:after{content:"▸";color:var(--muted);font-size:12px;transition:transform .2s}.vdetails[open] summary:after{transform:rotate(90deg)}.vdetails[open] summary{background:var(--blue-pale);color:var(--blue);border-bottom:1px solid var(--border)}.vdetails .vbody{color:var(--text);padding:16px;font-size:12px;line-height:1.7}.vbody h3{color:var(--blue);margin:12px 0 4px;font-size:12px;font-weight:700}.vbody ul{margin:4px 0 8px 16px;padding:0}.vbody li{margin-bottom:3px}.vbody .vfirma{color:var(--muted);border-top:1px solid var(--border);margin-top:12px;padding-top:10px;font-size:11px}.vacc-row{background:var(--blue-pale);border-top:1px solid var(--border);align-items:center;gap:10px;padding:10px 16px;display:flex}.vacc-row input{flex-shrink:0;width:18px;height:18px}.vacc-row label{color:var(--blue);cursor:pointer;font-size:12px;font-weight:600}.login-box{background:#fff;border-radius:20px;width:100%;max-width:520px;max-height:92vh;padding:32px 28px;overflow-y:auto;box-shadow:0 24px 80px #00000040}.login-logo{text-align:center;margin-bottom:28px}.login-logo img{height:36px}.login-title{color:var(--blue);text-align:center;margin-bottom:4px;font-size:20px;font-weight:800}.login-sub{color:var(--muted);text-align:center;margin-bottom:28px;font-size:13px}.lfield{margin-bottom:16px}.lfield label{color:var(--text);margin-bottom:6px;font-size:12px;font-weight:600;display:block}.lfield input{border:1.5px solid var(--border);width:100%;color:var(--text);background:var(--bg);border-radius:10px;outline:none;padding:11px 14px;font-family:inherit;font-size:14px;transition:border-color .15s,box-shadow .15s}.lfield input:focus{border-color:var(--blue);background:#fff;box-shadow:0 0 0 3px #003d7c1a}.btn-login{background:var(--blue);color:#fff;cursor:pointer;border:none;border-radius:10px;width:100%;margin-top:4px;padding:13px;font-family:inherit;font-size:15px;font-weight:700;transition:background .15s}.btn-login:hover{background:var(--blue-mid)}.btn-login:disabled{opacity:.7;cursor:not-allowed}.login-err{color:var(--red);text-align:center;min-height:18px;margin-top:10px;font-size:12px}.footer{background:var(--white);border-top:1px solid var(--border);text-align:center;color:var(--muted);margin-top:48px;padding:20px;font-size:11px}@keyframes fadeUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.card,.kpi-card,.be-banner{animation:.35s both fadeUp}.kpi-card:nth-child(2){animation-delay:50ms}.kpi-card:nth-child(3){animation-delay:.1s}.kpi-card:nth-child(4){animation-delay:.15s}@media (max-width:600px){.topbar-inner{flex-wrap:wrap;gap:8px;height:auto;padding:10px 12px}.nav-tabs{order:3;width:100%}.nav-tab{text-align:center;flex:1;padding:6px 4px;font-size:11px}.topbar-right{order:2}.page{padding:14px 12px 48px}.hero-strip{flex-direction:column;align-items:flex-start;gap:12px;margin-bottom:16px;padding:16px 14px}.main-grid{grid-template-columns:1fr;gap:14px}.card{padding:14px}.kpi-card{padding:12px 14px}.kv{font-size:19px}.chart-wrap{height:200px}.be-banner{flex-direction:column;align-items:stretch;gap:10px;padding:14px}.admin-grid{grid-template-columns:1fr}}@media (min-width:601px) and (max-width:960px){.topbar-inner{flex-wrap:wrap;gap:8px;height:auto;padding:8px 16px}.nav-tabs{order:3;width:100%}.nav-tab{flex:1;font-size:11px}.main-grid{grid-template-columns:1fr}.chart-wrap{height:240px}}
