:root{
  --bg:#f4f7fb;
  --panel:#ffffff;
  --ink:#182230;
  --muted:#667085;
  --line:#dfe6f0;
  --soft:#eef4ff;
  --primary:#0b4d78;
  --primary-2:#083957;
  --accent:#0f766e;
  --warning:#b45309;
  --danger:#b42318;
  --success:#087443;
  --shadow:0 18px 50px rgba(16,24,40,.10);
  --radius:18px;
  --radius-sm:12px;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:Inter,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--ink);
  background:linear-gradient(135deg,#edf5ff 0%,#f7f9fc 46%,#eef7f5 100%);
  font-size:14px;
}
button,input,select,textarea{font:inherit}
button{cursor:pointer;border:0}
.hidden{display:none!important}
.login-screen{min-height:100vh;display:grid;place-items:center;padding:28px}
.login-shell{width:min(1120px,100%);display:grid;grid-template-columns:1.2fr .8fr;gap:22px;align-items:stretch}
.brand-panel,.login-card,.card,.table-card,.form-card{background:rgba(255,255,255,.88);backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.72);border-radius:26px;box-shadow:var(--shadow)}
.brand-panel{padding:42px;position:relative;overflow:hidden;min-height:520px;display:flex;flex-direction:column;justify-content:center}
.brand-panel:after{content:"";position:absolute;right:-120px;bottom:-120px;width:360px;height:360px;border-radius:50%;background:rgba(11,77,120,.10)}
.brand-mark{width:70px;height:70px;border-radius:21px;display:grid;place-items:center;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;font-weight:900;letter-spacing:.8px;font-size:23px;box-shadow:0 16px 35px rgba(11,77,120,.24)}
.brand-mark.small{width:42px;height:42px;border-radius:13px;font-size:14px;box-shadow:none}
.eyebrow{text-transform:uppercase;letter-spacing:.12em;font-size:11px;color:var(--primary);font-weight:800;margin:18px 0 8px}
h1,h2,h3,p{margin-top:0}
.brand-panel h1{font-size:44px;line-height:1.05;max-width:620px;margin-bottom:16px;color:#111827}
.lead{font-size:17px;line-height:1.6;color:#475467;max-width:650px}
.mini-flow{display:flex;align-items:center;gap:10px;margin:34px 0 22px;flex-wrap:wrap;position:relative;z-index:1}
.mini-flow span{background:#fff;border:1px solid var(--line);border-radius:999px;padding:9px 13px;font-weight:800;color:#344054;box-shadow:0 8px 20px rgba(16,24,40,.06)}
.mini-flow i{height:2px;background:#9eb3c8;width:26px}
.security-note{max-width:700px;background:#f8fafc;border:1px dashed #b9c8d8;border-radius:14px;padding:14px 16px;color:#475467;position:relative;z-index:1}
.login-card{padding:30px;display:flex;flex-direction:column;justify-content:center}
.card-title-row,.section-head,.row-between{display:flex;align-items:center;justify-content:space-between;gap:12px}
.login-card h2{margin-bottom:4px;font-size:25px}
label{font-size:12px;font-weight:800;color:#344054;margin:12px 0 6px}
input,select,textarea{width:100%;border:1px solid #ccd6e3;background:#fff;color:var(--ink);border-radius:12px;padding:11px 12px;outline:none;transition:.18s border,.18s box-shadow}
textarea{min-height:92px;resize:vertical}
input:focus,select:focus,textarea:focus{border-color:#3982b5;box-shadow:0 0 0 4px rgba(11,77,120,.12)}
.primary,.secondary,.ghost,.danger,.success-btn{border-radius:12px;padding:10px 14px;font-weight:850;transition:.18s transform,.18s box-shadow,.18s background;white-space:nowrap}
.primary{background:var(--primary);color:#fff;box-shadow:0 10px 24px rgba(11,77,120,.20)}
.primary:hover,.secondary:hover,.ghost:hover,.danger:hover,.success-btn:hover{transform:translateY(-1px)}
.secondary{background:#eaf3fb;color:var(--primary);border:1px solid #bed6e9}
.ghost{background:#fff;color:#344054;border:1px solid var(--line)}
.danger{background:#fff1f0;color:var(--danger);border:1px solid #f7c7c1}
.success-btn{background:#eaf8f1;color:var(--success);border:1px solid #b7e1ca}
.full{width:100%;margin-top:16px}
.pill,.status-pill,.role-badge{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:850;border:1px solid var(--line);background:#fff;color:#344054}
.pill{background:#eef4ff;color:#175cd3;border-color:#c7d7fe}
.app-shell{height:100vh;display:grid;grid-template-columns:268px 1fr;overflow:hidden;background:var(--bg)}
.sidebar{background:#092f49;color:#eef6fb;display:flex;flex-direction:column;border-right:1px solid rgba(255,255,255,.12);min-width:0}
.sidebar-head{display:flex;align-items:center;gap:12px;padding:18px;border-bottom:1px solid rgba(255,255,255,.12)}
.sidebar-head strong{display:block;font-size:15px}.sidebar-head span{display:block;color:#b9cfde;font-size:12px;margin-top:3px}
.nav-menu{display:grid;gap:5px;padding:12px;overflow:auto}
.nav-menu button{text-align:left;color:#d9e8f2;background:transparent;border-radius:12px;padding:10px 12px;font-weight:750}
.nav-menu button:hover,.nav-menu button.active{background:rgba(255,255,255,.12);color:#fff}
.sidebar-footer{margin-top:auto;padding:14px;border-top:1px solid rgba(255,255,255,.12)}
.sidebar-footer .ghost{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.16);color:#fff}
.workspace{min-width:0;display:flex;flex-direction:column;height:100vh;overflow:hidden}
.topbar{height:72px;background:rgba(255,255,255,.94);border-bottom:1px solid var(--line);box-shadow:0 2px 18px rgba(16,24,40,.05);display:flex;align-items:center;gap:14px;padding:12px 18px;position:sticky;top:0;z-index:5}
.icon-btn{width:40px;height:40px;border-radius:12px;background:#f3f6fb;border:1px solid var(--line);color:#344054;font-weight:900}
.top-title{min-width:0;flex:1}.top-title h1{font-size:20px;margin-bottom:3px}.top-title p{margin:0;color:var(--muted);font-size:12px;font-weight:650}
.top-actions{display:flex;align-items:center;gap:10px}.top-actions select{min-width:270px}
.alert-bar{padding:10px 18px;background:#fffdf5;color:#854a0e;border-bottom:1px solid #f2dcac;font-size:12px;font-weight:750;display:none}.alert-bar.show{display:block}
.page-content{padding:18px;overflow:auto;min-height:0}
.grid{display:grid;gap:14px}.grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid.cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.card,.table-card,.form-card{border-radius:var(--radius);box-shadow:0 10px 28px rgba(16,24,40,.06);border-color:#edf1f6;background:#fff}
.card{padding:16px}.card h3,.form-card h3,.table-card h3{font-size:15px;margin-bottom:8px}.card p{color:#667085;line-height:1.5;margin-bottom:0}
.kpi{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;min-height:112px}.kpi span{color:#667085;font-weight:750;font-size:12px}.kpi strong{font-size:29px;margin-top:6px;display:block}.kpi i{font-style:normal;width:42px;height:42px;border-radius:14px;background:#f1f6fb;display:grid;place-items:center;font-size:20px}
.progress-wrap{height:10px;background:#e8eef5;border-radius:999px;overflow:hidden}.progress-bar{height:100%;background:linear-gradient(90deg,var(--primary),var(--accent));border-radius:999px;transition:.25s width}.progress-mini{display:flex;align-items:center;gap:10px}.progress-mini .progress-wrap{flex:1;height:8px}.progress-mini span{min-width:42px;text-align:right;font-weight:850;color:#344054;font-size:12px}
.stage-board{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.stage-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:13px;box-shadow:0 8px 20px rgba(16,24,40,.04);position:relative;min-height:168px}.stage-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;border-radius:16px 0 0 16px;background:#98a2b3}.stage-card.completed:before{background:var(--success)}.stage-card.inprogress:before{background:var(--primary)}.stage-card.delayed:before{background:var(--danger)}.stage-card h4{margin:0 0 10px;font-size:14px}.stage-meta{display:grid;gap:5px;color:#667085;font-size:12px;line-height:1.35}.stage-card footer{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-top:12px}
.status-pill.completed{background:#ecfdf3;color:var(--success);border-color:#b7e1ca}.status-pill.inprogress{background:#eef4ff;color:#175cd3;border-color:#c7d7fe}.status-pill.delayed,.status-pill.rejected{background:#fff1f0;color:var(--danger);border-color:#f7c7c1}.status-pill.pending{background:#fff8e8;color:#b45309;border-color:#f2dcac}.status-pill.approved,.status-pill.done,.status-pill.paid{background:#ecfdf3;color:var(--success);border-color:#b7e1ca}.status-pill.review{background:#f4f3ff;color:#5925dc;border-color:#d9d6fe}.status-pill.notstarted{background:#f2f4f7;color:#667085}
.table-card{overflow:hidden}.table-card .section-head{padding:14px 16px;border-bottom:1px solid var(--line)}
table{width:100%;border-collapse:collapse;background:#fff}th,td{padding:11px 12px;border-bottom:1px solid #edf1f6;text-align:left;vertical-align:top}th{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:#667085;background:#f8fafc}td{font-size:13px;color:#344054}.actions{display:flex;gap:7px;flex-wrap:wrap}.actions button{padding:7px 9px;border-radius:9px;font-size:12px}
.form-card{padding:16px}.form-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.form-grid .wide{grid-column:1/-1}.form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:12px}.inline-form{background:#f8fafc;border:1px solid var(--line);border-radius:16px;padding:14px;margin:12px 0}.compact-input{padding:8px 10px;border-radius:10px;font-size:13px}.toolbar{display:flex;justify-content:space-between;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:14px}.toolbar .left,.toolbar .right{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.search-box{max-width:320px}
.timeline{position:relative;display:grid;gap:12px}.timeline-item{display:grid;grid-template-columns:110px 1fr;gap:12px}.timeline-date{font-weight:900;color:var(--primary);font-size:12px;padding-top:12px}.timeline-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:14px;box-shadow:0 8px 20px rgba(16,24,40,.04)}.timeline-card h4{margin:0 0 6px}.timeline-card p{margin:0;color:#475467;line-height:1.5}.timeline-card small{display:block;margin-top:8px;color:#667085;font-weight:700}
.order-card{display:grid;grid-template-columns:1.1fr .9fr 160px;gap:12px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:16px;padding:14px}.order-card h3{margin-bottom:5px}.order-card p{margin:0;color:#667085}.legal-note{border-left:4px solid var(--primary);background:#f5faff;border-radius:14px;padding:12px 14px;color:#344054;line-height:1.55}.split-panel{display:grid;grid-template-columns:.9fr 1.1fr;gap:14px}.report-box{background:#fff;border:1px solid var(--line);border-radius:18px;padding:18px;max-width:980px;margin:auto}.report-header{display:flex;justify-content:space-between;gap:18px;border-bottom:2px solid #e4e7ec;padding-bottom:14px;margin-bottom:14px}.report-header h2{margin-bottom:4px}.report-section{margin:16px 0}.report-section h3{border-bottom:1px solid var(--line);padding-bottom:8px}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:10px}.detail-list{display:grid;grid-template-columns:150px 1fr;gap:8px 12px}.detail-list dt{font-weight:900;color:#667085}.detail-list dd{margin:0;color:#344054}.empty-state{text-align:center;background:#fff;border:1px dashed #cbd5e1;border-radius:20px;padding:40px;color:#667085}.empty-state div{font-size:34px;color:#98a2b3}.toast{position:fixed;right:18px;bottom:18px;background:#111827;color:#fff;border-radius:14px;padding:12px 14px;box-shadow:var(--shadow);opacity:0;transform:translateY(12px);pointer-events:none;transition:.22s;z-index:20;max-width:360px}.toast.show{opacity:1;transform:translateY(0)}
.badge-row{display:flex;gap:8px;flex-wrap:wrap}.muted{color:#667085}.small-text{font-size:12px;color:#667085}.center{text-align:center}.nowrap{white-space:nowrap}.hide-desktop{display:none}

.print-letterhead{display:flex;align-items:center;gap:16px;border-bottom:2px solid #e4e7ec;padding-bottom:14px;margin-bottom:14px}
.print-logo-box{width:96px;min-width:96px;height:74px;border:1px solid var(--line);border-radius:14px;background:#fff;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:8px}
.print-company-logo{display:block;max-width:100%;max-height:100%;object-fit:contain}
.print-company-logo-fallback{width:100%;height:100%;border-radius:10px;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:16px;letter-spacing:.04em}
.print-letterhead-text{min-width:0;flex:1}.print-letterhead-text h1{font-size:22px;margin:0 0 4px;color:#111827}.print-letterhead-text p{margin:0;color:#344054;font-weight:800}.print-letterhead-text span{display:block;margin-top:3px;color:#667085;font-size:12px;font-weight:650}.report-progress strong{font-size:26px;display:block;color:var(--primary)}

@media(max-width:1100px){.grid.cols-4,.stage-board{grid-template-columns:repeat(2,minmax(0,1fr))}.grid.cols-3{grid-template-columns:repeat(2,minmax(0,1fr))}.login-shell{grid-template-columns:1fr}.brand-panel{min-height:auto}.form-grid{grid-template-columns:1fr 1fr}.split-panel{grid-template-columns:1fr}}
@media(max-width:760px){body{font-size:13px}.app-shell{grid-template-columns:1fr}.sidebar{position:fixed;z-index:10;inset:0 auto 0 0;width:286px;transform:translateX(-100%);transition:.2s}.sidebar.open{transform:translateX(0)}.topbar{height:auto;align-items:flex-start;flex-wrap:wrap}.top-actions{width:100%;display:grid;grid-template-columns:1fr auto}.top-actions select{min-width:0}.page-content{padding:12px}.grid.cols-2,.grid.cols-3,.grid.cols-4,.stage-board,.form-grid{grid-template-columns:1fr}.order-card{grid-template-columns:1fr}.timeline-item{grid-template-columns:1fr}.timeline-date{padding-top:0}.login-screen{padding:14px}.brand-panel{padding:24px}.brand-panel h1{font-size:32px}.mini-flow i{display:none}.report-header,.two-col{grid-template-columns:1fr;display:grid}.detail-list{grid-template-columns:1fr}.hide-mobile{display:none}.hide-desktop{display:block}}
@media print{body{background:#fff!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.sidebar,.topbar,.alert-bar,.toolbar,.form-card,.toast,.no-print,.developer-credit{display:none!important}.app-shell,.workspace{display:block;height:auto;overflow:visible}.page-content{overflow:visible;padding:0}.card,.table-card,.report-box{box-shadow:none;border-color:#d0d5dd}.page-content>*:not(.printable){display:none!important}.printable{display:block!important}.report-box{max-width:100%;border:0;padding:0}.print-letterhead{display:flex!important;page-break-after:avoid}.print-logo-box{width:110px;min-width:110px;height:82px;border-color:#d0d5dd}.print-company-logo{max-width:100%;max-height:100%;object-fit:contain}.report-header{page-break-after:avoid}table{font-size:11px}th,td{padding:7px}}

/* Online database connection badges - text only, no dot, no clipping */
.db-status{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:0;
  border-radius:999px;
  padding:7px 14px;
  min-width:78px;
  box-sizing:border-box;
  font-size:12px;
  line-height:1.1;
  font-weight:850;
  border:1px solid var(--line);
  background:#fff;
  color:#344054;
  margin-top:10px;
  white-space:nowrap;
  overflow:visible;
  text-overflow:clip;
  flex:0 0 auto;
}
.db-status:before{content:none!important;display:none!important;width:0!important;height:0!important;margin:0!important}
.db-status.online{background:#ecfdf3;border-color:#abefc6;color:#067647}
.db-status.pending{background:#fffaeb;border-color:#fedf89;color:#93370d}
.db-status.offline{background:#f9fafb;border-color:#d0d5dd;color:#475467}
.db-status.syncpending{background:#fff8e8;border-color:#f2dcac;color:#b45309;min-width:112px}
.db-status.syncing{background:#eef4ff;border-color:#c7d7fe;color:#175cd3;min-width:84px}
.top-actions .db-status{margin-top:0;max-width:none;min-width:78px;white-space:nowrap;overflow:visible;text-overflow:clip;flex-shrink:0}
.topbar,.top-actions{overflow:visible}
@media(max-width:900px){.top-actions .db-status{display:none}}


/* Clean admin control layout */
.brand-mark{overflow:hidden}
.brand-mark img{width:100%;height:100%;object-fit:contain;border-radius:0;background:transparent;padding:0;display:block}
body.has-custom-logo .brand-mark{background:transparent;box-shadow:none;border-radius:0}
body.has-custom-logo .brand-mark:not(.small){width:120px;height:64px;display:flex;align-items:center;justify-content:flex-start}
body.has-custom-logo .brand-mark.small{width:52px;height:34px;display:flex;align-items:center;justify-content:flex-start}
.admin-grid{display:grid;grid-template-columns:1fr;gap:14px}
.mini-form{display:grid;grid-template-columns:1fr 1fr 1fr 180px auto;gap:8px;align-items:end}
.mini-form input,.mini-form select{padding:9px 10px;border-radius:10px;font-size:13px}
.compact-table{overflow:auto;border-radius:14px}
.compact-table input,.compact-table select{padding:8px 9px;border-radius:9px;font-size:12px;min-width:120px}
.compact-table th,.compact-table td{padding:8px}
.upload-label{display:inline-flex;align-items:center;justify-content:center}
button:disabled{opacity:.45;cursor:not-allowed;transform:none!important}
.login-card .small-text{margin:0 0 8px}

@media(max-width:1100px){.mini-form{grid-template-columns:1fr 1fr}.mini-form button{grid-column:1/-1}}
@media(max-width:760px){.mini-form{grid-template-columns:1fr}}

/* Developer credit - URL editable only by protected owner admin in app.js
   v9 layout fix: keeps the credit visible but reserves sidebar space so it does not overlap Logout/login controls. */
.developer-credit{
  position:fixed;
  left:14px;
  bottom:10px;
  z-index:8;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  max-width:230px;
  border:1px solid rgba(208,213,221,.9);
  background:rgba(255,255,255,.94);
  color:#667085;
  border-radius:999px;
  padding:5px 10px;
  font-size:11px;
  line-height:1.15;
  font-weight:750;
  box-shadow:0 8px 24px rgba(16,24,40,.08);
  backdrop-filter:blur(8px);
  white-space:nowrap;
  pointer-events:auto;
}
.developer-credit a{color:#344054;text-decoration:none}
.developer-credit a:hover{text-decoration:underline;color:var(--primary)}
body.app-mode .sidebar-footer{padding-bottom:58px}
body.app-mode .developer-credit{left:18px;bottom:14px}
body.auth-mode .developer-credit{left:18px;bottom:14px}
@media(max-width:760px){.developer-credit{left:10px;bottom:8px;font-size:10px;padding:4px 8px;max-width:210px}body.app-mode .sidebar-footer{padding-bottom:54px}body.auth-mode .login-screen{padding-bottom:58px}}
@media print{.developer-credit{display:none!important}}

/* v8 security hardening helpers */
.danger-text { color: #b42318; font-weight: 700; }
.security-list { margin: 10px 0 0 18px; color: var(--muted); font-size: 13px; line-height: 1.6; }
.login-card input[type="password"] { letter-spacing: 0.02em; }


/* v16 login security upgrade */
.modal-backdrop{
  position:fixed;
  inset:0;
  z-index:1000;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:18px;
  background:rgba(16,24,40,.42);
  backdrop-filter:blur(4px);
}
.modal-backdrop.hidden{display:none!important}
.modal-card{
  width:min(460px,100%);
  border:1px solid var(--line);
  border-radius:18px;
  background:#fff;
  box-shadow:0 24px 70px rgba(16,24,40,.22);
  padding:18px;
}
.modal-card h3{margin:0 0 8px}
.compact-modal input{width:100%;box-sizing:border-box;margin:6px 0 12px}
.security-mode-note{
  display:grid;
  gap:4px;
  border:1px solid var(--line);
  border-radius:14px;
  padding:10px 12px;
  margin:10px 0 12px;
  font-size:13px;
  background:#f9fafb;
  color:#344054;
}
.security-mode-note strong{font-size:13px;color:#101828}
.security-mode-note span{color:var(--muted)}
.security-mode-note.secure{background:#ecfdf3;border-color:#abefc6}
.security-mode-note.standard{background:#fffaeb;border-color:#fedf89}
