/* BUILDOPS Enterprise — Complete Stylesheet */
:root{
  --st:#1C2B3A;--st2:#243447;--am:#E8A020;--am2:#F5B93E;
  --co:#F0EDE8;--du:#D6CFC4;--wh:#FFFFFF;
  --ok:#27AE60;--er:#C0392B;--wa:#E67E22;--bl:#2980B9;--pu:#8E44AD;
  --mu:#7A8A99;--tx:#1C2B3A;
  --sbw:230px;--sbcw:60px;--tbh:52px;
  --r:10px;--rs:6px;--rl:14px;
  --sh:0 2px 12px rgba(0,0,0,.08);--shl:0 8px 32px rgba(0,0,0,.16);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Inter','Segoe UI',system-ui,sans-serif;font-size:14px;color:var(--tx);background:var(--co);min-height:100vh}
a{text-decoration:none;color:inherit;cursor:pointer}
button,input,select,textarea{font-family:inherit;font-size:inherit}
table{border-collapse:collapse;width:100%}

/* Config */
#config-screen,#login-screen{display:flex;min-height:100vh}
.config-wrap{margin:auto;width:480px;background:var(--wh);border-radius:var(--rl);padding:48px 40px;box-shadow:var(--shl)}
.config-wrap h2{font-size:20px;font-weight:800;color:var(--st);margin-bottom:6px}
.hint{font-size:11px;color:var(--mu);text-align:center}.hint a{color:var(--am);font-weight:600}

/* Brand */
.brand-logo{display:flex;align-items:center;gap:10px;font-size:18px;font-weight:800;letter-spacing:.5px;color:var(--wh)}
.b-icon{width:36px;height:36px;border-radius:9px;background:var(--am);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:900;color:var(--st);flex-shrink:0}
.b-icon.lg{width:48px;height:48px;font-size:24px;border-radius:12px}
.b-icon.sm{width:28px;height:28px;font-size:14px;border-radius:7px}

/* Login */
.login-left{flex:1;background:var(--st);display:flex;flex-direction:column;justify-content:center;padding:60px;color:var(--wh)}
.login-tagline{font-size:clamp(26px,3.5vw,42px);font-weight:800;line-height:1.15;margin-bottom:14px;letter-spacing:-1px}
.amber{color:var(--am)}
.login-left .sub{color:var(--mu);line-height:1.7;font-size:14px;margin-bottom:28px}
.login-features{display:flex;flex-direction:column;gap:12px}
.lf{display:flex;align-items:center;gap:12px;font-size:13px;color:rgba(255,255,255,.8)}
.lf span{width:32px;height:32px;border-radius:8px;background:rgba(232,160,32,.15);border:1px solid rgba(232,160,32,.25);display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0}
.login-box{width:clamp(300px,38%,420px);background:var(--co);display:flex;flex-direction:column;justify-content:center;padding:52px 40px;box-shadow:-8px 0 40px rgba(0,0,0,.25)}
.login-box h2{font-size:22px;font-weight:800;color:var(--st);margin-bottom:4px}
.login-box .sub{font-size:12px;color:var(--mu);margin-bottom:28px}
.pw-wrap{position:relative}.pw-wrap input{width:100%;padding-right:44px}
.pw-wrap button{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:14px;color:var(--mu)}
.divider-text{text-align:center;color:var(--mu);font-size:12px;margin:12px 0;position:relative}
.divider-text::before,.divider-text::after{content:'';position:absolute;top:50%;width:42%;height:1px;background:var(--du)}
.divider-text::before{left:0}.divider-text::after{right:0}
@media(max-width:700px){.login-left{display:none}.login-box{width:100%;box-shadow:none;padding:36px 24px}}

/* App shell */
#app{display:flex;min-height:100vh}
#sidebar{width:var(--sbw);min-height:100vh;background:var(--st);display:flex;flex-direction:column;transition:width .25s;flex-shrink:0;z-index:30;box-shadow:2px 0 12px rgba(0,0,0,.2)}
#sidebar.col{width:var(--sbcw)}
.sb-top{padding:14px;border-bottom:1px solid rgba(255,255,255,.07);display:flex;align-items:center;justify-content:space-between;min-height:58px}
.sb-brand{display:flex;align-items:center;gap:10px;overflow:hidden}
.sb-name{white-space:nowrap;font-weight:700;font-size:14px;color:var(--wh);letter-spacing:.5px}
#sidebar.col .sb-name{display:none}
.sb-tog{background:none;border:none;color:var(--mu);font-size:17px;cursor:pointer;padding:4px 6px;border-radius:4px}
#sb-nav{flex:1;padding:10px 0;overflow-y:auto;overflow-x:hidden}
.ns{padding:14px 16px 4px;font-size:9px;font-weight:700;color:var(--mu);letter-spacing:1.2px;text-transform:uppercase;white-space:nowrap}
#sidebar.col .ns{display:none}
.ni{display:flex;align-items:center;gap:10px;padding:10px 16px;color:var(--mu);border-left:3px solid transparent;border-top:none;border-right:none;border-bottom:none;background:none;width:100%;text-align:left;cursor:pointer;font-size:13px;transition:all .15s;white-space:nowrap;position:relative}
.ni:hover{background:rgba(255,255,255,.05);color:var(--wh)}
.ni.active{background:rgba(232,160,32,.15);border-left-color:var(--am);color:var(--am);font-weight:600}
.ni-ic{font-size:18px;flex-shrink:0;width:22px;text-align:center}
#sidebar.col .ni-lb{display:none}
#sidebar.col .ni{padding:11px 0;justify-content:center}
.nb{background:var(--er);color:var(--wh);border-radius:10px;font-size:10px;font-weight:700;padding:1px 6px;margin-left:auto}
#sidebar.col .nb{position:absolute;top:6px;right:4px;font-size:9px;padding:1px 4px}
.sb-user{padding:12px 14px;border-top:1px solid rgba(255,255,255,.07);display:flex;align-items:center;gap:9px;overflow:hidden}
#sidebar.col .sb-user{padding:10px 0;justify-content:center}
.uav{width:32px;height:32px;border-radius:50%;background:var(--am);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;color:var(--st);flex-shrink:0}
.uinfo>div:first-child{font-size:12px;font-weight:600;color:var(--wh);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.urole{font-size:10px;color:var(--mu);white-space:nowrap}
#sidebar.col .uinfo,.sb-user button{transition:opacity .2s}
#sidebar.col .uinfo{display:none}
.sb-user button{background:none;border:none;cursor:pointer;color:var(--mu);font-size:16px;margin-left:auto}
#sidebar.col .sb-user button{display:none}

/* Main */
#main{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden}
#topbar{height:var(--tbh);background:var(--wh);display:flex;align-items:center;padding:0 20px;gap:14px;border-bottom:1px solid var(--du);position:sticky;top:0;z-index:20;box-shadow:0 1px 4px rgba(0,0,0,.05)}
.mob-btn{display:none;background:none;border:none;font-size:20px;cursor:pointer;color:var(--st)}
#tb-bc{font-weight:700;font-size:14px;color:var(--st);flex:1}
.tb-right{display:flex;align-items:center;gap:10px}
.tb-badge{font-size:11px;color:var(--mu);background:var(--co);border-radius:20px;padding:3px 10px}
.tb-date{font-size:11px;color:var(--mu)}
.tb-user-chip{display:flex;align-items:center;gap:7px;background:var(--co);border-radius:20px;padding:4px 12px}
.tb-user-chip span:first-child{font-size:12px;font-weight:600;color:var(--st)}
.role-badge{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;padding:2px 7px;border-radius:10px;background:var(--st);color:var(--am)}
#content{flex:1;overflow-y:auto;padding:22px 24px}
#mob-ov{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:29}
#mob-ov.show{display:block}

/* Responsive */
@media(max-width:768px){
  #sidebar{position:fixed;left:-100%;top:0;bottom:0;z-index:31;transition:left .25s;width:var(--sbw)!important}
  #sidebar.mob-open{left:0}
  .mob-btn{display:block}.sb-tog{display:none}
  #content{padding:14px}
  .g4{grid-template-columns:1fr 1fr!important}
  .g3{grid-template-columns:1fr 1fr!important}
  .g2{grid-template-columns:1fr!important}
  .c3,.c4{grid-template-columns:1fr 1fr!important}
}
@media(max-width:480px){
  .g4,.g3{grid-template-columns:1fr!important}
  .c2,.c3,.c4{grid-template-columns:1fr!important}
  .tb-badge,.tb-date{display:none}
}

/* Forms */
.form-group{margin-bottom:14px}
.form-group label{display:block;font-size:11px;font-weight:700;color:var(--mu);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:9px 12px;border:1.5px solid var(--du);border-radius:var(--rs);font-size:13px;color:var(--tx);background:var(--wh);transition:border-color .15s}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--am)}
.form-group textarea{resize:vertical;min-height:72px;line-height:1.6}
.frow{display:grid;gap:12px}
.c2{grid-template-columns:1fr 1fr}.c3{grid-template-columns:1fr 1fr 1fr}.c4{grid-template-columns:repeat(4,1fr)}
.sub{color:var(--mu);font-size:13px}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:9px 18px;border:none;border-radius:var(--rs);font-weight:700;font-size:13px;cursor:pointer;transition:all .2s;white-space:nowrap}
.btn-sm{padding:5px 11px;font-size:11px;border-radius:4px}
.btn-amber{background:var(--am);color:var(--st);box-shadow:0 3px 10px rgba(232,160,32,.3)}.btn-amber:hover{background:var(--am2)}
.btn-steel{background:var(--st);color:var(--wh)}.btn-ok{background:var(--ok);color:var(--wh);box-shadow:0 3px 8px rgba(39,174,96,.25)}
.btn-err{background:var(--er);color:var(--wh)}.btn-blue{background:var(--bl);color:var(--wh)}.btn-pu{background:var(--pu);color:var(--wh)}
.btn-ghost{background:var(--co);border:1px solid var(--du);color:var(--mu)}.btn-ghost:hover{background:var(--du)}
.btn-outline{background:none;border:1.5px solid var(--du);color:var(--mu)}.btn-outline:hover{border-color:var(--am);color:var(--am)}
.btn-full{width:100%;padding:12px;font-size:14px}
button:disabled{opacity:.5;cursor:not-allowed}

/* Cards */
.card{background:var(--wh);border-radius:var(--rl);padding:20px 24px;box-shadow:var(--sh);margin-bottom:16px}
.card-title{font-size:14px;font-weight:700;color:var(--st);margin-bottom:14px}
.sc{background:var(--wh);border-radius:var(--r);padding:14px 18px;border-left:4px solid var(--st);box-shadow:var(--sh)}
.sc .sl{font-size:10px;color:var(--mu);text-transform:uppercase;letter-spacing:.6px;margin-bottom:4px}
.sc .sv{font-size:20px;font-weight:800;line-height:1.2}
.sc .ss{font-size:11px;color:var(--mu);margin-top:3px}
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:16px}
.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:16px}
.g2{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:16px}

/* Tables */
.tw{overflow-x:auto;border-radius:var(--r);box-shadow:var(--sh)}
.dt{width:100%;border-collapse:collapse;font-size:12px;background:var(--wh)}
.dt thead tr{background:var(--st)}
.dt th{padding:9px 12px;font-weight:600;color:var(--wh);text-align:left;white-space:nowrap;font-size:11px}
.dt td{padding:7px 12px;border-bottom:1px solid var(--co);vertical-align:middle}
.dt tbody tr:last-child td{border-bottom:none}
.dt tbody tr:nth-child(even){background:#F8F7F5}
.dt tbody tr:hover{background:#FFF9EF}
.th{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;flex-wrap:wrap;gap:8px}
.th h3{font-size:13px;font-weight:700;color:var(--st)}
.toolbar{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.srch{padding:7px 12px;border:1.5px solid var(--du);border-radius:var(--rs);font-size:12px;min-width:160px}
.srch:focus{outline:none;border-color:var(--am)}
.ta-r{text-align:right}

/* Badges */
.badge{display:inline-flex;align-items:center;gap:3px;padding:2px 9px;border-radius:12px;font-size:11px;font-weight:600;white-space:nowrap}
.bg{background:#D4EDDA;color:#155724}.br{background:#F8D7DA;color:#721C24}
.ba{background:#FFF3CD;color:#856404}.bb{background:#CCE5FF;color:#004085}
.bp{background:#E2D9F3;color:#4B1F8E}.bk{background:#E9ECEF;color:#495057}
.bst{background:var(--st);color:var(--wh)}

/* Alerts */
.alert{padding:10px 14px;border-radius:var(--rs);font-size:13px;margin-bottom:12px}
.alert-danger{background:#FEE;border:1px solid var(--er);color:var(--er)}
.alert-ok{background:#F0FFF4;border:1px solid var(--ok);color:#155724}
.alert-warn{background:#FFFBF0;border:1px solid var(--wa);color:#7B3F00}
.alert-info{background:#EBF5FB;border:1px solid var(--bl);color:#004085}

/* Tabs */
.tabs{display:flex;background:var(--wh);border-radius:var(--r);overflow:hidden;box-shadow:var(--sh);margin-bottom:16px;flex-wrap:wrap}
.tab{padding:10px 18px;border:none;background:none;font-weight:500;font-size:13px;color:var(--mu);cursor:pointer;transition:all .2s;white-space:nowrap}
.tab.active{background:var(--st);color:var(--am);font-weight:700}

/* Step Nav */
.snav{display:flex;gap:2px;background:var(--wh);border-radius:var(--r);padding:4px;box-shadow:var(--sh);margin-bottom:16px;overflow-x:auto}
.sbtn{display:flex;flex-direction:column;align-items:center;padding:8px 12px;border-radius:var(--rs);border:none;background:none;cursor:pointer;min-width:70px;transition:all .2s;flex-shrink:0}
.sicon{font-size:18px;margin-bottom:2px}
.slbl{font-size:9px;font-weight:500;color:var(--mu);white-space:nowrap}
.sbtn.active{background:var(--st)}.sbtn.active .slbl{color:var(--am);font-weight:700}

/* Modal */
#modal{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:16px}
.modal-bg{position:absolute;inset:0;background:rgba(0,0,0,.5)}
.modal-box{position:relative;background:var(--wh);border-radius:var(--rl);box-shadow:var(--shl);width:100%;max-width:640px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}
.modal-box.modal-lg{max-width:880px}
.modal-hdr{display:flex;align-items:center;justify-content:space-between;padding:16px 22px;border-bottom:1px solid var(--du);flex-shrink:0}
.modal-hdr h3{font-size:15px;font-weight:700;color:var(--st)}
.modal-hdr button{background:none;border:none;font-size:18px;color:var(--mu);cursor:pointer;padding:2px 8px;border-radius:4px}
.modal-body{padding:22px;overflow-y:auto;flex:1}
.modal-ftr{padding:14px 22px;border-top:1px solid var(--du);display:flex;gap:10px;justify-content:flex-end;background:var(--co);flex-shrink:0;flex-wrap:wrap}

/* Toasts */
#toast-container{position:fixed;bottom:24px;right:24px;z-index:200;display:flex;flex-direction:column;gap:8px}
.toast{padding:12px 18px;border-radius:var(--r);font-size:13px;font-weight:500;color:var(--wh);min-width:200px;box-shadow:var(--shl);animation:tin .3s ease;display:flex;align-items:center;gap:8px}
.tst-ok{background:var(--ok)}.tst-err{background:var(--er)}.tst-info{background:var(--bl)}.tst-warn{background:var(--wa)}
@keyframes tin{from{transform:translateX(110%);opacity:0}to{transform:translateX(0);opacity:1}}

/* Upload zone */
.upz{border:2px dashed var(--du);border-radius:var(--r);padding:24px;text-align:center;cursor:pointer;transition:all .2s;background:var(--co)}
.upz:hover,.upz.drag{border-color:var(--am);background:#FFF9EE}
.upz-ic{font-size:32px;margin-bottom:8px}
.upz p{font-size:13px;color:var(--mu)}
.upz small{font-size:11px;color:var(--mu)}
.fchips{display:flex;flex-wrap:wrap;gap:5px;margin-top:8px;justify-content:center}
.fchip{background:var(--wh);border-radius:20px;padding:2px 10px;font-size:11px;color:var(--st)}

/* Progress bar */
.pb{height:6px;background:var(--du);border-radius:3px;overflow:hidden}
.pbf{height:100%;background:var(--am);border-radius:3px;transition:width .3s}

/* Page header */
.ph{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;flex-wrap:wrap;gap:10px}
.ph h1{font-size:18px;font-weight:800;color:var(--st)}
.sl{font-size:11px;font-weight:700;color:var(--am);text-transform:uppercase;letter-spacing:.8px;margin-bottom:8px;padding-bottom:6px;border-bottom:2px solid rgba(232,160,32,.2)}

/* Pipeline */
.pipe{display:flex;flex-wrap:wrap;margin-bottom:14px;border-radius:var(--rs);overflow:hidden;box-shadow:var(--sh)}
.ps{flex:1;min-width:80px;padding:10px 6px;text-align:center;background:var(--co);cursor:pointer;border-right:2px solid var(--du)}
.ps:last-child{border-right:none}.ps:hover{background:var(--du)}
.psc{font-size:22px;font-weight:800;color:var(--st)}
.psl{font-size:10px;color:var(--mu);font-weight:600;text-transform:uppercase;letter-spacing:.4px}
.ps.hi{background:rgba(232,160,32,.15)}.ps.hi .psl{color:var(--am)}

/* Rate compare */
.rc-po{color:var(--bl);font-weight:700}.rc-ag{color:var(--ok);font-weight:700}.rc-mg{color:var(--am);font-weight:800}

/* Module banners */
.mbanner{border-radius:var(--rl);padding:16px 22px;color:var(--wh);display:flex;align-items:center;gap:16px;margin-bottom:16px;flex-wrap:wrap}
.mb-mp{background:linear-gradient(135deg,var(--st) 0%,var(--bl) 100%)}
.mb-eq{background:linear-gradient(135deg,var(--st) 0%,var(--pu) 100%)}
.mb-cp{background:linear-gradient(135deg,var(--st) 0%,var(--wa) 100%)}
.mb-ai{background:linear-gradient(135deg,#0F2027 0%,#203A43 50%,#2C5364 100%)}
.mbi{font-size:40px;flex-shrink:0}
.mbanner h2{font-size:17px;font-weight:800;margin-bottom:2px}
.mbanner p{font-size:12px;opacity:.85}

/* AI Inbox */
.ai-doc{border:1px solid var(--du);border-radius:var(--r);padding:16px;margin-bottom:10px;background:var(--wh);display:flex;align-items:flex-start;gap:14px}
.ai-doc.processing{border-color:var(--wa);background:#FFFBF0}
.ai-doc.completed{border-color:var(--ok);background:#F0FFF4}
.ai-doc.failed{border-color:var(--er);background:#FEF2F2}
.ai-doc.needs_review{border-color:var(--bl);background:#EBF5FB}
.ai-doc-icon{font-size:28px;flex-shrink:0}
.ai-doc-name{font-weight:700;font-size:13px;color:var(--st);margin-bottom:3px}
.ai-doc-det{font-size:12px;color:var(--mu);margin-bottom:6px}
.ai-tag{display:inline-block;background:var(--st);color:var(--am);font-size:10px;font-weight:700;padding:2px 8px;border-radius:10px;margin-right:5px;text-transform:uppercase}

/* Spinner */
.spin{display:inline-block;width:18px;height:18px;border:3px solid var(--du);border-top-color:var(--am);border-radius:50%;animation:rot .7s linear infinite;flex-shrink:0}
@keyframes rot{to{transform:rotate(360deg)}}
.loading{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--wa);padding:14px 0}

/* Empty */
.empty{text-align:center;padding:48px 20px;color:var(--mu)}
.empty .ei{font-size:48px;margin-bottom:12px}
.empty h3{font-size:16px;font-weight:700;color:var(--st);margin-bottom:6px}

/* Profit box */
.profit-box{border-radius:var(--r);padding:16px 20px;display:flex;justify-content:space-between;align-items:center}
.profit-box.green{background:#F0FFF4;border:1px solid var(--ok)}.profit-box.red{background:#FEF2F2;border:1px solid var(--er)}

/* Utilities */
.flex{display:flex}.fac{display:flex;align-items:center}.fbc{display:flex;align-items:center;justify-content:space-between}
.gap8{gap:8px}.gap12{gap:12px}
.mt8{margin-top:8px}.mt12{margin-top:12px}.mt16{margin-top:16px}
.mb8{margin-bottom:8px}.mb12{margin-bottom:12px}.mb16{margin-bottom:16px}
.mu{color:var(--mu)}.fw7{font-weight:700}.f11{font-size:11px}.f12{font-size:12px}.f13{font-size:13px}
.w100{width:100%}
.divider{height:1px;background:var(--du);margin:14px 0}
.actions{display:flex;gap:5px;flex-wrap:nowrap}
code{font-size:11px;background:var(--co);padding:1px 6px;border-radius:3px;font-family:monospace}
