/* ══════════════════════════════════════════════════
   PORTAL — theme vars (body.app-mode)
══════════════════════════════════════════════════ */
body.app-mode{
  
  --white:#F5EDE8;--off:#EDE4E0;--off2:#E4D8D0;
  --gold:#6D4035;--gold-l:#8A5B59;--gold-dim:rgba(109,64,53,0.12);--gold-dim2:rgba(109,64,53,0.05);
  --black:#311418;--ink:#2A1216;--gray:#5A2A28;--gray-l:#8A5050;--gray-ll:#B29488;
  --border:#D6C7B8;--border-s:#E4D0C8;--r:4px;--rl:6px;
  --green:#4a7a4a;--green-bg:#ecf2ec;--green-border:#a8c8a8;
  --amber:#907018;--amber-bg:#fdf7e8;--amber-border:#deca80;
  --red:#904040;--red-bg:#fdf0f0;--red-border:#d8a8a8;
  --int:#8A5B59;--int-l:#B29488;--int-dim:rgba(138,91,89,0.12);--int-dim2:rgba(138,91,89,0.05);

  font-family:'Montserrat',sans-serif!important;letter-spacing:.01em;
  background:var(--white)!important;
  color:var(--ink)!important;
}
body.app-mode::-webkit-scrollbar-track{background:var(--off)}
body.app-mode::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}

/* ══════════════════════════════════════════════════
   PORTAL — original styles
══════════════════════════════════════════════════ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}



/* ─── LOGIN ─── */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--burgundy);flex-direction:column;gap:0}
.login-box{background:var(--white);border:1px solid var(--border);border-radius:var(--rl);padding:40px 44px;width:420px;max-width:95vw}
.login-brand{text-align:center;margin-bottom:28px}
.login-logo{width:48px;height:48px;border:1px solid var(--gold);display:flex;align-items:center;justify-content:center;margin:0 auto 10px}
.login-logo-inner{display:flex;align-items:center;justify-content:center;}
.login-title{font-family:'Cormorant Garamond',serif;font-size:26px;font-weight:400;letter-spacing:.1em;color:#F5EDE8}
.login-title span.g{color:var(--gold)}.login-title span.v{color:var(--int)}
.login-sub{font-size:11px;color:#B29488;letter-spacing:.04em;margin-top:3px}
.login-field{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}
.login-field label{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--gray-l)}
.login-field input{background:var(--off);border:1px solid var(--border);border-radius:var(--r);padding:9px 12px;color:var(--ink);font-size:13px;font-family:'Montserrat',sans-serif;outline:none;transition:border-color .15s}
.login-field input:focus{border-color:var(--gold)}
.login-btn{width:100%;padding:10px;background:var(--gold);color:#fff;border:none;border-radius:var(--r);font-family:'Montserrat',sans-serif;font-size:13px;cursor:pointer;letter-spacing:.04em;margin-top:6px;transition:background .15s}
.login-btn:hover{background:var(--gold-l)}
.login-err{font-size:11px;color:#b07070;margin-top:10px;text-align:center;min-height:16px}
.login-demo{margin-top:20px;padding-top:16px;border-top:1px solid var(--border);font-size:11px;color:var(--gray-l);text-align:center;line-height:1.8}
.login-demo strong{color:var(--gray)}

/* ─── MODULE SWITCHER ─── */
.module-bar{background:#311418;border-bottom:1px solid #4a2020;display:flex;align-items:center;justify-content:center;padding:8px 24px;gap:0;position:sticky;top:0;z-index:101;flex-shrink:0}
.mod-btn{padding:6px 22px;border-radius:3px;font-size:11px;letter-spacing:.12em;text-transform:uppercase;font-family:'Montserrat',sans-serif;cursor:pointer;border:1px solid transparent;transition:all .2s;display:flex;align-items:center;gap:6px}
.mod-btn svg{width:12px;height:12px;flex-shrink:0}
.mod-btn.mod-light{color:#888;border-color:transparent}
.mod-btn.mod-light:hover{color:var(--gold);background:rgba(184,149,90,.08);border-color:rgba(184,149,90,.2)}
.mod-btn.mod-light.active{color:var(--gold);background:rgba(184,149,90,.12);border-color:rgba(184,149,90,.3)}
.mod-btn.mod-int{color:#888;border-color:transparent}
.mod-btn.mod-int:hover{color:var(--int-l);background:var(--int-dim);border-color:rgba(107,79,160,.3)}
.mod-btn.mod-int.active{color:var(--int-l);background:var(--int-dim);border-color:rgba(107,79,160,.4)}
.mod-divider{width:1px;height:18px;background:#6D4035;margin:0 8px}

/* ─── USER BADGE ─── */
.user-badge{display:flex;align-items:center;gap:7px;padding:4px 10px;border-radius:var(--r);border:1px solid #6D4035;cursor:default}
.u-avatar{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:600;letter-spacing:.05em;flex-shrink:0}
.u-admin .u-avatar{background:var(--gold);color:var(--white)}
.u-staff .u-avatar{background:#4a7a5a;color:#fff}
.u-guest .u-avatar{background:#555;color:#ccc}
.u-name{font-size:11px;color:#888;max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.u-role{font-size:9px;letter-spacing:.1em;text-transform:uppercase}
.u-admin .u-role{color:var(--gold)}
.u-staff .u-role{color:#7aaa8a}
.u-guest .u-role{color:#666}
.btn-logout{padding:4px 8px;border-radius:var(--r);border:1px solid #6D4035;background:transparent;color:#B29488;font-size:11px;cursor:pointer;font-family:'Montserrat',sans-serif;transition:all .15s}
.btn-logout:hover{background:#4a2020;color:#D6C7B8}

/* ─── TOPBAR ─── */
.topbar{height:52px;background:#311418;display:flex;align-items:center;justify-content:space-between;padding:0 20px;z-index:100;border-bottom:1px solid #1e1e1c;flex-shrink:0}
.brand{display:flex;align-items:center;gap:10px}
.brand-mark{width:26px;height:26px;border:1px solid;display:flex;align-items:center;justify-content:center}
.brand-mark svg{width:13px;height:13px;fill:none;stroke-width:1.5;stroke-linecap:round}
.brand-mark.light{border-color:var(--gold)}
.brand-mark.light svg{stroke:var(--gold)}
.brand-mark.interior{border-color:var(--int-l)}
.brand-mark.interior svg{stroke:var(--int-l)}
.brand-name{font-family:'Cormorant Garamond',serif;font-size:16px;font-weight:500;letter-spacing:.14em;color:var(--vanilla);text-transform:uppercase}
.brand-name span.g{color:var(--gold)}
.brand-name span.v{color:var(--int-l)}
.topbar-r{display:flex;align-items:center;gap:8px}

/* ─── BTN ─── */
.btn{padding:6px 13px;border-radius:var(--r);border:1px solid var(--border);background:transparent;color:var(--gray);font-family:'Montserrat',sans-serif;font-size:12px;font-weight:400;cursor:pointer;transition:all .15s;letter-spacing:.03em;display:inline-flex;align-items:center;gap:5px;line-height:1}
.btn:hover{background:var(--off);color:var(--ink);border-color:var(--gray-ll)}
.btn-gold{background:var(--gold);color:#fff;border-color:var(--gold)}
.btn-gold:hover{background:var(--gold-l);border-color:var(--gold-l)}
.btn-int{background:var(--int);color:#fff;border-color:var(--int)}
.btn-int:hover{background:var(--int-l);border-color:var(--int-l)}
.btn-gw{border-color:#6D4035;color:#B29488}
.btn-gw:hover{background:#4a2020;color:#D6C7B8;border-color:#8A5B59}
.btn-sm{padding:4px 10px;font-size:11px}
.btn-del{border-color:#e8cece;color:#b07070}
.btn-del:hover{background:#fef5f5;border-color:#c08080;color:#903030}
.btn-edit-inline{padding:3px 8px;font-size:10px;border-radius:3px;border:1px solid var(--border);background:transparent;color:var(--gray-l);font-family:'Montserrat',sans-serif;cursor:pointer;transition:all .15s;letter-spacing:.03em}
.btn-edit-inline:hover{background:var(--gold-dim);color:var(--gold);border-color:var(--gold)}
.btn-save-inline{padding:3px 8px;font-size:10px;border-radius:3px;border:1px solid var(--gold);background:var(--gold);color:#fff;font-family:'Montserrat',sans-serif;cursor:pointer;letter-spacing:.03em}

/* ─── LAYOUT ─── */
.layout{display:flex;flex:1;overflow:hidden;height:100%}
.nav{width:210px;background:#3d1a1c;border-right:1px solid #4a2020;display:flex;flex-direction:column;flex-shrink:0;overflow:hidden;transition:width .2s}
.nav.collapsed{width:0;border-right:none}
.nav-sec{padding:16px 14px 6px;font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:#8A5B59;font-weight:400;display:flex;align-items:center;justify-content:space-between}
.nav-sec-toggle{cursor:pointer;color:#444;font-size:14px;line-height:1;padding:0 2px;transition:color .15s;background:none;border:none;font-family:monospace}
.nav-sec-toggle:hover{color:#888}
.nav-item{padding:9px 14px;cursor:pointer;display:flex;align-items:center;gap:9px;color:#777;font-size:12px;letter-spacing:.02em;transition:all .15s;border-left:2px solid transparent;white-space:nowrap}
.nav-item svg{width:13px;height:13px;flex-shrink:0;stroke:currentColor;fill:none;stroke-width:1.5;stroke-linecap:round}
.nav-item:hover{color:#ccc;background:#161614}
.nav-item.active{color:var(--peach);border-left-color:var(--mocha);background:rgba(109,64,53,.15)}
.nav-item.active.int{color:var(--int-l);border-left-color:var(--int-l);background:var(--int-dim2)}
.nav-hr{border:none;border-top:1px solid #4a2020;margin:6px 0}
.proj-list{flex:1;overflow-y:auto;padding:2px 0}
.proj-list::-webkit-scrollbar{width:2px}
.proj-list::-webkit-scrollbar-thumb{background:#333}
.pitem{padding:8px 14px 8px 26px;cursor:pointer;color:#555;font-size:11px;display:flex;align-items:center;justify-content:space-between;gap:6px;transition:all .15s;border-left:2px solid transparent}
.pitem:hover{color:#aaa;background:#161614}
.pitem.active{color:var(--gold-l);border-left-color:var(--gold-l);background:rgba(184,149,90,.04)}
.pitem-cnt{background:#1e1e1c;border-radius:10px;padding:1px 7px;font-size:10px;color:#444;flex-shrink:0}
.pitem.active .pitem-cnt{background:rgba(184,149,90,.15);color:var(--gold)}
.nav-add{padding:10px 14px;border-top:1px solid #4a2020}
.nav-proj-header{padding:6px 14px;display:flex;align-items:center;justify-content:space-between}
.nav-proj-section{overflow:hidden;transition:max-height .25s}
.nav-proj-section.collapsed{max-height:0!important}

.sb{width:265px;background:var(--off);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;overflow:hidden}
.sb-head{padding:12px 14px;border-bottom:1px solid var(--border)}
.sb-ttl{font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--gray-l);margin-bottom:9px}
.srch{position:relative}
.srch input{width:100%;background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:7px 10px 7px 28px;color:var(--ink);font-size:12px;font-family:'Montserrat',sans-serif;outline:none;transition:border-color .15s}
.srch input:focus{border-color:var(--gold)}
.srch input::placeholder{color:var(--gray-ll)}
.srch-ic{position:absolute;left:8px;top:50%;transform:translateY(-50%);color:var(--gray-ll);font-size:13px}
.slist{flex:1;overflow-y:auto;padding:6px}
.slist::-webkit-scrollbar{width:3px}
.slist::-webkit-scrollbar-thumb{background:var(--border)}
.scard{padding:11px;border-radius:var(--r);border:1px solid transparent;cursor:pointer;margin-bottom:3px;transition:all .15s}
.scard:hover{background:var(--white);border-color:var(--border)}
.scard.active{background:var(--white);border-color:var(--gold)}
.scard.active.int{border-color:var(--int)}
.sid{font-size:10px;font-weight:500;color:var(--gold);letter-spacing:.08em;margin-bottom:2px}
.sid.int{color:var(--int)}
.sname{font-size:13px;font-weight:400;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px}
.smeta{display:flex;align-items:center;gap:5px;flex-wrap:wrap}
.pill{padding:2px 7px;border-radius:3px;font-size:10px}
.pill-in{background:var(--off2);color:var(--gray);border:1px solid var(--border)}
.pill-out{background:#eff4ec;color:#5a7a50;border:1px solid #c0d4b8}
.pill-q{background:var(--gold-dim);color:var(--gold);border:1px solid rgba(184,149,90,.2)}
.pill-status-app{background:var(--green-bg);color:var(--green);border:1px solid var(--green-border)}
.pill-status-draft{background:var(--off2);color:var(--gray);border:1px solid var(--border)}
.pill-status-pend{background:var(--amber-bg);color:var(--amber);border:1px solid var(--amber-border)}
.pill-status-can{background:var(--red-bg);color:var(--red);border:1px solid var(--red-border)}
.sb-ft{padding:9px 14px;border-top:1px solid var(--border);font-size:11px;color:var(--gray-l)}

.main{flex:1;overflow-y:auto;background:var(--white)}
.main::-webkit-scrollbar{width:4px}
.main::-webkit-scrollbar-thumb{background:var(--border)}
.empty{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--gray-l);padding:40px}
.empty-ring{width:52px;height:52px;border:1px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center}
.empty h3{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:400;color:var(--gray);letter-spacing:.04em}
.empty p{font-size:12px;color:var(--gray-l);text-align:center;max-width:250px;line-height:1.7}
.panel{padding:28px 36px;max-width:1100px}
.phead{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;padding-bottom:22px;border-bottom:1px solid var(--border)}
.pid{font-size:10px;letter-spacing:.15em;color:var(--gold);font-weight:500;text-transform:uppercase;margin-bottom:5px}
.pid.int{color:var(--int)}
.pname{font-family:'Cormorant Garamond',serif;font-size:28px;font-weight:600;letter-spacing:-.01em;color:var(--black);line-height:1.2}
.psub{margin-top:6px;font-size:12px;color:var(--gray-l);display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.sbadge{padding:3px 10px;border-radius:3px;font-size:10px;letter-spacing:.05em;font-weight:600}
.b-app{background:var(--green-bg);color:var(--green);border:1px solid var(--green-border)}
.b-draft{background:var(--off2);color:var(--gray);border:1px solid var(--border)}
.b-pend{background:var(--amber-bg);color:var(--amber);border:1px solid var(--amber-border)}
.b-can{background:var(--red-bg);color:var(--red);border:1px solid var(--red-border)}
.pactions{display:flex;gap:7px;flex-shrink:0;margin-top:3px}
.sec{margin-bottom:26px}
.sttl{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:14px;display:flex;align-items:center;gap:10px;font-weight:600}
.sttl::after{content:'';flex:1;height:1px;background:var(--gold-dim)}
.sttl.int{color:var(--int)}
.sttl.int::after{background:var(--int-dim)}
.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.g2{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.s2{grid-column:span 2}.s3{grid-column:span 3}.s4{grid-column:span 4}
.vf{display:flex;flex-direction:column;gap:4px}
.vl{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--gray-l)}
.vv{font-size:13px;color:var(--ink);padding:7px 10px;background:var(--off);border:1px solid var(--border-s);border-radius:var(--r);min-height:34px;line-height:1.5}
.vv.mono{font-size:11px;font-weight:500;color:var(--gold);letter-spacing:.06em}
.vv.em{color:var(--gray-ll);font-style:italic;font-size:12px}
.vv.na{color:var(--gray-ll);font-style:italic;font-size:12px}
.vv.note{white-space:pre-wrap;min-height:56px}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:20px}
.stat{background:var(--off);border:1px solid var(--border-s);border-radius:var(--rl);padding:14px 16px}
.stl{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--gray-l);margin-bottom:4px}
.stv{font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:400;color:var(--black)}
.stv.g{color:var(--gold)}
.stv.v{color:var(--int)}
.tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:22px;flex-wrap:wrap}
.tab{padding:9px 16px;font-size:12px;letter-spacing:.03em;color:var(--gray-l);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .15s}
.tab:hover{color:var(--ink)}
.tab.active{color:var(--gold);border-bottom-color:var(--gold)}
.tab.active.int{color:var(--int);border-bottom-color:var(--int)}

/* ─── IMAGE HERO ─── */
.img-hero{margin-bottom:22px;border:1px solid var(--border);border-radius:var(--rl);overflow:hidden;background:var(--off)}
.img-hero-main{position:relative;background:var(--off2);display:flex;align-items:center;justify-content:center;min-height:240px;max-height:360px;overflow:hidden;cursor:pointer}
.img-hero-main img{width:100%;max-height:360px;object-fit:contain;display:block}
.img-hero-main .no-img{display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--gray-ll);padding:60px;text-align:center}
.img-hero-main .no-img svg{width:36px;height:36px;stroke:currentColor;fill:none;stroke-width:1;stroke-linecap:round}
.img-hero-thumb-row{display:flex;gap:0;border-top:1px solid var(--border);background:var(--off)}
.img-thumb-item{width:68px;height:68px;flex-shrink:0;overflow:hidden;cursor:pointer;border-right:1px solid var(--border);position:relative;display:flex;align-items:center;justify-content:center;background:var(--off2)}
.img-thumb-item img{width:100%;height:100%;object-fit:cover;transition:opacity .15s}
.img-thumb-item:hover img{opacity:.8}
.img-thumb-item.active-thumb{outline:2px solid var(--gold);outline-offset:-2px}
.img-thumb-item .idel{position:absolute;top:2px;right:2px;background:rgba(0,0,0,.6);color:#fff;border:none;border-radius:2px;padding:1px 4px;font-size:9px;cursor:pointer;opacity:0;transition:opacity .15s;font-family:'Montserrat',sans-serif;line-height:1.4}
.img-thumb-item:hover .idel{opacity:1}
.img-add-btn{width:68px;height:68px;flex-shrink:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;cursor:pointer;color:var(--gray-l);font-size:10px;border-right:1px solid var(--border);transition:all .15s}
.img-add-btn:hover{background:var(--gold-dim2);color:var(--gold)}
.img-add-btn svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.5;stroke-linecap:round}

/* ─── TABLES ─── */
.ptbl-wrap{border:1px solid var(--border);border-radius:var(--rl);overflow:hidden}
.ptbl{width:100%;border-collapse:collapse}
.ptbl th{font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--gray-l);padding:8px 12px;border-bottom:1px solid var(--border);text-align:left;font-weight:400;background:var(--off)}
.ptbl td{padding:9px 12px;border-bottom:1px solid var(--border-s);font-size:12px;color:var(--ink);vertical-align:middle}
.ptbl tr:last-child td{border-bottom:none}
.ptbl tr:not(.tr-total):hover td{background:var(--off)}
.nr{text-align:right}
.boq-wrap{border:1px solid var(--border);border-radius:var(--rl);overflow:hidden;margin-bottom:20px}
.btbl{width:100%;border-collapse:collapse}
.btbl th{font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--gray-l);padding:9px 13px;border-bottom:1px solid var(--border);text-align:left;font-weight:400;background:var(--off)}
.btbl td{padding:9px 13px;border-bottom:1px solid var(--border-s);font-size:12px;color:var(--ink);vertical-align:middle}
.btbl tr:not(.brow-sec):not(.brow-tot):not(.brow-grand):hover td{background:var(--off)}
.brow-sec td{background:var(--gold-dim2);color:var(--gold);font-size:9px;letter-spacing:.12em;text-transform:uppercase;font-weight:500;padding:5px 13px}
.brow-sec.int td{background:var(--int-dim2);color:var(--int)}
.brow-brand td{background:var(--off2);color:var(--gray);font-size:9px;letter-spacing:.1em;text-transform:uppercase;padding:5px 13px;font-weight:500}
.brow-tot td{background:var(--off2);font-weight:500;color:var(--black);font-size:13px}
.brow-grand td{background:var(--burgundy);color:var(--peach);font-size:15px;font-family:'Cormorant Garamond',serif;border-bottom:none}
.brow-grand:hover td{background:var(--black)!important}

/* ─── PROCUREMENT INLINE ─── */
.ptbl td input.proc-input{background:transparent;border:none;border-bottom:1px solid transparent;border-radius:0;padding:3px 4px;font-size:12px;font-family:'Montserrat',sans-serif;color:var(--ink);outline:none;width:100%;transition:border-color .15s}
.ptbl td input.proc-input:focus{border-bottom-color:var(--gold);background:var(--gold-dim2)}
.ptbl.edit-mode td{padding:6px 8px}
.proc-edit-bar{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--gold-dim2);border:1px solid rgba(184,149,90,.2);border-radius:var(--r);margin-bottom:8px;font-size:11px;color:var(--gold)}
.proc-edit-bar svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:1.5;stroke-linecap:round;flex-shrink:0}
.autosave-dot{width:6px;height:6px;border-radius:50%;background:var(--gold);display:inline-block;margin-right:4px;animation:pulse 1.5s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

/* ─── STATUS BAR ─── */
.status-bar{display:flex;align-items:center;gap:6px;padding:8px 12px;background:var(--off);border:1px solid var(--border-s);border-radius:var(--r);margin-bottom:14px}
.status-bar-label{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--gray-l);margin-right:4px}
.status-btn{padding:3px 10px;border-radius:3px;font-size:10px;letter-spacing:.05em;font-weight:500;cursor:pointer;border:1px solid transparent;font-family:'Montserrat',sans-serif;transition:all .15s}
.status-btn:not(.active):hover{opacity:.7}
.status-btn.active{box-shadow:0 0 0 2px var(--gold)}
.sb-app{background:var(--green-bg);color:var(--green);border-color:var(--green-border)}
.sb-draft{background:var(--off2);color:var(--gray);border-color:var(--border)}
.sb-pend{background:var(--amber-bg);color:var(--amber);border-color:var(--amber-border)}
.sb-can{background:var(--red-bg);color:var(--red);border-color:var(--red-border)}

/* ─── COMPARE ─── */
.compare-wrap{border:1px solid var(--border);border-radius:var(--rl);overflow:hidden;margin-bottom:14px}
.compare-tbl{width:100%;border-collapse:collapse}
.compare-tbl th{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);padding:9px 12px;border-bottom:1px solid var(--border);text-align:left;font-weight:500;background:var(--off)}
.compare-tbl th:not(:first-child){text-align:center;border-left:1px solid var(--border)}
.compare-tbl td{padding:8px 12px;border-bottom:1px solid var(--border-s);font-size:12px;color:var(--ink);vertical-align:middle}
.compare-tbl td:not(:first-child){text-align:center;border-left:1px solid var(--border-s)}
.compare-tbl tr:last-child td{border-bottom:none}
.compare-tbl tr:hover td{background:var(--off)}
.compare-tbl .field-label{font-size:10px;color:var(--gray-l);letter-spacing:.06em;font-weight:500}
.compare-tbl td input.ci{background:transparent;border:none;border-bottom:1px solid transparent;padding:2px 4px;font-size:12px;font-family:'Montserrat',sans-serif;color:var(--ink);outline:none;width:100%;text-align:center;transition:border-color .15s}
.compare-tbl td input.ci:focus{border-bottom-color:var(--gold);background:var(--gold-dim2)}
.compare-brand-input{font-size:14px;font-weight:500;text-align:center;color:var(--black);border-bottom:1px solid var(--border);width:100%;background:transparent;border-top:none;border-left:none;border-right:none;outline:none;font-family:'Montserrat',sans-serif;padding:2px}
.compare-brand-input:focus{border-bottom-color:var(--gold)}
.btn-add-brand{padding:4px 12px;border-radius:var(--r);border:1px dashed var(--border);background:transparent;color:var(--gray-l);font-family:'Montserrat',sans-serif;font-size:11px;cursor:pointer;transition:all .15s}
.btn-add-brand:hover{border-color:var(--gold);color:var(--gold);background:var(--gold-dim2)}
.btn-del-brand{padding:2px 7px;border-radius:3px;border:1px solid #e8cece;background:transparent;color:#b07070;font-size:10px;cursor:pointer;font-family:'Montserrat',sans-serif;margin-left:4px}
.btn-del-brand:hover{background:#fef5f5}

/* ─── ACC TABLE ─── */
.acc-tbl{width:100%;border-collapse:collapse}
.acc-tbl th{font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--gray-l);padding:7px 10px;border-bottom:1px solid var(--border);text-align:left;font-weight:400;background:var(--off)}
.acc-tbl td{padding:8px 10px;border-bottom:1px solid var(--border-s);font-size:12px;color:var(--ink);vertical-align:middle}
.acc-tbl tr:last-child td{border-bottom:none}
.acc-tbl tr:hover td{background:var(--off)}
.acc-type-badge{padding:2px 7px;border-radius:3px;font-size:10px;letter-spacing:.04em;font-weight:500}
.acc-lens{background:#e8f0fe;color:#3a5fcc;border:1px solid #b8d0f8}
.acc-bracket{background:#fce8e0;color:#c04a20;border:1px solid #f0b8a0}
.acc-deco{background:#f0e8fc;color:#7030b0;border:1px solid #d8b0f8}
.acc-filter{background:#e8fce8;color:#207030;border:1px solid #a0d8a0}
.acc-other{background:var(--off2);color:var(--gray);border:1px solid var(--border)}

/* ─── MODALS ─── */
.overlay{display:none;position:fixed;inset:0;background:rgba(49,20,24,.5);z-index:200;align-items:flex-start;justify-content:center;padding:36px 20px;overflow-y:auto}
.overlay.show{display:flex}
.modal{background:var(--white);border:1px solid var(--border);border-radius:var(--rl);padding:28px;width:700px;max-width:100%;margin-bottom:40px}
.modal h2{font-family:'Cormorant Garamond',serif;font-size:21px;font-weight:400;margin-bottom:20px;color:var(--black);letter-spacing:.02em}
.m-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:20px;padding-top:18px;border-top:1px solid var(--border)}
.pm{width:520px}
.co{display:none;position:fixed;inset:0;background:rgba(49,20,24,.6);z-index:300;align-items:center;justify-content:center}
.co.show{display:flex}
.cbox{background:var(--white);border:1px solid var(--border);border-radius:var(--rl);padding:24px;width:340px}
.cbox h3{font-family:'Cormorant Garamond',serif;font-size:17px;font-weight:400;margin-bottom:7px}
.cbox p{font-size:12px;color:var(--gray);margin-bottom:18px;line-height:1.6}
.c-actions{display:flex;gap:8px;justify-content:flex-end}
.lightbox{display:none;position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:400;align-items:center;justify-content:center}
.lightbox.show{display:flex}
.lightbox img{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:4px}
.lb-close{position:fixed;top:18px;right:22px;color:#888;font-size:22px;cursor:pointer;background:none;border:none;line-height:1;font-family:'Montserrat',sans-serif}
.toast{position:fixed;bottom:22px;right:22px;background:var(--black);border:1px solid #2a2a28;border-radius:var(--rl);padding:11px 16px;font-size:12px;color:#ccc;z-index:999;opacity:0;transform:translateY(6px);transition:all .22s;pointer-events:none;display:flex;align-items:center;gap:9px;letter-spacing:.02em}
.toast.show{opacity:1;transform:translateY(0)}
.tdot{width:6px;height:6px;border-radius:50%;background:var(--gold);flex-shrink:0}

/* ─── FORM ─── */
.field{display:flex;flex-direction:column;gap:4px}
body.app-mode label{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--gray-l)}
body.app-mode input[type=text],body.app-mode input[type=number],body.app-mode select,body.app-mode textarea{background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:7px 10px;color:var(--ink);font-size:13px;font-family:'Montserrat',sans-serif;outline:none;transition:border-color .15s;width:100%}
body.app-mode input:focus,body.app-mode select:focus,body.app-mode textarea:focus{border-color:var(--gold)}
body.app-mode input::placeholder,body.app-mode textarea::placeholder{color:var(--gray-ll)}
select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23bbb' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 9px center}
textarea{resize:vertical;min-height:72px}
.iunit{display:flex}
.iunit input{border-radius:var(--r) 0 0 var(--r);border-right:none}
.utag{background:var(--off);border:1px solid var(--border);border-radius:0 var(--r) var(--r) 0;padding:7px 9px;font-size:11px;color:var(--gray-l);white-space:nowrap;display:flex;align-items:center;min-width:42px;justify-content:center}

/* ─── CATALOG / PRODUCT LIBRARY ─── */
.catalog-card{border:1px solid var(--border);border-radius:var(--rl);margin-bottom:8px;overflow:hidden;cursor:pointer;transition:border-color .15s}
.catalog-card:hover{border-color:var(--gold)}
.catalog-card.int:hover{border-color:var(--int)}
.catalog-card-head{padding:10px 14px;display:flex;align-items:center;justify-content:space-between;background:var(--off)}
.catalog-card-id{font-size:10px;color:var(--gold);font-weight:600;letter-spacing:.08em}
.catalog-card-id.int{color:var(--int)}
.catalog-card-name{font-size:13px;font-weight:500;color:var(--ink)}
.catalog-card-meta{font-size:11px;color:var(--gray-l);margin-top:2px}

/* ─── BOQ FIXTURE CARDS ─── */
.boq-fixture-card{border:1px solid var(--border);border-radius:var(--rl);margin-bottom:10px;overflow:hidden;transition:border-color .15s}
.boq-fixture-card:hover{border-color:var(--gold-l)}
.boq-fc-head{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--off);cursor:pointer}
.boq-fc-id{font-size:10px;font-weight:600;color:var(--gold);letter-spacing:.1em}
.boq-fc-id.int{color:var(--int)}
.boq-fc-name{font-size:13px;font-weight:500;color:var(--ink);margin-top:1px}
.boq-fc-val{font-size:15px;font-family:'Cormorant Garamond',serif;color:var(--gold)}
.boq-fc-body{padding:10px 14px;border-top:1px solid var(--border-s);display:none;background:var(--white)}
.boq-fc-body.open{display:block}
.boq-mini-tbl{width:100%;border-collapse:collapse}
.boq-mini-tbl th{font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--gray-l);padding:5px 8px;border-bottom:1px solid var(--border-s);text-align:left;font-weight:400}
.boq-mini-tbl td{padding:6px 8px;border-bottom:1px solid var(--border-s);font-size:12px;color:var(--ink)}
.boq-mini-tbl tr:last-child td{border-bottom:none}

/* ─── HISTORY ─── */
.history-item{padding:12px 14px;border-bottom:1px solid var(--border-s);font-size:12px}
.history-item:last-child{border-bottom:none}
.no-history{padding:16px;text-align:center;color:var(--gray-l);font-size:12px}

/* ─── ACCT MODAL ─── */
.acct-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border-s)}
.acct-info{flex:1}
.acct-name{font-weight:500;font-size:13px}
.acct-meta{font-size:11px;color:var(--gray-l);margin-top:1px}
.acct-role-badge{padding:2px 8px;border-radius:3px;font-size:10px;font-weight:600;letter-spacing:.04em}
.role-admin{background:var(--gold-dim);color:var(--gold);border:1px solid rgba(184,149,90,.3)}
.role-staff{background:#e8f4ec;color:#4a7a5a;border:1px solid #a8cca8}
.role-guest{background:var(--off2);color:var(--gray-l);border:1px solid var(--border)}

/* ─── NAV TOGGLE ─── */
.nav-toggle-btn{position:absolute;left:2px;top:50%;transform:translateY(-50%);z-index:10;background:var(--black);border:1px solid #2a2a28;border-radius:0 3px 3px 0;padding:8px 4px;cursor:pointer;color:#555;transition:all .15s;display:none}
.nav-toggle-btn:hover{color:#999}
.layout-wrap{position:relative;display:flex;flex:1;overflow:hidden;min-height:0}
#mob-nav-btn{display:none;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid #333;border-radius:var(--r);background:transparent;cursor:pointer;color:#777;flex-shrink:0}
#mob-nav-btn:hover{color:#ccc;background:#1e1e1c}
#mob-nav-btn svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:1.5;stroke-linecap:round}
.mob-nav-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:199}
.mob-nav-overlay.show{display:block}

/* ─── PRINT ─── */
@media print{
  .topbar,.module-bar,.nav,.sb,.pactions,.status-bar,.tabs,
  #btnNewSpec,#btnProj,#btnAcct,.btn-logout,
  .proc-edit-bar,.img-hero-thumb-row .img-add-btn,
  [id$="Overlay"],[id="coEl"],[id="lb"],[id="toast"],
  .boq-fixture-card,.boq-wrap:not(.print-target),
  #boqEl .tabs,#boqEl .stats{display:none!important}
  body{font-size:11px}
  .layout{height:auto;overflow:visible}
  .main{overflow:visible}
  .panel{padding:12px 16px;max-width:100%}
  .print-boq-only .boq-wrap{display:block!important}
  .spec-print-page{page-break-after:always;padding:20px 24px}
  .spec-print-page:last-child{page-break-after:auto}
}

/* ─── RESPONSIVE — TABLET (≤900px) ─── */
/* ════════════════════════════════════════════════════
   RESPONSIVE — TABLET (≤900px)
════════════════════════════════════════════════════ */
@media(max-width:900px){
  /* Layout */
  .layout{flex:1;min-height:0}
  /* Sidebar nav — hidden by default, slide in on toggle */
  .nav{
    width:0;border-right:none;overflow:hidden;
    position:fixed;top:52px;left:0;
    height:calc(100vh - 52px);z-index:300;
    transition:width .25s
  }
  .nav.mob-open{width:220px;border-right:1px solid #1e1e1c;overflow-y:auto}
  #mob-nav-btn{display:flex!important}

  /* ── Mobile layout ── */
  .layout{flex-direction:column;position:relative}

  /* Spec sidebar — เต็มจอโดย default */
  .sb{
    width:100%;border-right:none;
    border-bottom:1px solid var(--border);
    flex:1;max-height:none;
    transition:max-height .25s,flex .25s;
  }
  /* Main content — ซ่อนโดย default บน mobile */
  .main{flex:0;max-height:0;overflow:hidden;transition:all .25s}

  /* spec-open: ซ่อน sb แสดง main เต็มจอ */
  .layout.spec-open .sb{max-height:0;flex:0;overflow:hidden;border-bottom:none}
  .layout.spec-open .main{flex:1;max-height:none;overflow:auto}

  /* main-open: แสดง main เต็มจอ (สำหรับ projDash / All Projects) */
  .layout.main-open .sb{max-height:0;flex:0;overflow:hidden;border-bottom:none}
  .layout.main-open .main{flex:1;max-height:none;overflow:auto}

  /* ปุ่ม "← Specs" */
  #mob-back-btn{
    display:none;align-items:center;gap:6px;
    padding:8px 14px;background:var(--off);
    border-bottom:1px solid var(--border);
    font-size:11px;letter-spacing:.06em;color:var(--gray);
    cursor:pointer;flex-shrink:0;
  }
  .layout.spec-open #mob-back-btn{display:flex!important}
  /* ปุ่ม "← All Projects" ใน projDash บน mobile ไม่ต้องซ่อน */
  .layout.main-open #mob-back-btn{display:none!important}
  /* Panels */
  .panel{padding:16px 14px}
  .g4{grid-template-columns:repeat(2,1fr)}
  .g3{grid-template-columns:repeat(2,1fr)}
  .stats{grid-template-columns:repeat(2,1fr)}
  .module-bar{padding:6px 12px;gap:0}
  .mod-btn{padding:5px 12px;font-size:10px}
  .phead{flex-direction:column;gap:10px}
  .pactions{flex-wrap:wrap}
  /* Topbar — compact */
  .topbar{padding:0 8px;height:48px}
  .topbar-r{gap:3px;flex-wrap:nowrap}
  .brand-name{font-size:11px;letter-spacing:.04em}
  /* ซ่อน label ทุกปุ่มใน topbar — เหลือแค่ icon */
  .tb-label{display:none!important}
  .topbar-r .btn-gw,.topbar-r .btn-gold{padding:5px 8px!important}
  #adminMenuBtn{padding:4px 8px!important;gap:4px}
  #adminMenuBtn .admin-menu-name{display:none}
  #adminMenuDropdown{left:auto;right:0}
  /* DB status — ย่อ */
  .topbar-r [style*="DB Connected"] span:last-child{display:none}
  /* projDash — full width, no left gap */
  #projDash{left:0!important}
  /* Project Dashboard tabs — horizontal scroll */
  .pd-tabs-row{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap!important;scrollbar-width:none}
  .pd-tabs-row::-webkit-scrollbar{display:none}
  /* All Projects grid */
  .pd-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))!important;gap:12px!important}
  /* projDash content padding */
  #projDash > div:last-child{padding:16px!important}
}

/* ════════════════════════════════════════════════════
   RESPONSIVE — MOBILE (≤600px)
════════════════════════════════════════════════════ */
@media(max-width:600px){
  .topbar{height:48px;padding:0 8px}
  .brand-name{font-size:11px}
  .module-bar{padding:5px 8px}
  .mod-btn{padding:5px 10px;font-size:9px;letter-spacing:.05em}
  .mod-divider{margin:0 3px}
  .layout{flex:1;min-height:0}
  .nav{top:48px;height:calc(100vh - 48px)}
  .sb{max-height:none;flex:1}
  .layout.spec-open .sb{max-height:0;flex:0}
  .scard{padding:9px}
  .panel{padding:12px 10px}
  .g4,.g3,.g2{grid-template-columns:1fr 1fr;gap:8px}
  .stats{grid-template-columns:1fr 1fr;gap:8px}
  .pname{font-size:20px}
  .img-hero-main{min-height:160px;max-height:220px}
  .status-bar{flex-wrap:wrap;gap:4px;padding:8px 10px}
  .status-btn{font-size:9px;padding:4px 8px}
  .boq-wrap{overflow-x:auto}
  .btbl{min-width:560px}
  .u-name{display:none}
  .tabs{gap:0}
  .tab{padding:8px 10px;font-size:11px}
  .modal{width:95vw!important;max-height:90vh;overflow-y:auto}
  .overlay .modal{margin:0;border-radius:12px 12px 0 0;position:fixed;bottom:0;left:0;right:0;width:100%!important}
  .overlay{align-items:flex-end}
  /* Topbar compact — icon-only buttons */
  .topbar-r{gap:3px}
  #btnCatalog span, #btnGoHome .btn-label-home{display:none}
  #btnCatalog, #btnGoHome{padding:5px 7px}
  #adminMenuBtn{padding:4px 7px;font-size:10px}
  .admin-menu-name{display:none}
  /* Admin dropdown — fixed full width */
  #adminMenuDropdown{position:fixed;left:8px;right:8px;top:56px;width:auto;min-width:unset}
  /* All Projects grid — single column */
  .pd-grid{grid-template-columns:1fr!important}
  /* Phase tracker text */
  .stage-badge{font-size:8px;padding:1px 5px}
  /* Folders */
  .folder-add-item{flex-direction:column}
  .folder-add-item .fi-url,.folder-add-item .fi-name{min-width:unset;width:100%}
  /* Spec breadcrumb */
  #specBreadcrumb{padding:5px 10px}
  /* projDash header padding */
  #projDash > div:first-child{padding:10px 12px 0!important}
}

/* ─── INTERIOR ITEM COLORS ─── */
.int-badge{background:var(--int-dim);color:var(--int);border:1px solid rgba(107,79,160,.3);padding:2px 7px;border-radius:3px;font-size:10px;font-weight:600;letter-spacing:.04em}

/* ─── SIDEBAR FILTER BAR ─── */
.sb-filter{padding:8px 14px;border-bottom:1px solid var(--border);display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.sb-filter-label{font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--gray-l);white-space:nowrap}
.filter-btn{padding:3px 9px;border-radius:3px;font-size:10px;border:1px solid var(--border);background:transparent;color:var(--gray);cursor:pointer;font-family:'Montserrat',sans-serif;white-space:nowrap;transition:all .15s}
.filter-btn:hover{border-color:var(--gold-l);color:var(--gold)}
.filter-btn.active{background:var(--gold-dim);border-color:var(--gold);color:var(--gold)}
.filter-btn.active.int{background:var(--int-dim);border-color:var(--int);color:var(--int)}
.sort-wrap{display:flex;gap:4px;align-items:center;padding:6px 14px;border-bottom:1px solid var(--border)}
.sort-label{font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--gray-l)}
.sort-select{font-size:11px;padding:3px 7px;border:1px solid var(--border);border-radius:3px;background:var(--white);color:var(--ink);font-family:'Montserrat',sans-serif;cursor:pointer;outline:none;flex:1}
.sort-select:focus{border-color:var(--gold)}

/* ─── BOQ ACCESSORIES SUB-ROW ─── */
.brow-acc td{background:var(--off);color:var(--gray);font-size:11px;padding:5px 13px 5px 36px;border-bottom:1px solid var(--border-s)}
.brow-acc .acc-bullet{color:var(--gold);margin-right:5px;font-size:12px}
.brow-acc:hover td{background:var(--off2)!important}
.brow-acc td.acc-name-col{color:var(--gray-l)}

/* ─── AUTO SPEC IMPORT MODAL ─── */
.import-drop-zone{border:2px dashed var(--border);border-radius:var(--rl);padding:32px;text-align:center;cursor:pointer;transition:all .2s;background:var(--off)}
.import-drop-zone:hover,.import-drop-zone.drag-over{border-color:var(--gold);background:var(--gold-dim2)}
.import-drop-zone svg{width:32px;height:32px;stroke:var(--gray-l);fill:none;stroke-width:1.2;stroke-linecap:round;margin-bottom:10px}
.import-drop-zone h4{font-family:'Cormorant Garamond',serif;font-size:18px;font-weight:400;color:var(--gray);margin-bottom:4px}
.import-drop-zone p{font-size:11px;color:var(--gray-l);line-height:1.6}
.import-status{margin-top:14px;padding:12px;border-radius:var(--r);font-size:12px;display:none}
.import-status.loading{background:var(--gold-dim);border:1px solid rgba(184,149,90,.2);color:var(--gold);display:block}
.import-status.success{background:var(--green-bg);border:1px solid var(--green-border);color:var(--green);display:block}
.import-status.error{background:var(--red-bg);border:1px solid var(--red-border);color:var(--red);display:block}
.import-preview{margin-top:14px;border:1px solid var(--border);border-radius:var(--r);overflow:hidden;display:none}
.import-preview-head{background:var(--off2);padding:10px 14px;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--gray-l);border-bottom:1px solid var(--border)}
.import-preview-body{padding:14px;max-height:240px;overflow-y:auto}
.import-field-row{display:grid;grid-template-columns:140px 1fr;gap:8px;padding:5px 0;border-bottom:1px solid var(--border-s);font-size:12px}
.import-field-row:last-child{border-bottom:none}
.import-field-label{color:var(--gray-l);font-size:10px;letter-spacing:.06em;text-transform:uppercase;padding-top:1px}
.import-field-val{color:var(--ink);font-weight:500}
.import-spinner{display:inline-block;width:12px;height:12px;border:2px solid rgba(184,149,90,.3);border-top-color:var(--gold);border-radius:50%;animation:spin .7s linear infinite;margin-right:6px;vertical-align:middle}
@keyframes spin{to{transform:rotate(360deg)}}
.import-hint{font-size:10px;color:var(--gray-l);line-height:1.7;padding:10px 12px;background:var(--off);border-radius:var(--r);margin-top:10px}
.import-hint strong{color:var(--gray)}



/* ── TEAM SECTION ── */
.team-section{padding:100px 60px;background:var(--cream)}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;margin-top:48px}
.team-card{position:relative;overflow:hidden;cursor:default}
.team-img{aspect-ratio:3/4;overflow:hidden;background:var(--cream2)}
.team-img img{width:100%;height:100%;object-fit:cover;display:block;filter:sepia(15%) saturate(85%);transition:all .5s}
.team-card:hover .team-img img{filter:sepia(0%) saturate(100%);transform:scale(1.03)}
.team-info{padding:16px 0 0}
.team-name{font-family:'Cormorant Garamond',serif;font-size:18px;font-weight:400;color:var(--ink);letter-spacing:.02em}
.team-role{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:#6D4035;margin-top:4px}
.team-bio{font-size:12px;color:#3A1A1C;line-height:1.7;margin-top:8px;font-weight:300}
/* ── CAREERS SECTION ── */
.careers-section{padding:100px 60px;background:var(--cream2);border-top:1px solid var(--cream3)}
.careers-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;margin-top:48px}
.careers-intro{font-size:13px;color:#3A1A1C;line-height:1.9;font-weight:300;max-width:480px;margin-top:16px}
.job-list{display:flex;flex-direction:column;gap:0}
.job-item{padding:20px 0;border-bottom:1px solid var(--cream3);display:flex;align-items:flex-start;justify-content:space-between;gap:20px}
.job-item:first-child{border-top:1px solid var(--cream3)}
.job-left{flex:1}
.job-title{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:400;color:var(--ink);margin-bottom:4px}
.job-meta{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:#6D4035;margin-bottom:6px}
.job-desc{font-size:12px;color:#4A2820;line-height:1.7;font-weight:300}
.job-apply-btn{flex-shrink:0;font-size:9px;letter-spacing:.16em;text-transform:uppercase;padding:8px 18px;background:transparent;border:1px solid #6D4035;color:#6D4035;cursor:pointer;font-family:'Montserrat',sans-serif;transition:all .2s;white-space:nowrap;align-self:center}
.job-apply-btn:hover{background:#6D4035;color:#D6C7B8}
.career-form-wrap{background:var(--cream);padding:28px;border:1px solid var(--cream3)}
.career-form-title{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:400;color:var(--ink);margin-bottom:4px}
.career-form-sub{font-size:11px;color:#6D4035;letter-spacing:.06em;margin-bottom:20px}
.career-form{display:flex;flex-direction:column;gap:14px}
.career-field{display:flex;flex-direction:column;gap:6px}
.career-field label{font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:#6D4035}
.career-field input,.career-field select,.career-field textarea{background:var(--cream2);border:1px solid var(--cream3);padding:10px 12px;color:var(--ink);font-family:'Montserrat',sans-serif;font-size:13px;outline:none;transition:border-color .2s;font-weight:300;width:100%}
.career-field input:focus,.career-field select:focus,.career-field textarea:focus{border-color:#6D4035}
.career-submit{padding:11px 28px;background:#6D4035;color:#D6C7B8;border:none;font-family:'Montserrat',sans-serif;font-size:10px;letter-spacing:.18em;text-transform:uppercase;cursor:pointer;transition:background .2s;font-weight:400;align-self:flex-start}
.career-submit:hover{background:#8A5B59}
@media(max-width:960px){
  .team-grid{grid-template-columns:repeat(2,1fr);gap:24px}
  .team-section{padding:60px 24px}
  .careers-grid{grid-template-columns:1fr;gap:40px}
  .careers-section{padding:60px 24px}
}


/* ══ ADMIN PANEL OVERLAY ══ */
#adminOverlay{display:none;position:fixed;inset:0;z-index:600;background:rgba(30,10,12,.55);backdrop-filter:blur(4px);align-items:flex-start;justify-content:flex-end}
#adminOverlay.show{display:flex}
.admin-panel{width:min(700px,96vw);height:100vh;background:var(--cream);display:flex;flex-direction:column;overflow:hidden;box-shadow:-8px 0 40px rgba(30,10,12,.2)}
.admin-header{padding:24px 28px;border-bottom:1px solid var(--cream3);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;background:var(--cream)}
.admin-title{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:400;color:var(--ink);letter-spacing:.04em}
.admin-close{background:none;border:none;cursor:pointer;color:#8A5B59;font-size:20px;line-height:1;padding:4px 8px;transition:color .2s}
.admin-close:hover{color:var(--ink)}
.admin-tabs{display:flex;border-bottom:1px solid var(--cream3);flex-shrink:0;background:var(--cream)}
.admin-tab{flex:1;padding:13px 0;font-size:10px;letter-spacing:.16em;text-transform:uppercase;background:none;border:none;cursor:pointer;color:#8A5B59;font-family:'Montserrat',sans-serif;border-bottom:2px solid transparent;transition:all .2s;font-weight:400}
.admin-tab.active{color:#311418;border-bottom-color:#6D4035}
.admin-body{flex:1;overflow-y:auto;padding:0}
/* ── List view ── */
.admin-list{list-style:none}
.admin-item{display:flex;align-items:center;gap:12px;padding:14px 28px;border-bottom:1px solid var(--cream3);transition:background .15s}
.admin-item:hover{background:var(--cream2)}
.admin-item-img{width:48px;height:48px;object-fit:cover;flex-shrink:0;background:var(--cream2);display:block}
.admin-item-img.placeholder{display:flex;align-items:center;justify-content:center;font-size:18px;color:#C0A098}
.admin-item-info{flex:1;min-width:0}
.admin-item-name{font-size:14px;color:var(--ink);font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.admin-item-meta{font-size:11px;color:#8A5B59;margin-top:2px;letter-spacing:.04em}
.admin-item-actions{display:flex;gap:6px;flex-shrink:0}
.admin-btn-edit{padding:5px 14px;font-size:10px;letter-spacing:.12em;text-transform:uppercase;background:transparent;border:1px solid #6D4035;color:#6D4035;cursor:pointer;font-family:'Montserrat',sans-serif;transition:all .2s}
.admin-btn-edit:hover{background:#6D4035;color:#D6C7B8}
.admin-btn-del{padding:5px 10px;font-size:10px;background:transparent;border:1px solid #C0A098;color:#C0A098;cursor:pointer;font-family:'Montserrat',sans-serif;transition:all .2s}
.admin-btn-del:hover{background:#8A5B59;color:#fff;border-color:#8A5B59}
.admin-add-bar{padding:16px 28px;border-top:1px solid var(--cream3);background:var(--cream);flex-shrink:0}
.admin-add-btn{width:100%;padding:11px;background:#6D4035;color:#D6C7B8;border:none;font-family:'Montserrat',sans-serif;font-size:10px;letter-spacing:.2em;text-transform:uppercase;cursor:pointer;transition:background .2s}
.admin-add-btn:hover{background:#8A5B59}
/* ── Edit form ── */
.admin-form-wrap{padding:28px}
.admin-form-back{display:flex;align-items:center;gap:8px;background:none;border:none;cursor:pointer;color:#8A5B59;font-size:11px;letter-spacing:.1em;text-transform:uppercase;font-family:'Montserrat',sans-serif;margin-bottom:20px;padding:0;transition:color .2s}
.admin-form-back:hover{color:var(--ink)}
.admin-form-back svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round}
.admin-form-title{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:400;color:var(--ink);margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--cream3)}
.admin-field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.admin-field label{font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:#6D4035;font-weight:400}
.admin-field input,.admin-field select,.admin-field textarea{background:var(--cream2);border:1px solid var(--cream3);padding:10px 12px;color:var(--ink);font-family:'Montserrat',sans-serif;font-size:13px;outline:none;transition:border-color .2s;font-weight:300;width:100%}
.admin-field input:focus,.admin-field select:focus,.admin-field textarea:focus{border-color:#6D4035}
.admin-field select option{background:var(--cream);color:var(--ink)}
.admin-field textarea{resize:vertical;min-height:80px}
.admin-g2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.admin-save-btn{padding:11px 32px;background:#6D4035;color:#D6C7B8;border:none;font-family:'Montserrat',sans-serif;font-size:10px;letter-spacing:.18em;text-transform:uppercase;cursor:pointer;transition:background .2s;margin-top:8px}
.admin-save-btn:hover{background:#8A5B59}
.admin-img-preview{width:100%;height:160px;object-fit:cover;display:block;background:var(--cream2);margin-bottom:8px;border:1px solid var(--cream3)}
.admin-section-label{font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:#6D4035;margin:20px 0 12px;padding-top:16px;border-top:1px solid var(--cream3)}

/* ══════════════════════════════════════════════════
   PROJECT STAGE BADGES
══════════════════════════════════════════════════ */
.stage-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 7px;border-radius:3px;font-size:9px;letter-spacing:.1em;text-transform:uppercase;font-weight:500;white-space:nowrap}
.stage-badge::before{content:'';width:5px;height:5px;border-radius:50%;flex-shrink:0}
.stage-concept{background:rgba(59,130,246,.12);color:#2563eb;border:1px solid rgba(59,130,246,.25)}
.stage-concept::before{background:#3b82f6}
.stage-design{background:rgba(234,179,8,.12);color:#a16207;border:1px solid rgba(234,179,8,.3)}
.stage-design::before{background:#eab308}
.stage-construction{background:rgba(249,115,22,.12);color:#c2410c;border:1px solid rgba(249,115,22,.25)}
.stage-construction::before{background:#f97316}
.stage-finish{background:rgba(34,197,94,.12);color:#15803d;border:1px solid rgba(34,197,94,.25)}
.stage-finish::before{background:#22c55e}

.pitem-stage{margin-top:3px}

/* ══════════════════════════════════════════════════
   FOLDER PANEL
══════════════════════════════════════════════════ */
.folder-panel{background:var(--white);border:1px solid var(--border);border-radius:var(--rl);overflow:hidden}
.folder-panel-hd{padding:12px 14px;background:var(--off);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.folder-panel-title{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--gray);font-weight:500}
.folder-list{padding:10px}
.folder-row{border:1px solid var(--border-s);border-radius:var(--r);margin-bottom:8px;overflow:hidden}
.folder-row-hd{display:flex;align-items:center;gap:8px;padding:9px 12px;background:var(--off);cursor:pointer;user-select:none;transition:background .15s}
.folder-row-hd:hover{background:var(--off2)}
.folder-row-hd svg{flex-shrink:0;color:var(--gold)}
.folder-name{flex:1;font-size:12px;font-weight:500;color:var(--ink)}
.folder-cnt{font-size:10px;color:var(--gray-ll);background:var(--off2);padding:1px 6px;border-radius:10px}
.folder-row-body{display:none;padding:8px 10px;background:var(--white);border-top:1px solid var(--border-s)}
.folder-row-body.open{display:block}
.folder-item{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:var(--r);transition:background .15s;cursor:default}
.folder-item:hover{background:var(--off)}
.folder-item-icon{width:24px;height:24px;border-radius:3px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:10px;font-weight:700;letter-spacing:.02em}
.fi-canva{background:rgba(56,183,108,.15);color:#1a7a3a}
.fi-link{background:rgba(59,130,246,.12);color:#2563eb}
.fi-file{background:rgba(109,64,53,.1);color:var(--gold)}
.folder-item-info{flex:1;min-width:0}
.folder-item-name{font-size:12px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.folder-item-url{font-size:10px;color:var(--gray-l);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:240px}
.folder-item-del{padding:2px 6px;border:1px solid var(--border);background:transparent;border-radius:3px;font-size:10px;color:var(--gray-l);cursor:pointer;transition:all .15s;flex-shrink:0}
.folder-item-del:hover{background:#fdf0f0;border-color:#d8a8a8;color:#904040}
.folder-add-item{display:flex;gap:6px;margin-top:8px;padding-top:8px;border-top:1px solid var(--border-s);flex-wrap:wrap;align-items:flex-end}
.folder-add-item input,.folder-add-item select{background:var(--off);border:1px solid var(--border);border-radius:var(--r);padding:5px 8px;font-size:11px;color:var(--ink);font-family:'Montserrat',sans-serif;outline:none;transition:border-color .15s}
.folder-add-item input:focus,.folder-add-item select:focus{border-color:var(--gold)}
.folder-add-item .fi-name{flex:1;min-width:120px}
.folder-add-item .fi-url{flex:2;min-width:160px}
.folder-add-item .fi-type{width:80px}
.btn-add-folder-item{padding:5px 10px;background:var(--gold);color:#fff;border:none;border-radius:var(--r);font-size:10px;cursor:pointer;transition:background .15s;white-space:nowrap;font-family:'Montserrat',sans-serif;letter-spacing:.04em}
.btn-add-folder-item:hover{background:var(--gold-l)}
.folder-empty{font-size:11px;color:var(--gray-ll);text-align:center;padding:12px 0;font-style:italic}
.add-folder-row{display:flex;gap:6px;margin-top:8px}
.add-folder-row input{flex:1;background:var(--off);border:1px solid var(--border);border-radius:var(--r);padding:6px 10px;font-size:12px;color:var(--ink);font-family:'Montserrat',sans-serif;outline:none;transition:border-color .15s}
.add-folder-row input:focus{border-color:var(--gold)}
.btn-add-folder{padding:6px 12px;background:var(--gold);color:#fff;border:none;border-radius:var(--r);font-size:11px;cursor:pointer;transition:background .15s;white-space:nowrap;font-family:'Montserrat',sans-serif}
.btn-add-folder:hover{background:var(--gold-l)}
/* Folder drag-drop & PDF upload */
.folder-row-body.folder-drag-over{background:rgba(194,156,80,.07)!important;outline:2px dashed var(--gold);outline-offset:-2px}
.folder-upload-zone{display:flex;align-items:center;justify-content:center;gap:6px;border:1.5px dashed var(--border);border-radius:var(--r);padding:8px 12px;font-size:11px;color:var(--gray-l);cursor:pointer;transition:all .2s;margin-top:8px;letter-spacing:.02em}
.folder-upload-zone:hover,.folder-upload-zone.dragover{border-color:var(--gold);color:var(--gold);background:rgba(194,156,80,.05)}
.folder-upload-zone svg{flex-shrink:0;opacity:.7}
.doc-row[draggable=true]{cursor:grab}
.doc-row[draggable=true]:hover{background:var(--off2)}
.doc-row.dragging{opacity:.5;cursor:grabbing}
.btn-del-folder{padding:4px 8px;border:1px solid var(--border);background:transparent;border-radius:var(--r);font-size:10px;color:var(--gray-l);cursor:pointer;transition:all .15s}
.btn-del-folder:hover{background:#fdf0f0;border-color:#d8a8a8;color:#904040}

/* ══════════════════════════════════════════════════
   PROJECT DASHBOARD
══════════════════════════════════════════════════ */
/* ── Admin Dropdown ── */
.admin-menu-item{
  display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;
  background:none;border:none;color:rgba(255,255,255,.7);cursor:pointer;
  font-size:12px;font-family:'Montserrat',sans-serif;letter-spacing:.02em;
  border-radius:4px;text-align:left;transition:all .15s;
}
.admin-menu-item:hover{background:rgba(255,255,255,.08);color:#fff}
.admin-menu-item svg{flex-shrink:0;opacity:.7}
.admin-menu-item:hover svg{opacity:1}

#projDash{background:var(--white)}
#projDash .stage-badge{font-size:10px}
#pdSpecSB .pill{padding:1px 6px;font-size:9px;border-radius:2px;font-weight:500}
#pdSpecSB .pill-ok   {background:var(--green-bg);color:var(--green);border:1px solid var(--green-border)}
#pdSpecSB .pill-warn {background:var(--amber-bg);color:var(--amber);border:1px solid var(--amber-border)}
#pdSpecSB .pill-del  {background:var(--red-bg);color:var(--red);border:1px solid var(--red-border)}
#pdSpecSB .pill-gray {background:var(--off2);color:var(--gray-l);border:1px solid var(--border)}
.stage-design-development{background:rgba(234,179,8,.12);color:#a16207;border:1px solid rgba(234,179,8,.3)}
.stage-design-development::before{background:#eab308}

