/* ============================================================
   PR131 — Property-Spine styling
   Build marker: pr131-css:2026-05-22 (PR133b Round 5 — tokens + mobile)
   PR133b: hardcoded hex replaced with portal CSS custom properties
   from index.html :root (--teal, --navy, --tx, --bd, etc.) with hex
   fallbacks for older renderers. Mobile breakpoints + 44px touch
   targets added at the bottom of the file.
============================================================ */

/* Universal search */
.pr131-usearch-host { position: relative; display: inline-block; min-width: 280px; }
.pr131-usearch { position: relative; }
.pr131-usearch-input {
  width: 100%;
  padding: 6px 10px;
  border: 1px solid var(--bd, #cfd6dc);
  border-radius: 4px;
  font: 14px/1.3 inherit;
}
.pr131-usearch-dd {
  position: absolute; z-index: 50; top: calc(100% + 4px); left: 0; right: 0;
  background: var(--white, #fff); border: 1px solid var(--bd, #cfd6dc); border-radius: 4px;
  box-shadow: 0 6px 24px rgba(0,0,0,0.10);
  max-height: 380px; overflow-y: auto;
}
.pr131-usearch-section + .pr131-usearch-section { border-top: 1px solid var(--bd-lt, #eef1f4); }
.pr131-usearch-section-h {
  padding: 6px 12px; font-size: 11px; text-transform: uppercase;
  color: var(--tx-md, #6b7280); background: var(--bg, #f8fafc); letter-spacing: 0.04em;
}
.pr131-usearch-list { margin: 0; padding: 0; list-style: none; }
.pr131-usearch-item {
  display: flex; gap: 10px; align-items: flex-start;
  padding: 8px 12px; cursor: pointer;
}
.pr131-usearch-item:hover { background: var(--teal-lt, #eff6ff); }
.pr131-usearch-icon { font-size: 18px; line-height: 1; }
.pr131-usearch-pri { font-weight: 600; color: var(--tx, #1f2937); }
.pr131-usearch-sub { color: var(--tx-md, #6b7280); font-size: 12px; }
.pr131-usearch-empty { padding: 16px; color: var(--tx-md, #6b7280); text-align: center; font-size: 13px; }

/* Property page */
.pr131-prop-root { padding: 0 16px 24px; }
.pr131-prop-hero {
  display: flex; gap: 14px; align-items: center;
  background: var(--navy, #141310); color: var(--white, #fff);
  padding: 18px 22px; border-radius: 12px;
  margin: 12px 0 8px;
}
.pr131-prop-hero-ic { font-size: 30px; }
.pr131-prop-hero-tx h2 { margin: 0 0 4px; font-size: 20px; }
.pr131-prop-hero-tx p { margin: 0; opacity: 0.85; font-size: 13px; }
.pr131-prop-tabs {
  display: flex; gap: 4px; padding: 6px;
  background: var(--white, #fff); border-radius: 999px; border: 1px solid var(--bd, #e5e7eb);
  margin-bottom: 16px; flex-wrap: nowrap;
  overflow-x: auto; -webkit-overflow-scrolling: touch;
  /* PR137 AUDIT-024 — right-edge mask so users see there are more tabs offscreen on mobile. */
  -webkit-mask-image: linear-gradient(to right, #000 0%, #000 92%, transparent 100%);
          mask-image: linear-gradient(to right, #000 0%, #000 92%, transparent 100%);
}
@media (min-width: 720px) {
  .pr131-prop-tabs { -webkit-mask-image: none; mask-image: none; }
}
.pr131-prop-tab {
  border: 0; background: transparent; padding: 6px 14px; border-radius: 999px;
  font: 13px/1 inherit; cursor: pointer; color: var(--tx-md, #475569);
}
.pr131-prop-tab.on { background: var(--teal, #FF6B00); color: var(--white, #fff); }
.pr131-prop-grid { display: grid; grid-template-columns: 160px 1fr; gap: 6px 16px; }
.pr131-prop-grid dt { color: var(--tx-md, #64748b); font-size: 12px; padding-top: 6px; }
.pr131-prop-grid dd { margin: 0; padding: 4px 0; }
.pr131-prop-pill {
  display: inline-block; padding: 2px 10px; border-radius: 999px;
  background: var(--teal-lt, #e0f2fe); color: var(--teal-dk, #075985); font-size: 12px; margin-right: 4px;
}
.pr131-prop-table { width: 100%; border-collapse: collapse; margin-top: 8px; }
.pr131-prop-table th, .pr131-prop-table td { padding: 6px 8px; text-align: left; border-bottom: 1px solid var(--bd-lt, #eef1f4); font-size: 13px; }
.pr131-prop-table th { color: var(--tx-md, #64748b); font-weight: 500; }
.pr131-prop-role.ended td { color: var(--tx-lt, #94a3b8); }
.pr131-prop-empty { padding: 16px; color: var(--tx-lt, #94a3b8); text-align: center; font-size: 13px; }
.pr131-prop-section-h { display: flex; align-items: center; justify-content: space-between; }
.pr131-prop-btn {
  background: var(--teal, #FF6B00); color: var(--white, #fff); border: 0; padding: 6px 12px;
  border-radius: 6px; cursor: pointer; font: 13px/1 inherit;
}
.pr131-prop-btn:hover { background: var(--teal-dk, #D95A00); }
.pr131-prop-btn-mini { padding: 2px 8px; font-size: 12px; }
.pr131-prop-event-list { margin: 0; padding: 0; list-style: none; }
.pr131-prop-event {
  display: grid; grid-template-columns: 200px 200px 1fr 120px; gap: 12px;
  padding: 6px 0; border-bottom: 1px solid var(--bd-lt, #eef1f4); font-size: 13px;
}
.pr131-prop-event-type { color: var(--teal-dk, #D95A00); font-weight: 500; }
.pr131-prop-event-actor { color: var(--tx-lt, #94a3b8); font-size: 12px; }

/* Customer Hub extensions */
.pr131-vch-aliases, .pr131-vch-trades { margin-top: 10px; }
.pr131-vch-lbl { font-size: 12px; color: var(--tx-md, #64748b); display: block; margin-bottom: 4px; }
.pr131-vch-pills { display: flex; gap: 6px; flex-wrap: wrap; }
.pr131-vch-pill {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 2px 8px; background: var(--bd-lt, #f1f5f9); border-radius: 999px; font-size: 12px;
}
.pr131-vch-pill-x { background: transparent; border: 0; cursor: pointer; color: var(--tx-md, #64748b); }
.pr131-vch-pill-add {
  background: transparent; border: 1px dashed var(--bd, #cbd5e1); padding: 2px 8px;
  border-radius: 999px; cursor: pointer; font-size: 12px; color: var(--tx-md, #64748b);
}
.pr131-vch-jobsite { padding: 6px 0; border-bottom: 1px solid var(--bd-lt, #eef1f4); }
.pr131-vch-jobsite h4 { margin: 0 0 4px; font-size: 13px; color: var(--teal-dk, #D95A00); }
.pr131-vch-event-list { margin: 0; padding: 0; list-style: none; }
.pr131-vch-event { display: grid; grid-template-columns: 200px 160px 1fr; gap: 8px; padding: 4px 0; font-size: 12px; border-bottom: 1px solid var(--bd-lt, #eef1f4); }

/* Bid intake form */
.pr131-bid-intake { padding: 12px 0; }
.pr131-bid-intake .pr131-row { display: flex; flex-direction: column; gap: 4px; margin-bottom: 10px; }
.pr131-bid-intake .pr131-row-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.pr131-bid-intake label { font-size: 12px; color: var(--tx-md, #64748b); }
.pr131-bid-intake input { padding: 6px 10px; border: 1px solid var(--bd, #cfd6dc); border-radius: 4px; font: 14px/1.3 inherit; }
.pr131-helper { font-size: 12px; color: var(--tx-md, #4a6b65); margin: -4px 0 8px; }

/* Lily / MyDay — PR133b: rounded card style aligned with portal .psr-task-card */
.pr131-lily-card {
  background: var(--white, #fff);
  border: 1px solid var(--bd-lt, #dde8e7);
  border-left: 4px solid var(--teal, #FF6B00);
  padding: 12px 14px; margin: 8px 0; border-radius: 12px;
  box-shadow: 0 1px 2px rgba(0,0,0,0.04);
}
/* When mounted inside the My Day panel, drop the left-border accent and
   use the portal's standard rounded card. P2-002 carryover. */
.pr131-myday-card,
.myday-panel .pr131-lily-card,
.pr131-myday-section .pr131-lily-card {
  border-left: 1px solid var(--bd-lt, #dde8e7);
  border-radius: 12px;
}
.pr131-lily-pri { font-weight: 600; color: var(--tx, #0f172a); margin-bottom: 4px; }
.pr131-lily-sub { color: var(--tx-md, #475569); font-size: 13px; }
.pr131-lily-actions { margin-top: 8px; display: flex; gap: 6px; flex-wrap: wrap; }
.pr131-lily-btn, .pr131-btn {
  background: var(--bd-lt, #f1f5f9); border: 1px solid var(--bd, #cbd5e1); padding: 6px 12px;
  border-radius: 6px; cursor: pointer; font: 12px/1.2 inherit;
}
.pr131-lily-btn:hover, .pr131-btn:hover { border-color: var(--teal, #FF6B00); color: var(--teal, #FF6B00); }
.pr131-btn-primary { background: var(--teal, #FF6B00); color: var(--white, #fff); border-color: var(--teal, #FF6B00); }
.pr131-btn-primary:hover { background: var(--teal-dk, #D95A00); border-color: var(--teal-dk, #D95A00); color: var(--white, #fff); }
.pr131-btn-primary[disabled] { opacity: 0.5; cursor: not-allowed; }

/* Settings */
.pr131-settings-table { width: 100%; border-collapse: collapse; }
.pr131-settings-table th, .pr131-settings-table td { padding: 6px 8px; text-align: left; border-bottom: 1px solid var(--bd-lt, #eef1f4); font-size: 13px; }
.pr131-settings-table input, .pr131-settings-table select { padding: 4px 8px; border: 1px solid var(--bd, #cfd6dc); border-radius: 4px; font: 13px/1.2 inherit; }
.pr131-settings-add { margin-top: 16px; display: flex; gap: 8px; flex-wrap: wrap; }
.pr131-admin-only { color: var(--coral, #b91c1c); font-style: italic; font-size: 12px; }

/* PR132 — bid intake field-level error messages */
.pr131-bid-fielderr {
  margin-top: 4px; color: var(--coral, #b91c1c); font-size: 12.5px; font-weight: 600;
  background: #fef2f2; border: 1px solid #fecaca; padding: 6px 10px; border-radius: 6px;
}
.pr131-bid-formerr {
  margin: 10px 0; color: #7f1d1d; font-size: 13px; font-weight: 600;
  background: #fef2f2; border: 1px solid #fecaca; padding: 8px 12px; border-radius: 6px;
}

/* PR132 — property browse modal */
.pr131-prop-browse { display: flex; flex-direction: column; gap: 12px; }
.pr131-prop-browse-bar { display: flex; gap: 8px; }
.pr131-prop-browse-search {
  flex: 1; padding: 8px 12px; border: 1px solid var(--bd, #cfd6dc); border-radius: 6px;
  font: 14px/1.3 inherit;
}
.pr131-prop-browse-list { display: flex; flex-direction: column; gap: 6px; }
.pr131-prop-browse-row {
  display: flex; align-items: center; gap: 10px; width: 100%;
  text-align: left; padding: 10px 14px; background: var(--white, #fff); border: 1px solid var(--bd-lt, #e2e8f0);
  border-radius: 12px; cursor: pointer; font: 14px/1.3 inherit;
}
.pr131-prop-browse-row:hover { background: var(--bg, #f8fafc); border-color: var(--teal, #FF6B00); }
.pr131-prop-browse-ic { font-size: 18px; }
.pr131-prop-browse-tx { flex: 1; display: flex; flex-direction: column; gap: 2px; }
.pr131-prop-browse-addr { font-weight: 600; color: var(--tx, #0f172a); }
.pr131-prop-browse-aliases { font-size: 12px; color: var(--tx-md, #64748b); }
.pr131-prop-browse-chev { font-size: 18px; color: var(--tx-lt, #94a3b8); }
.pr131-prop-browse-new { background: var(--bg, #f8fafc); padding: 16px; border-radius: 12px; border: 1px solid var(--bd-lt, #e2e8f0); }
.pr131-prop-new h3 { margin: 0 0 12px; font-size: 15px; }
.pr131-prop-new .pr131-row { margin-bottom: 10px; display: flex; flex-direction: column; gap: 4px; }
.pr131-prop-new .pr131-row label { font-size: 12px; font-weight: 600; color: var(--tx-md, #475569); }
.pr131-prop-new .pr131-row input { padding: 6px 10px; border: 1px solid var(--bd, #cfd6dc); border-radius: 4px; font: 14px/1.3 inherit; }
.pr131-prop-new-err { color: var(--coral, #b91c1c); font-size: 13px; padding: 8px; background: #fef2f2; border-radius: 6px; margin-bottom: 8px; }
.pr131-prop-new-actions { display: flex; gap: 8px; }

/* PR132 — Lily MyDay section inside My Day panel */
.pr131-myday-section { margin-top: 12px; }
.pr131-myday-section .myday-group-hdr { display: flex; align-items: center; gap: 8px; padding-bottom: 6px; border-bottom: 1px solid var(--bd-lt, #e2e8f0); }
.pr131-myday-section .myday-group-hdr h4 { margin: 0; font-size: 14px; }
.pr131-myday-section .myday-group-hdr .ct {
  margin-left: auto; background: var(--teal, #FF6B00); color: var(--white, #fff); font-size: 11px; padding: 2px 8px; border-radius: 999px;
}
.pr131-myday-section .myday-group-body { padding: 8px 0; display: flex; flex-direction: column; gap: 8px; }

/* PR132 — bid tracker award gate failure panel */
.bidtr-award-fail {
  margin-top: 12px; padding: 12px 14px; background: #fffbeb; border: 1px solid #fcd34d;
  border-radius: 12px; color: #78350f;
}
.bidtr-award-fail h4 { margin: 0 0 8px; font-size: 14px; }
.bidtr-award-list { margin: 0 0 8px; padding-left: 20px; }
.bidtr-award-list li { margin-bottom: 6px; }
.bidtr-award-hint { font-size: 12px; color: #92400e; font-weight: 400; margin-top: 2px; }

/* PR132 — schedule assign-supervisor inline form */
.pr131-assign-super { background: var(--bg, #f8fafc); padding: 14px; border-radius: 12px; border: 1px solid var(--bd-lt, #e2e8f0); margin: 8px 0; }
.pr131-assign-super h4 { margin: 0 0 10px; font-size: 14px; }
.pr131-assign-super .pr131-row { margin-bottom: 10px; display: flex; flex-direction: column; gap: 4px; }
.pr131-assign-super .pr131-row label { font-size: 12px; font-weight: 600; color: var(--tx-md, #475569); }
.pr131-assign-super .pr131-row input[type=text] { padding: 6px 10px; border: 1px solid var(--bd, #cfd6dc); border-radius: 4px; font: 14px/1.3 inherit; }
.pr131-assign-super .pr131-row-check em { font-weight: 400; color: var(--tx-md, #64748b); font-size: 12px; margin-left: 4px; }
.pr131-assign-fail {
  margin: 8px 0; padding: 10px 12px; background: #fef2f2; border: 1px solid #fecaca;
  border-radius: 6px; color: #7f1d1d; font-size: 13px;
}
.pr131-assign-fail ul { margin: 6px 0 0; padding-left: 20px; }
.pr131-assign-actions { display: flex; gap: 8px; margin-top: 8px; }

/* PR132 — Settings hero strip (uses same .pr131-prop-hero from property page) */
[data-pr131-settings-hero="1"] .pr131-prop-hero-ic { font-size: 32px; }

/* ============================================================
   PR133b Round 5 — Mobile breakpoints (≤480px)
   Tables collapse to card stack, multi-column forms collapse to
   single column, all interactive targets ≥44px. AUDIT-022/023/024.
============================================================ */
@media (max-width: 480px) {
  .pr131-prop-root { padding: 0 10px 24px; }
  .pr131-prop-hero { padding: 14px 16px; border-radius: 10px; }
  .pr131-prop-hero-tx h2 { font-size: 17px; }
  .pr131-prop-tabs { border-radius: 12px; gap: 2px; padding: 4px; }
  .pr131-prop-tab { min-height: 44px; padding: 10px 14px; font-size: 13px; }
  .pr131-prop-grid { grid-template-columns: 1fr; gap: 2px 0; }
  .pr131-prop-grid dt { padding-top: 8px; font-weight: 600; color: var(--tx, #334155); }
  /* Tables → card stack */
  .pr131-prop-table, .pr131-prop-table thead, .pr131-prop-table tbody,
  .pr131-prop-table tr, .pr131-prop-table th, .pr131-prop-table td {
    display: block;
  }
  .pr131-prop-table thead { display: none; }
  .pr131-prop-table tr {
    background: var(--white, #fff);
    border: 1px solid var(--bd-lt, #e2e8f0);
    border-radius: 10px;
    padding: 8px 10px;
    margin-bottom: 8px;
  }
  .pr131-prop-table td {
    border: 0;
    padding: 4px 0;
  }
  /* Property event-list grid → single column */
  .pr131-prop-event { grid-template-columns: 1fr; gap: 2px; padding: 8px 0; }
  /* Bid intake form: 2-col → 1-col */
  .pr131-bid-intake .pr131-row-2 { grid-template-columns: 1fr; gap: 8px; }
  /* Settings tables → card stack */
  .pr131-settings-table, .pr131-settings-table thead, .pr131-settings-table tbody,
  .pr131-settings-table tr, .pr131-settings-table th, .pr131-settings-table td {
    display: block;
  }
  .pr131-settings-table thead { display: none; }
  .pr131-settings-table tr {
    background: var(--white, #fff);
    border: 1px solid var(--bd-lt, #e2e8f0);
    border-radius: 10px;
    padding: 8px 10px;
    margin-bottom: 8px;
  }
  .pr131-settings-table td { border: 0; padding: 4px 0; }
  .pr131-settings-table input,
  .pr131-settings-table select { width: 100%; min-height: 44px; }
  .pr131-settings-add { flex-direction: column; }
  .pr131-settings-add > * { width: 100%; min-height: 44px; }
  /* Lily / button touch targets */
  .pr131-lily-btn, .pr131-btn { min-height: 44px; padding: 10px 14px; font-size: 13px; }
  .pr131-prop-btn { min-height: 44px; padding: 10px 14px; }
  .pr131-prop-btn-mini { min-height: 36px; padding: 6px 10px; }
  .pr131-vch-pill-x { min-width: 32px; min-height: 32px; }
  /* Universal search */
  .pr131-usearch-host { min-width: 0; width: 100%; display: block; }
  .pr131-usearch-input { min-height: 44px; }
  /* Property browse list rows: ensure ≥44px tap */
  .pr131-prop-browse-row { min-height: 44px; }
  /* Notification prefs role-defaults wide table → allow horizontal scroll */
  .pr131-settings-rolesdef { overflow-x: auto; }
}
