/* JS&Co Internal ERP — Stylesheet */

:root {
  --ink:#0f0e0c; --paper:#faf8f4; --cream:#f2ede3; --gold:#b8882a;
  --gold-light:#e8c96a; --rust:#8b3a2a; --sage:#3d5a47; --muted:#8a8070;
  --border:#ddd8cc; --white:#ffffff;
  --shadow:0 4px 24px rgba(15,14,12,0.08); --shadow-lg:0 12px 48px rgba(15,14,12,0.16);
}
*{margin:0;padding:0;box-sizing:border-box;}
body{font-family:'DM Sans',sans-serif;background:var(--paper);color:var(--ink);min-height:100vh;}

/* SIDEBAR */
.sidebar{position:fixed;left:0;top:0;bottom:0;width:232px;background:var(--ink);display:flex;flex-direction:column;z-index:100;overflow:hidden;}
.sidebar-logo{padding:26px 22px 18px;border-bottom:1px solid rgba(255,255,255,0.07);}
.firm{font-family:'Playfair Display',serif;font-size:17px;font-weight:700;color:var(--gold-light);}
.sidebar-nav{flex:1;overflow-y:auto;padding-bottom:4px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,0.25) rgba(255,255,255,0.05);}
.sidebar-nav::-webkit-scrollbar{width:4px;}
.sidebar-nav::-webkit-scrollbar-track{background:rgba(255,255,255,0.05);}
.sidebar-nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.25);border-radius:2px;}
.sidebar-nav::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,0.4);}
.tagline{font-size:9.5px;color:rgba(255,255,255,0.3);letter-spacing:1.8px;text-transform:uppercase;margin-top:3px;}
.nav-section{padding:14px 10px 6px;}
.nav-label{font-size:9px;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,0.22);padding:0 10px;margin-bottom:5px;}
.nav-item{display:flex;align-items:center;gap:9px;padding:9px 10px;border-radius:8px;cursor:pointer;color:rgba(255,255,255,0.5);font-size:13px;font-weight:400;transition:all 0.18s;margin-bottom:1px;}
.nav-item:hover{background:rgba(255,255,255,0.06);color:rgba(255,255,255,0.8);}
.nav-item.active{background:rgba(184,136,42,0.17);color:var(--gold-light);}
.nav-item .ico{font-size:15px;width:18px;text-align:center;}
.nav-badge{margin-left:auto;background:var(--gold);color:var(--ink);font-size:9.5px;font-weight:700;border-radius:10px;padding:1px 7px;}
.nav-soon{margin-left:auto;font-size:8.5px;letter-spacing:1px;background:rgba(255,255,255,0.05);color:rgba(255,255,255,0.22);padding:2px 6px;border-radius:4px;text-transform:uppercase;}
.sidebar-footer{flex-shrink:0;padding:14px;border-top:1px solid rgba(255,255,255,0.05);font-size:10.5px;color:rgba(255,255,255,0.18);text-align:center;}
.sidebar-footer .site-link{display:inline-block;color:var(--gold-light);font-size:12.5px;font-weight:500;text-decoration:none;letter-spacing:0.4px;animation:sitePulse 2.8s ease-in-out infinite;}
@keyframes sitePulse{0%,100%{opacity:0.6;text-shadow:none;}50%{opacity:1;text-shadow:0 0 10px rgba(232,201,106,0.7),0 0 20px rgba(232,201,106,0.3);}}

/* MAIN */
.main{margin-left:232px;min-height:100vh;}
.topbar{background:var(--white);border-bottom:1px solid var(--border);padding:0 28px;height:58px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50;}
.topbar-title{font-family:'Playfair Display',serif;font-size:18px;font-weight:600;}
.content{padding:28px;}

/* BUTTONS */
.btn{padding:8px 17px;border-radius:8px;border:none;cursor:pointer;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:500;transition:all 0.18s;display:inline-flex;align-items:center;gap:6px;}
.btn-primary{background:var(--ink);color:var(--white);}
.btn-primary:hover{background:#2a2820;}
.btn-gold{background:var(--gold);color:var(--white);}
.btn-gold:hover{background:#a07520;}
.btn-outline{background:transparent;color:var(--ink);border:1.5px solid var(--border);}
.btn-outline:hover{border-color:var(--ink);background:var(--cream);}
.btn-danger{background:#c0392b;color:#fff;}
.btn-danger:hover{background:#a93226;}
.btn-sm{padding:6px 12px;font-size:12px;}
.btn-green{background:var(--sage);color:#fff;}
.btn-green:hover{background:#2d4434;}
.btn-icon{padding:6px 10px;background:var(--cream);border:1px solid var(--border);color:var(--muted);border-radius:7px;cursor:pointer;font-size:14px;transition:all 0.15s;}
.btn-icon:hover{background:var(--border);color:var(--rust);}

/* CARDS */
.card{background:var(--white);border-radius:14px;border:1px solid var(--border);padding:24px;box-shadow:var(--shadow);}
.card-title{font-family:'Playfair Display',serif;font-size:16px;font-weight:600;margin-bottom:5px;}
.card-sub{font-size:12.5px;color:var(--muted);margin-bottom:20px;}

/* TABS */
.tabs{display:flex;gap:2px;background:var(--cream);border-radius:10px;padding:4px;margin-bottom:24px;width:fit-content;}
.tab{padding:7px 18px;border-radius:7px;cursor:pointer;font-size:13px;font-weight:500;color:var(--muted);transition:all 0.18s;white-space:nowrap;}
.tab.active{background:var(--white);color:var(--ink);box-shadow:var(--shadow);}

/* STATS */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px;}
.stat-card{background:var(--white);border:1px solid var(--border);border-radius:12px;padding:16px 18px;}
.stat-val{font-family:'Playfair Display',serif;font-size:26px;font-weight:700;color:var(--ink);line-height:1;}
.stat-label{font-size:11.5px;color:var(--muted);margin-top:3px;}

/* SECTION DIVIDER */
.sec-div{display:flex;align-items:center;gap:10px;margin:22px 0 16px;}
.sec-div span{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);white-space:nowrap;font-weight:500;}
.sec-div::before,.sec-div::after{content:'';flex:1;height:1px;background:var(--border);}

/* FORM */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.fg{display:flex;flex-direction:column;gap:5px;}
.fg.full{grid-column:1/-1;}
.fg.w3{grid-column:span 1;}
.fg label{font-size:11px;font-weight:500;color:var(--muted);letter-spacing:0.4px;text-transform:uppercase;}
.fg input,.fg select,.fg textarea{padding:9px 13px;border-radius:8px;border:1.5px solid var(--border);font-family:'DM Sans',sans-serif;font-size:13.5px;color:var(--ink);background:var(--paper);transition:border-color 0.18s;outline:none;}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--gold);background:var(--white);}
.fg textarea{resize:vertical;min-height:72px;}

/* PARTNER CARD */
.partner-card{background:var(--paper);border:1.5px solid var(--border);border-radius:12px;padding:18px 20px;margin-bottom:14px;position:relative;}
.partner-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;}
.partner-num{font-family:'Playfair Display',serif;font-size:14px;font-weight:600;color:var(--gold);display:flex;align-items:center;gap:7px;}
.partner-num .ordinal{font-size:11px;font-weight:400;color:var(--muted);font-family:'DM Sans',sans-serif;}

/* CLAUSE CARD */
.clause-card{background:var(--paper);border:1.5px solid var(--border);border-radius:10px;padding:14px 16px;margin-bottom:10px;display:flex;gap:12px;align-items:flex-start;}
.clause-num-badge{min-width:28px;height:28px;border-radius:50%;background:var(--gold);color:var(--white);font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;margin-top:2px;flex-shrink:0;}
.clause-locked{opacity:0.55;}
.clause-locked .clause-num-badge{background:var(--border);color:var(--muted);}
.clause-text{flex:1;font-size:13px;color:var(--ink);line-height:1.6;}
.clause-text.muted{color:var(--muted);font-style:italic;}
.clause-actions{display:flex;gap:6px;flex-shrink:0;}

/* no highlight classes needed */

/* FILENAME */
.filename-preview{background:var(--cream);border:1px solid var(--border);border-radius:8px;padding:9px 14px;font-family:'DM Mono',monospace;font-size:12px;color:var(--sage);display:flex;align-items:center;gap:8px;}

/* ACTION ROW */
.action-row{display:flex;gap:10px;align-items:center;margin-top:24px;flex-wrap:wrap;}

/* SAVED DOCS */
.search-bar{display:flex;gap:10px;margin-bottom:18px;}
.search-bar input{flex:1;padding:9px 14px;border-radius:8px;border:1.5px solid var(--border);font-family:'DM Sans',sans-serif;font-size:13.5px;background:var(--white);color:var(--ink);outline:none;transition:border-color 0.18s;}
.search-bar input:focus{border-color:var(--gold);}
.search-bar select{padding:9px 12px;border-radius:8px;border:1.5px solid var(--border);font-family:'DM Sans',sans-serif;font-size:13px;background:var(--white);color:var(--ink);outline:none;cursor:pointer;}
.docs-table{width:100%;border-collapse:collapse;}
.docs-table th{text-align:left;padding:9px 13px;font-size:10.5px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);border-bottom:1.5px solid var(--border);font-weight:500;}
.docs-table td{padding:12px 13px;border-bottom:1px solid var(--border);font-size:13px;vertical-align:middle;}
.docs-table tr:last-child td{border-bottom:none;}
.docs-table tr:hover td{background:var(--paper);}
.doc-type-badge{display:inline-block;padding:3px 9px;border-radius:20px;font-size:10.5px;font-weight:500;}
.badge-partnership{background:#e8f0e9;color:var(--sage);}
.badge-llp{background:#fdf3e3;color:var(--gold);}
.badge-engagement{background:#f0e8e8;color:var(--rust);}

/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(15,14,12,0.65);z-index:200;display:flex;align-items:center;justify-content:center;padding:20px;}
.modal{background:var(--white);border-radius:16px;width:100%;max-width:820px;max-height:92vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);}
.modal-header{padding:18px 24px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;}
.modal-header h3{font-family:'Playfair Display',serif;font-size:17px;}
.modal-close{width:30px;height:30px;border-radius:7px;border:none;background:var(--cream);cursor:pointer;font-size:15px;display:flex;align-items:center;justify-content:center;color:var(--muted);}
.modal-close:hover{background:var(--border);color:var(--ink);}
.modal-body{padding:24px;overflow-y:auto;flex:1;}
.modal-footer{padding:14px 24px;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap;}

/* DEED PREVIEW */
.deed-preview{font-family:'DM Sans',sans-serif;line-height:1.85;font-size:13px;color:#111;}
.deed-preview .dt{font-family:'Playfair Display',serif;font-size:21px;font-weight:700;text-align:center;text-transform:uppercase;letter-spacing:2.5px;text-decoration:underline;margin-bottom:20px;}
.deed-preview p{margin-bottom:12px;text-align:justify;}
.deed-preview .bold{font-weight:700;}
.deed-preview .clause{margin-bottom:11px;text-align:justify;}
.deed-preview .party-line{margin-bottom:10px;text-align:justify;}
.deed-preview .sig-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;margin-top:36px;}
.deed-preview .sig-col{border-top:1px solid #ccc;padding-top:8px;}
.deed-preview .sig-name{font-weight:600;font-size:13px;}
.deed-preview .sig-role{font-size:11.5px;color:var(--muted);}
.deed-preview .wit-section{margin-top:32px;}
.deed-preview table{width:100%;border-collapse:collapse;margin:12px 0;}
.deed-preview table td,.deed-preview table th{border:1px solid #aaa;padding:7px 10px;font-size:12.5px;text-align:left;}
.deed-preview table th{background:#f5f0e8;font-weight:600;}

/* MULTI-SELECT PARTNER CHIPS */
.pms-wrap{position:relative;}
.partner-multiselect{border:1.5px solid var(--border);border-radius:8px;background:var(--paper);min-height:44px;padding:5px 10px;display:flex;flex-wrap:wrap;gap:5px;align-items:center;cursor:pointer;transition:border-color 0.18s;}
.partner-multiselect.open,.partner-multiselect:focus-within{border-color:var(--gold);background:var(--white);}
.pchip{display:inline-flex;align-items:center;gap:4px;background:var(--gold);color:#fff;border-radius:20px;padding:3px 10px 3px 10px;font-size:12px;font-weight:500;white-space:nowrap;}
.pchip .px{cursor:pointer;font-size:14px;line-height:1;margin-left:2px;opacity:0.85;}
.pchip .px:hover{opacity:1;}
.pms-placeholder{font-size:13.5px;color:#aaa;}
.pms-dropdown{position:absolute;left:0;right:0;top:calc(100% + 4px);z-index:400;background:var(--white);border:1.5px solid var(--gold);border-radius:10px;box-shadow:var(--shadow-lg);padding:4px 0;display:none;}
.pms-dropdown.open{display:block;}
.pms-mobile-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.3);z-index:999;}
.pms-mobile-backdrop.open{display:block;}
.pms-option{padding:9px 14px;font-size:13.5px;cursor:pointer;display:flex;align-items:center;gap:9px;transition:background 0.12s;}
.pms-option:hover{background:var(--cream);}
.pms-option.selected{background:#fdf3e3;color:var(--gold);}
.pms-option input[type=checkbox]{accent-color:var(--gold);width:14px;height:14px;cursor:pointer;flex-shrink:0;}

/* COMING SOON */
.coming-soon{background:linear-gradient(135deg,var(--ink) 0%,#2a2820 100%);border-radius:14px;padding:40px;text-align:center;color:var(--white);}
.coming-soon .cs-icon{font-size:38px;margin-bottom:12px;}
.coming-soon h3{font-family:'Playfair Display',serif;font-size:21px;color:var(--gold-light);margin-bottom:8px;}
.coming-soon p{color:rgba(255,255,255,0.45);font-size:13.5px;max-width:380px;margin:0 auto;}
.module-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:22px;}
.module-pill{background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.09);border-radius:8px;padding:9px 12px;font-size:12.5px;color:rgba(255,255,255,0.55);display:flex;align-items:center;gap:7px;}

.empty-state{text-align:center;padding:44px 24px;color:var(--muted);}
.empty-state .esi{font-size:38px;margin-bottom:10px;opacity:0.35;}

.toast{position:fixed;bottom:22px;right:22px;background:var(--ink);color:var(--white);padding:11px 18px;border-radius:10px;font-size:13px;font-weight:500;box-shadow:var(--shadow-lg);z-index:9999;display:flex;align-items:center;gap:9px;animation:slideUp 0.25s ease;}
@keyframes slideUp{from{transform:translateY(16px);opacity:0;}to{transform:translateY(0);opacity:1;}}

.page{display:none;}
.page.active{display:block;}
.hidden{display:none!important;}
.add-partner-btn{border:2px dashed var(--border);border-radius:12px;padding:14px;text-align:center;cursor:pointer;color:var(--muted);font-size:13.5px;transition:all 0.18s;margin-bottom:14px;}
.add-partner-btn:hover{border-color:var(--gold);color:var(--gold);background:rgba(184,136,42,0.04);}

.spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,0.3);border-top-color:#fff;border-radius:50%;animation:spin 0.7s linear infinite;margin-right:6px;}
@keyframes spin{to{transform:rotate(360deg);}}
.progress-bar{height:4px;background:var(--cream);border-radius:2px;margin-top:8px;overflow:hidden;}
.progress-fill{height:100%;background:var(--gold);border-radius:2px;width:0;transition:width 0.3s;}

/* ═══ MOBILE RESPONSIVE ═══════════════════════════════════════════ */
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;background:none;border:none;z-index:200;}
.hamburger span{display:block;width:22px;height:2px;background:var(--ink);border-radius:2px;transition:all 0.25s;}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.45);z-index:98;}
.sidebar-overlay.open{display:block;}

@media (max-width: 768px) {
  .sidebar{transform:translateX(-100%);transition:transform 0.28s cubic-bezier(.4,0,.2,1);z-index:99;width:260px;}
  .sidebar.open{transform:translateX(0);}
  .main{margin-left:0;}
  .topbar{padding:0 14px 0 10px;}
  .hamburger{display:flex;}
  .content{padding:14px 12px;}
  .stats-row{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px;}
  .form-grid{grid-template-columns:1fr;}
  .fg.full{grid-column:1;}
  .fg.w3{grid-column:1;}
  .tabs{width:100%;}
  .tab{flex:1;text-align:center;padding:7px 10px;font-size:12px;}
  .partner-card{padding:14px;}
  .action-row{flex-direction:column;align-items:stretch;}
  .action-row .btn{width:100%;justify-content:center;}
  .modal{max-height:96vh;margin:8px;border-radius:12px;width:calc(100% - 16px);}
  .modal-footer{flex-wrap:wrap;gap:6px;}
  .modal-footer .btn{flex:1 1 calc(50% - 6px);justify-content:center;font-size:12px;}
  .docs-table{font-size:12px;}
  .docs-table th,.docs-table td{padding:8px 6px;}
  .search-bar{flex-direction:column;}
  .search-bar select{width:100%;}
  .stat-card{padding:12px 14px;}
  .stat-val{font-size:22px;}
  .partner-card .form-grid{grid-template-columns:1fr;}
  .pms-dropdown{position:fixed !important;left:10px !important;right:10px !important;top:auto !important;bottom:0 !important;width:auto !important;border-radius:16px 16px 0 0 !important;max-height:60vh;overflow-y:auto;padding-bottom:16px;z-index:1000 !important;}
  .pms-wrap{position:static;}
  .partner-multiselect.open{border-color:var(--gold);}
  .filename-preview{font-size:11px;word-break:break-all;}
  .clause-card{flex-wrap:wrap;}
  .topbar-title{font-size:15px;}
  /* Engagement services grid */
  div[style*="grid-template-columns:1fr 1fr"][style*="gap:8px"]{grid-template-columns:1fr !important;}
}

@media (max-width: 420px) {
  .stats-row{grid-template-columns:1fr 1fr;}
  .modal-footer .btn{flex:1 1 100%;}
  .tab{font-size:11px;padding:6px 6px;}
}
/* ═══════════════════════════════════════════════════
   INVOICE MODULE
═══════════════════════════════════════════════════ */

/* Invoice number row */
.inv-num-row {
  display: flex;
  gap: 12px;
  align-items: flex-end;
  margin-bottom: 12px;
  flex-wrap: wrap;
}
.inv-num-row .fg { min-width: 160px; }

/* Toggle switches */
.inv-toggles-row {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  padding: 10px 14px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 8px;
  margin-bottom: 4px;
}
.inv-toggle-label {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--ink);
  cursor: pointer;
  font-weight: 500;
  text-transform: none;
  letter-spacing: 0;
}
.inv-toggle-wrap {
  position: relative;
  width: 36px;
  height: 20px;
  flex-shrink: 0;
}
.inv-toggle-wrap input { opacity: 0; width: 0; height: 0; position: absolute; }
.inv-toggle-slider {
  position: absolute;
  inset: 0;
  background: #ccc;
  border-radius: 20px;
  cursor: pointer;
  transition: background 0.25s;
}
.inv-toggle-slider:before {
  content: '';
  position: absolute;
  width: 14px; height: 14px;
  left: 3px; top: 3px;
  background: #fff;
  border-radius: 50%;
  transition: transform 0.25s;
}
.inv-toggle-wrap input:checked + .inv-toggle-slider { background: var(--gold); }
.inv-toggle-wrap input:checked + .inv-toggle-slider:before { transform: translateX(16px); }

/* Radio */
.inv-radio {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 13px;
  color: var(--ink);
  cursor: pointer;
  font-weight: 400;
  text-transform: none;
  letter-spacing: 0;
}

/* Service line card */
.inv-line-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 12px 16px;
  margin-bottom: 8px;
  position: relative;
}
.inv-line-grid {
  display: grid;
  grid-template-columns: 2fr 90px 110px 120px 44px;
  gap: 10px;
  align-items: end;
}
.inv-line-grid.with-sac {
  grid-template-columns: 2fr 80px 90px 110px 120px 44px;
  gap: 10px;
}
.inv-line-label {
  font-size: 11px;
  color: var(--muted);
  margin-bottom: 3px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.inv-line-del {
  background: #fee2e2;
  color: #dc2626;
  border: none;
  border-radius: 6px;
  width: 36px;
  height: 36px;
  min-width: 36px;
  cursor: pointer;
  font-size: 15px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.inv-line-del:hover { background: #fecaca; }

/* Service dropdown */
.inv-service-select {
  width: 100%;
  padding: 7px 10px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--bg);
  color: var(--ink);
  font-size: 13px;
  font-family: inherit;
}

/* Totals box */
.inv-totals-box {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 12px 16px;
  margin-top: 12px;
  max-width: 420px;
  margin-left: auto;
}
.inv-total-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding: 4px 0;
  font-size: 13px;
  color: var(--ink);
  border-bottom: 1px solid var(--border);
  gap: 12px;
}
.inv-total-row:last-child { border-bottom: none; }
.inv-grand {
  font-size: 15px !important;
  font-weight: 700;
  color: var(--gold) !important;
  padding-top: 8px !important;
  margin-top: 4px;
}

/* Saved invoices */
.inv-saved-stats {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 12px;
}
.inv-stat-pill {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 4px 14px;
  font-size: 12.5px;
  color: var(--ink);
  font-weight: 500;
}
.inv-stat-pill span { color: var(--gold); font-weight: 700; }

/* Invoice card in saved list */
.inv-saved-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 12px 16px;
  margin-bottom: 10px;
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}
.inv-saved-num {
  font-size: 14px;
  font-weight: 700;
  color: var(--gold);
  min-width: 130px;
}
.inv-saved-client {
  font-size: 13px;
  font-weight: 600;
  color: var(--ink);
  flex: 1;
  min-width: 140px;
}
.inv-saved-meta {
  font-size: 11.5px;
  color: var(--muted);
}
.inv-saved-amount {
  font-size: 14px;
  font-weight: 700;
  color: var(--ink);
  min-width: 90px;
  text-align: right;
}
.inv-saved-actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

/* Invoice print/preview styles */
.inv-print-wrap {
  font-family: 'DM Sans', sans-serif;
  font-size: 12pt;
  color: #111;
  line-height: 1.6;
  max-width: 780px;
  margin: 0 auto;
}
.inv-print-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  border-bottom: 2px solid #b8882a;
  padding-bottom: 12px;
  margin-bottom: 14px;
  gap: 16px;
}
.inv-print-firm-name {
  font-family: 'Playfair Display', serif;
  font-size: 20pt;
  font-weight: 700;
  color: #b8882a;
  letter-spacing: 1px;
}
.inv-print-title {
  font-size: 18pt;
  font-weight: 700;
  color: #b8882a;
  text-align: right;
  letter-spacing: 2px;
  text-transform: uppercase;
}
.inv-print-meta { font-size: 11pt; color: #444; margin-top: 2px; }
.inv-print-parties {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin: 14px 0;
}
.inv-print-party-box {
  background: #faf8f4;
  border: 1px solid #ddd;
  border-radius: 6px;
  padding: 10px 14px;
}
.inv-print-party-label {
  font-size: 9pt;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: #b8882a;
  margin-bottom: 4px;
}
.inv-print-party-name { font-size: 12pt; font-weight: 700; }
.inv-print-party-meta { font-size: 10.5pt; color: #444; margin-top: 2px; }
table.inv-items {
  width: 100%;
  border-collapse: collapse;
  margin: 14px 0;
  font-size: 11pt;
}
table.inv-items th {
  background: #b8882a;
  color: #fff;
  padding: 7px 10px;
  text-align: left;
  font-weight: 600;
  font-size: 10pt;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
table.inv-items td {
  padding: 7px 10px;
  border-bottom: 1px solid #eee;
  vertical-align: top;
}
table.inv-items tr:nth-child(even) td { background: #faf8f4; }
.inv-print-totals {
  margin-left: auto;
  width: 280px;
  margin-top: 8px;
}
.inv-print-total-row {
  display: flex;
  justify-content: space-between;
  padding: 4px 0;
  font-size: 11pt;
  border-bottom: 1px solid #eee;
}
.inv-print-grand {
  font-size: 13pt;
  font-weight: 700;
  color: #b8882a;
  border-top: 2px solid #b8882a;
  border-bottom: 2px solid #b8882a;
  padding: 6px 0;
}
.inv-print-words {
  font-size: 10pt;
  color: #555;
  font-style: italic;
  text-align: right;
  margin-top: 4px;
}
.inv-print-footer {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-top: 20px;
  padding-top: 14px;
  border-top: 1px solid #ddd;
}
.inv-print-bank-box {
  background: #faf8f4;
  border: 1px solid #ddd;
  border-radius: 6px;
  padding: 10px 14px;
}
.inv-print-sig-box {
  text-align: right;
}
.inv-print-terms {
  font-size: 9.5pt;
  color: #666;
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px dashed #ddd;
}
.inv-print-computer-gen {
  text-align: center;
  font-size: 9pt;
  color: #999;
  margin-top: 14px;
  font-style: italic;
}

/* Mobile responsive */
@media (max-width: 768px) {
  .inv-num-row { flex-direction: column; }
  .inv-num-row .fg { min-width: unset; width: 100%; }
  .inv-line-grid,
  .inv-line-grid.with-sac { grid-template-columns: 1fr 1fr; }
  .inv-totals-box { max-width: 100%; }
  .inv-print-parties { grid-template-columns: 1fr; }
  .inv-print-footer { grid-template-columns: 1fr; }
  .inv-print-totals { width: 100%; }
  .inv-saved-card { flex-direction: column; align-items: flex-start; }
  .inv-saved-amount { text-align: left; }
  .inv-saved-actions { width: 100%; display: grid; grid-template-columns: 1fr 1fr; }
}

/* ═══════════════════════════════════════════════════
   BACKUP BUTTON (sidebar)
═══════════════════════════════════════════════════ */
.backup-btn {
  width: 100%;
  background: rgba(184,136,42,0.1);
  border: 1px solid rgba(184,136,42,0.25);
  color: var(--gold-light);
  border-radius: 8px;
  padding: 7px 10px;
  font-family: 'DM Sans', sans-serif;
  font-size: 11.5px;
  font-weight: 500;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 7px;
  transition: all 0.18s;
}
.backup-btn:hover {
  background: rgba(184,136,42,0.2);
  border-color: rgba(184,136,42,0.5);
}

/* ═══════════════════════════════════════════════════
   IMPORT DROP ZONE
═══════════════════════════════════════════════════ */
.import-drop-zone {
  border: 2px dashed var(--border);
  border-radius: 10px;
  padding: 20px;
  text-align: center;
  cursor: pointer;
  transition: all 0.18s;
  background: var(--paper);
  min-height: 80px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.import-drop-zone:hover, .import-drop-zone.drag-over {
  border-color: var(--gold);
  background: rgba(184,136,42,0.04);
}

/* ═══════════════════════════════════════════════════
   BOARD MEETING PACK
═══════════════════════════════════════════════════ */

/* Stepper */
.bp-stepper {
  display: flex;
  align-items: center;
  margin-bottom: 6px;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 14px 20px;
}
.bp-step {
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 1;
}
.bp-step-num {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 600;
  flex-shrink: 0;
  transition: all 0.2s;
}
.bp-step.done .bp-step-num { background: var(--sage); color: #fff; }
.bp-step.active .bp-step-num { background: var(--gold); color: #fff; }
.bp-step.todo .bp-step-num { background: var(--cream); color: var(--muted); border: 1.5px solid var(--border); }
.bp-step-label { font-size: 12px; font-weight: 500; color: var(--muted); }
.bp-step.done .bp-step-label, .bp-step.active .bp-step-label { color: var(--ink); }
.bp-step-line { flex: 1; height: 1px; background: var(--border); margin: 0 6px; }
.bp-step-line.done { background: var(--sage); }

/* Print mode options */
.print-mode-opt {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  cursor: pointer;
  flex: 1;
  min-width: 160px;
  padding: 10px 12px;
  border-radius: 8px;
  border: 1.5px solid var(--border);
  background: var(--white);
  transition: all 0.18s;
}
.print-mode-opt:hover { border-color: var(--gold); background: rgba(184,136,42,0.03); }
.print-mode-opt.active { border-color: var(--gold); background: rgba(184,136,42,0.06); }

/* Logo upload button */
.logo-upload-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 16px;
  background: var(--ink);
  color: var(--white);
  border-radius: 8px;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.18s;
}
.logo-upload-btn:hover { background: #2a2820; }

/* Resolution grid */
.res-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-bottom: 8px;
}
.res-pill {
  background: var(--paper);
  border: 1.5px solid var(--border);
  border-radius: 8px;
  padding: 9px 12px;
  font-size: 12.5px;
  color: var(--ink);
  display: flex;
  align-items: flex-start;
  gap: 8px;
  cursor: pointer;
  transition: all 0.15s;
  line-height: 1.4;
}
.res-pill:hover { border-color: var(--gold); background: rgba(184,136,42,0.03); }
.res-pill.selected { background: #fdf3e3; border-color: var(--gold); color: var(--ink); }
.res-chk {
  min-width: 18px;
  height: 18px;
  border-radius: 4px;
  border: 1.5px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  color: var(--white);
  flex-shrink: 0;
  margin-top: 1px;
  transition: all 0.15s;
}
.res-pill.selected .res-chk { background: var(--gold); border-color: var(--gold); }

/* Pack preview */
.bp-pack-preview {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin-bottom: 8px;
}
.bp-pack-item {
  background: var(--paper);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 9px 11px;
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12.5px;
  font-weight: 500;
}
.bp-pack-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--gold);
  flex-shrink: 0;
}

/* Generated doc cards */
.bp-doc-card {
  background: var(--paper);
  border: 1.5px solid var(--border);
  border-radius: 12px;
  padding: 14px 16px;
  margin-bottom: 10px;
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
  transition: border-color 0.15s;
}
.bp-doc-card:hover { border-color: var(--gold); }
.bp-doc-card-icon { font-size: 24px; flex-shrink: 0; }
.bp-doc-card-info { flex: 1; min-width: 160px; }
.bp-doc-card-title { font-size: 14px; font-weight: 600; margin-bottom: 2px; }
.bp-doc-card-sub { font-size: 12px; color: var(--muted); }
.bp-doc-card-actions { display: flex; gap: 6px; flex-wrap: wrap; }

/* Document preview styles */
.bp-doc-wrap {
  font-family: 'DM Sans', sans-serif;
  font-size: 13px;
  color: #111;
  line-height: 1.85;
}
.lh-header {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  border-bottom: 2px solid #1a3a5c;
  padding-bottom: 12px;
  margin-bottom: 18px;
}
.lh-logo-wrap { flex-shrink: 0; }
.lh-logo-wrap img { max-height: 70px; max-width: 150px; object-fit: contain; }
.lh-company-info { flex: 1; }
.lh-company-name {
  font-family: 'Playfair Display', serif;
  font-size: 19px;
  font-weight: 700;
  color: #1a3a5c;
  margin-bottom: 2px;
}
.lh-tagline { font-size: 11px; color: #666; margin-bottom: 2px; }
.lh-address { font-size: 11px; color: #444; }
.lh-contacts { font-size: 10.5px; color: #666; margin-top: 2px; }
.lh-cin { font-size: 10px; color: #888; margin-top: 2px; }
.lh-divider { height: 1px; background: #ddd; margin: 8px 0 14px; }
.lh-footer {
  text-align: center;
  font-size: 10.5px;
  color: #888;
  border-top: 1px solid #ddd;
  padding-top: 8px;
  margin-top: 20px;
}
.bp-doc-body p { margin-bottom: 10px; }
.bp-info-table { width: 100%; border-collapse: collapse; margin-bottom: 14px; }
.bp-info-table td { padding: 6px 10px; border: 0.5px solid #ccc; font-size: 12.5px; }
.bp-table { width: 100%; border-collapse: collapse; font-size: 11.5px; }
.bp-table th { background: #f5f0e8; font-weight: 600; padding: 6px 9px; border: 0.5px solid #aaa; text-align: left; }
.bp-table td { padding: 6px 9px; border: 0.5px solid #ddd; }
.bp-resolution-box {
  border-left: 3px solid var(--gold);
  padding: 10px 14px;
  margin: 10px 0;
  background: #fffdf8;
  border-radius: 0 6px 6px 0;
}
.bp-sig-col { display: inline-block; min-width: 160px; margin-right: 20px; vertical-align: top; }
.bp-agenda-ol { margin-left: 20px; padding-left: 0; }
.bp-agenda-ol li { margin-bottom: 6px; }

/* Mobile responsive for board pack */
@media (max-width: 768px) {
  .bp-stepper { padding: 10px 12px; }
  .bp-step-label { display: none; }
  .bp-step.active .bp-step-label { display: block; font-size: 11px; }
  .res-grid { grid-template-columns: 1fr; }
  .bp-pack-preview { grid-template-columns: 1fr 1fr; }
  .bp-doc-card { flex-direction: column; align-items: flex-start; }
  .bp-doc-card-actions { width: 100%; display: grid; grid-template-columns: 1fr 1fr 1fr; }
  .print-mode-opt { min-width: 100%; }
  .lh-header { flex-direction: column; gap: 8px; }
}
@media (max-width: 420px) {
  .bp-pack-preview { grid-template-columns: 1fr; }
  .bp-doc-card-actions { grid-template-columns: 1fr 1fr; }
}

/* Saved toolbar for invoices */
.saved-toolbar {
  display: flex;
  gap: 10px;
  margin-bottom: 14px;
  flex-wrap: wrap;
}

/* ═══ BOARD PACK TABS ═══════════════════════════════════════════ */
.bp-tabs {
  display: flex;
  gap: 2px;
  background: var(--cream);
  border-radius: 10px;
  padding: 4px;
  margin-bottom: 4px;
  width: fit-content;
  max-width: 100%;
  flex-wrap: wrap;
}
.bp-tab {
  padding: 7px 16px;
  border-radius: 7px;
  border: none;
  cursor: pointer;
  font-family: 'DM Sans', sans-serif;
  font-size: 13px;
  font-weight: 500;
  color: var(--muted);
  background: transparent;
  transition: all 0.18s;
  white-space: nowrap;
}
.bp-tab:hover { background: rgba(255,255,255,0.6); color: var(--ink); }
.bp-tab.active { background: var(--white); color: var(--ink); box-shadow: var(--shadow); }

/* ═══ PROFILE CARDS ════════════════════════════════════════════ */
.bp-profile-card {
  background: var(--white);
  border: 1.5px solid var(--border);
  border-radius: 14px;
  padding: 18px 20px;
  margin-bottom: 14px;
  transition: border-color 0.18s;
}
.bp-profile-card:hover { border-color: var(--gold); }

/* ═══ RESOLUTION DETAIL FORM ═══════════════════════════════════ */
.bp-res-detail-form {
  background: #fffdf4;
  border: 1.5px solid var(--gold);
  border-radius: 10px;
  padding: 14px 16px;
  margin: -4px 0 12px 0;
  animation: fadeIn 0.2s ease;
}
@keyframes fadeIn { from { opacity:0; transform:translateY(-4px); } to { opacity:1; transform:translateY(0); } }

/* ═══ MOBILE RESPONSIVE ADDITIONS ══════════════════════════════ */
@media (max-width: 768px) {
  .bp-tabs { width: 100%; }
  .bp-tab { flex: 1; text-align: center; padding: 7px 8px; font-size: 12px; }
  .bp-profile-card { padding: 14px; }
}

/* ═══ ENTITY TYPE SELECTOR ══════════════════════════════════════ */
.entity-type-radio { display:flex; flex-wrap:wrap; gap:8px; }
