/* ============================================================
   Villa Plumbing Field Portal — Lily Bid Intake styling
   Foundation pass. Mobile-first, follows existing palette.
   ============================================================ */

.lbi-overlay{
  position:fixed; inset:0; z-index:1200;
  background:rgba(20,19,16,.45);
  display:flex; align-items:flex-start; justify-content:center;
  padding:28px 12px;
  overflow-y:auto;
}
.lbi-overlay[hidden]{ display:none !important; }
.lbi-shell{
  background:#fff;
  width:min(1100px, 100%);
  border-radius:18px;
  box-shadow:0 32px 80px rgba(0,0,0,.35);
  overflow:hidden;
  font-family:'Barlow', system-ui, sans-serif;
  color:#1a2e2b;
  display:flex; flex-direction:column;
  max-height:calc(100vh - 56px);
}
.lbi-shell-h{
  padding:18px 22px 14px 22px;
  background:linear-gradient(135deg,#1A1916,#141310);
  color:#fff; position:relative;
}
.lbi-shell-title{
  font-family:'Barlow Condensed', sans-serif;
  font-size:20px; font-weight:700;
  letter-spacing:.5px;
}
.lbi-shell-sub{
  font-size:13px; opacity:.78; margin-top:4px; max-width:760px;
}
.lbi-shell-close{
  position:absolute; top:14px; right:14px;
  background:rgba(255,255,255,.12); color:#fff;
  border:none; border-radius:999px;
  width:34px; height:34px; font-size:22px; line-height:1;
  cursor:pointer;
}
.lbi-shell-close:hover{ background:rgba(255,255,255,.22); }

.lbi-shell-body{
  display:grid;
  grid-template-columns:280px 1fr;
  gap:0;
  flex:1; min-height:0;
}
@media (max-width:760px){
  .lbi-shell-body{ grid-template-columns:1fr; }
}

.lbi-aside{
  background:#eef4f3; padding:14px 12px;
  border-right:1px solid #d8e2df;
  overflow-y:auto;
}
.lbi-aside-h{
  font-family:'Barlow Condensed', sans-serif;
  font-size:12px; font-weight:700;
  text-transform:uppercase; letter-spacing:1px;
  color:#4a6b65; margin-bottom:8px;
}
.lbi-list{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:8px; }
.lbi-list-btn{
  display:block; width:100%; text-align:left;
  background:#fff; border:1px solid #d8e2df; border-radius:12px;
  padding:10px 12px; cursor:pointer;
  font-family:inherit; color:inherit;
  transition:border-color .15s, box-shadow .15s, transform .05s;
}
.lbi-list-btn:hover{ border-color:#FF6B00; box-shadow:0 2px 12px rgba(255,107,0,.18); }
.lbi-list-btn:active{ transform:translateY(1px); }
.lbi-list-title{ font-weight:600; font-size:14px; margin-bottom:2px; }
.lbi-list-meta{
  display:flex; flex-wrap:wrap; gap:6px;
  font-size:11px; color:#4a6b65; margin-bottom:4px;
}
.lbi-list-next{ font-size:11px; color:#D95A00; font-weight:600; }

.lbi-main{
  padding:18px 22px 22px 22px;
  overflow-y:auto;
}
.lbi-detail-h{
  display:flex; justify-content:space-between; align-items:flex-start;
  gap:12px; flex-wrap:wrap; margin-bottom:8px;
}
.lbi-detail-title{
  font-family:'Barlow Condensed', sans-serif;
  font-size:22px; font-weight:700;
  color:#141310;
}
.lbi-detail-sub{ font-size:13px; color:#4a6b65; }
.lbi-detail-h-r{ display:flex; gap:6px; flex-wrap:wrap; align-items:center; }

.lbi-pill{
  display:inline-block;
  padding:3px 10px; border-radius:999px;
  font-size:11px; font-weight:700;
  text-transform:uppercase; letter-spacing:.5px;
  background:#FFF0E5; color:#D95A00;
}
.lbi-pill-new{ background:#fff4e0; color:#b07900; }
.lbi-pill-in-review{ background:#e8f0fa; color:#1A1916; }
.lbi-pill-drafted{ background:#FFF0E5; color:#D95A00; }
.lbi-pill-submitted{ background:#e0f0e6; color:#1f6e3a; }
.lbi-pill-awarded{ background:#cdebd6; color:#0c5a2a; }
.lbi-pill-lost{ background:#f8ddd6; color:#a23a1f; }
.lbi-pill-due{ background:#eef4f3; color:#4a6b65; }
.lbi-tone-urgent{ background:#fdd; color:#a23a1f; }
.lbi-tone-warn{ background:#fff0d4; color:#a06c00; }
.lbi-tone-ok{ background:#FFF0E5; color:#D95A00; }
.lbi-tone-muted{ background:#eef4f3; color:#8aada8; }

.lbi-lily-line{
  background:#f4f7f6; border:1px dashed #FFD4B0;
  padding:8px 12px; border-radius:10px;
  font-size:13px; color:#1a2e2b; margin:10px 0;
}
.lbi-lily-line em{ color:#D95A00; font-style:normal; font-weight:600; }

.lbi-next{
  display:flex; justify-content:space-between; align-items:center;
  background:#FFF0E5; border:1px solid #FFD4B0;
  padding:10px 14px; border-radius:12px; margin-bottom:14px;
  gap:12px;
}
.lbi-next-label{
  font-size:12px; text-transform:uppercase; letter-spacing:1px;
  font-weight:700; color:#D95A00;
}

.lbi-section{ background:#fff; border:1px solid #d8e8e5; border-radius:14px; padding:14px 16px; margin-bottom:14px; }
.lbi-section-h{
  font-family:'Barlow Condensed', sans-serif;
  font-size:14px; font-weight:700; letter-spacing:.6px;
  color:#141310; margin-bottom:8px;
  text-transform:uppercase;
}
.lbi-section-sub{ font-size:12px; color:#4a6b65; margin-bottom:8px; }
.lbi-section-actions{ display:flex; gap:8px; margin:8px 0; flex-wrap:wrap; }

.lbi-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
  gap:8px 14px;
}
.lbi-field{ padding:4px 0; min-width:0; }
.lbi-field-label{ font-size:11px; color:#8aada8; text-transform:uppercase; letter-spacing:.6px; font-weight:700; }
.lbi-field-value{ font-size:14px; color:#1a2e2b; word-wrap:break-word; }
.lbi-muted .lbi-field-value{ color:#8aada8; }
.lbi-passive{ color:#8aada8; font-style:italic; }

.lbi-scope{ margin-top:10px; }
.lbi-scope-body{
  background:#f4f7f6; border:1px solid #eef4f3;
  padding:8px 10px; border-radius:10px;
  font-size:13px; line-height:1.45; color:#1a2e2b;
}

.lbi-atts{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:6px; }
.lbi-att{
  display:flex; align-items:center; gap:10px;
  padding:6px 10px; background:#f4f7f6; border:1px solid #eef4f3;
  border-radius:10px; font-size:13px;
}
.lbi-att-kind{
  display:inline-block; min-width:56px;
  font-size:10px; text-transform:uppercase; letter-spacing:.5px;
  font-weight:700; color:#4a6b65;
}
.lbi-att-name{ word-break:break-word; }

.lbi-missing{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:6px; }
.lbi-mi{
  background:#fff4e0; border:1px solid #f3d68f;
  padding:8px 10px; border-radius:10px; font-size:13px;
  color:#7a4f00;
}

.lbi-textarea{
  width:100%; min-height:120px;
  padding:10px 12px; border:1.5px solid #d8e8e5;
  border-radius:10px; font-family:'Barlow', sans-serif;
  font-size:14px; resize:vertical; color:#1a2e2b;
  background:#fff;
}
.lbi-textarea:focus{ border-color:#FF6B00; outline:none; }

.lbi-claude-imported{
  margin-top:10px; padding:10px; background:#f4f7f6;
  border-radius:10px;
}
.lbi-claude-grid{ display:grid; gap:8px; }

.lbi-pkg-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}
@media (max-width:680px){ .lbi-pkg-row{ grid-template-columns:1fr; } }

.lbi-pkg{
  border:1px solid #d8e8e5; border-radius:12px;
  padding:12px 14px; background:#fff;
}
.lbi-pkg-empty{ background:#f4f7f6; }
.lbi-pkg-routed{ border-color:#FF6B00; background:#FFF0E5; }
.lbi-pkg-title{
  font-family:'Barlow Condensed', sans-serif;
  font-weight:700; font-size:14px; color:#141310;
  margin-bottom:4px; text-transform:uppercase;
}
.lbi-pkg-note{ font-size:12px; color:#4a6b65; margin-bottom:8px; line-height:1.4; }
.lbi-pkg-actions{ display:flex; gap:6px; flex-wrap:wrap; }
.lbi-pkg-foot{ font-size:11px; color:#8aada8; margin-top:8px; }

.lbi-outcome{
  border:1px solid #d8e8e5; border-radius:12px;
  padding:12px 14px; background:#fff; margin-bottom:14px;
}
.lbi-outcome-empty{ background:#f4f7f6; }
.lbi-outcome-awarded{ background:#FFF0E5; border-color:#FF6B00; }
.lbi-outcome-lost{ background:#f8ddd6; border-color:#e76f51; }
.lbi-outcome-grid{
  display:grid; grid-template-columns:repeat(auto-fit, minmax(180px,1fr)); gap:8px 14px;
  margin-top:6px;
}
.lbi-outcome-note{ font-size:11px; color:#4a6b65; margin-top:8px; font-style:italic; }
.lbi-outcome-actions{ display:flex; gap:8px; margin-top:6px; flex-wrap:wrap; }

.lbi-btn{
  display:inline-flex; align-items:center; gap:6px;
  font-family:'Barlow', sans-serif;
  font-size:13px; font-weight:600;
  padding:8px 14px; border-radius:10px;
  border:1.5px solid transparent; cursor:pointer;
  transition:background .15s, border-color .15s, transform .05s;
}
.lbi-btn:active{ transform:translateY(1px); }
.lbi-btn-p{ background:#FF6B00; color:#fff; }
.lbi-btn-p:hover{ background:#D95A00; }
.lbi-btn-o{ background:#fff; color:#D95A00; border-color:#FF6B00; }
.lbi-btn-o:hover{ background:#FFF0E5; }
.lbi-btn-ghost{ background:transparent; color:#4a6b65; border-color:#d8e8e5; }
.lbi-btn-ghost:hover{ background:#f4f7f6; color:#1a2e2b; }

.lbi-empty{
  padding:32px 18px; text-align:center;
  color:#8aada8; font-style:italic;
}

.lbi-explain{
  position:sticky; bottom:0;
  margin-top:12px;
  background:#141310; color:#fff;
  padding:10px 14px; border-radius:12px;
  font-size:13px; line-height:1.4;
  box-shadow:0 8px 24px rgba(0,0,0,.25);
}

.lbi-entry-btn{
  display:inline-flex; align-items:center;
  font-family:'Barlow', sans-serif; font-weight:600;
  font-size:12px;
  padding:6px 12px; margin-left:6px;
  border-radius:999px; cursor:pointer;
  background:#FFF0E5; color:#D95A00; border:1px solid #FF6B00;
}
.lbi-entry-btn:hover{ background:#FFD4B0; }

/* Mobile */
@media (max-width:520px){
  .lbi-overlay{ padding:0; align-items:stretch; }
  .lbi-shell{ border-radius:0; max-height:100vh; }
  .lbi-main{ padding:14px; }
  .lbi-detail-title{ font-size:18px; }
}

/* Print — the routed package is what should print; this shell is preview */
@media print{
  .lbi-overlay{ position:static; background:none; padding:0; }
  .lbi-shell{ box-shadow:none; border-radius:0; }
  .lbi-shell-close,
  .lbi-pkg-actions,
  .lbi-section-actions,
  .lbi-outcome-actions,
  .lbi-entry-btn{ display:none !important; }
}
