/* ============================================================
   Villa Plumbing Field Portal — Projects/Schedule Must-Fixes
   Additive layer ON TOP of existing portal styles. Preserves the
   teal/navy/Barlow visual identity (no layout overrides, no
   replacement of existing components).
   Items addressed:
     - Inline status edit on project rows (dropdown styled to match
       existing .badge pills)
     - Hover key-contacts popover on project rows
     - PlanHub label inside project detail (count rendered as
       secondary badge, not primary label)
     - Project Contacts section inside project Info tab
     - Schedule "Add Time" affordance + conflict popup w/ Lily
       suggestions (uses existing modal styling tokens)
   ============================================================ */

/* ---------- Inline status select (matches .badge pill look) ---------- */
.vmf-status-cell { position: relative; }
.vmf-status-select {
  border: 1px solid var(--bd);
  background: var(--white);
  color: var(--tx);
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .3px;
  padding: 3px 22px 3px 9px;
  border-radius: 20px;
  cursor: pointer;
  outline: none;
  transition: border .15s, background .15s, color .15s;
  appearance: none;
  -webkit-appearance: none;
  background-image:
    linear-gradient(45deg, transparent 50%, var(--tx-md) 50%),
    linear-gradient(135deg, var(--tx-md) 50%, transparent 50%);
  background-position:
    calc(100% - 11px) 52%,
    calc(100% - 7px) 52%;
  background-size: 4px 4px, 4px 4px;
  background-repeat: no-repeat;
}
.vmf-status-select:hover { border-color: var(--teal); color: var(--teal-dk); }
.vmf-status-select:focus { border-color: var(--teal); box-shadow: 0 0 0 3px rgba(255,107,0,.15); }
.vmf-status-select.s-active { background: var(--teal-lt); color: var(--teal-dk); border-color: var(--teal-md); }
.vmf-status-select.s-warn   { background: #fff4dc; color: #8a5c00; border-color: #f0d68c; }
.vmf-status-select.s-cool   { background: #eaf2ff; color: #1a3a72; border-color: #c8d8f4; }
.vmf-status-select.s-done   { background: #e9eef0; color: #4a6b65; border-color: #c9d6d4; }

/* ---------- Hover key-contacts popover ---------- */
.vmf-contact-pop {
  position: fixed;
  z-index: 600;
  min-width: 260px;
  max-width: 320px;
  background: var(--white);
  border: 1px solid var(--bd);
  border-radius: 12px;
  box-shadow: 0 18px 46px rgba(20,19,16,.18);
  padding: 12px 14px;
  font-family: 'Barlow', sans-serif;
  pointer-events: none;
}
.vmf-contact-pop h5 {
  margin: 0 0 6px;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 12px;
  font-weight: 700;
  color: var(--tx-lt);
  text-transform: uppercase;
  letter-spacing: .5px;
}
.vmf-contact-pop ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 4px; }
.vmf-contact-pop li { display: flex; justify-content: space-between; gap: 12px; font-size: 12.5px; color: var(--tx); }
.vmf-contact-pop .role { color: var(--tx-lt); font-weight: 600; text-transform: uppercase; font-size: 10.5px; letter-spacing: .4px; }
.vmf-contact-pop .name { font-weight: 600; }
.vmf-contact-pop .empty { font-size: 12px; color: var(--tx-lt); font-style: italic; }

/* ---------- Project Contacts section (inside Info tab) ---------- */
.vmf-contacts {
  margin-top: 1rem;
  border: 1px solid var(--bd-lt);
  border-radius: 12px;
  padding: 14px 16px;
  background: #fbfdfd;
}
.vmf-contacts-head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 10px;
}
.vmf-contacts-head h4 {
  margin: 0;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 15px;
  font-weight: 700;
  color: var(--navy);
  text-transform: uppercase;
  letter-spacing: .5px;
}
.vmf-contacts-list { display: flex; flex-direction: column; gap: 8px; }
.vmf-contact-row {
  display: grid;
  grid-template-columns: 110px 1fr 1fr 1fr auto auto;
  gap: 8px;
  align-items: center;
  background: var(--white);
  border: 1px solid var(--bd-lt);
  border-radius: 10px;
  padding: 8px 10px;
}
.vmf-contact-row input, .vmf-contact-row select {
  padding: 6px 9px;
  border: 1px solid var(--bd);
  border-radius: 8px;
  font-family: 'Barlow', sans-serif;
  font-size: 12.5px;
  background: #fff;
  color: var(--tx);
  outline: none;
  width: 100%;
}
.vmf-contact-row input:focus, .vmf-contact-row select:focus { border-color: var(--teal); }
.vmf-contact-row .vmf-primary-flag {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .4px;
  padding: 3px 8px;
  border-radius: 999px;
  border: 1px solid var(--bd);
  background: #fff;
  color: var(--tx-lt);
  cursor: pointer;
}
.vmf-contact-row .vmf-primary-flag.on { background: var(--teal-lt); border-color: var(--teal-md); color: var(--teal-dk); }
.vmf-contact-row .vmf-rm {
  border: 1px solid var(--bd);
  background: #fff;
  color: var(--coral);
  border-radius: 8px;
  padding: 5px 9px;
  cursor: pointer;
  font-size: 13px;
  line-height: 1;
}
.vmf-contact-row .vmf-rm:hover { background: #fce8e4; border-color: var(--coral); }
.vmf-contact-empty {
  font-size: 13px; color: var(--tx-lt); font-style: italic;
  padding: 10px; text-align: center;
}

/* ---------- PlanHub label fix (inside project tabs) ---------- */
.vmf-tab-count {
  display: inline-flex;
  align-items: center;
  margin-left: 6px;
  padding: 1px 7px;
  border-radius: 999px;
  background: var(--teal-lt);
  color: var(--teal-dk);
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .3px;
}

/* ---------- Schedule extend-time popover ---------- */
.vmf-extend-pop {
  position: fixed;
  z-index: 700;
  background: var(--white);
  border: 1px solid var(--bd);
  border-radius: 12px;
  box-shadow: 0 18px 46px rgba(20,19,16,.22);
  padding: 12px 14px;
  font-family: 'Barlow', sans-serif;
  width: 260px;
}
.vmf-extend-pop h5 {
  margin: 0 0 8px;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 13px;
  font-weight: 700;
  color: var(--navy);
  text-transform: uppercase;
  letter-spacing: .4px;
}
.vmf-extend-pop label {
  display: block;
  font-size: 11px;
  font-weight: 700;
  color: var(--tx-md);
  text-transform: uppercase;
  letter-spacing: .4px;
  margin-bottom: 4px;
}
.vmf-extend-pop input[type="number"] {
  width: 100%;
  padding: 8px 10px;
  border: 1.5px solid var(--bd);
  border-radius: 8px;
  font-family: 'Barlow', sans-serif;
  font-size: 14px;
  background: #fff;
  outline: none;
  margin-bottom: 8px;
}
.vmf-extend-pop input[type="number"]:focus { border-color: var(--teal); }
.vmf-extend-pop .vmf-extend-actions {
  display: flex; gap: 8px; justify-content: flex-end;
}

/* ---------- Conflict popup (Lily suggestions) ---------- */
.vmf-conflict-overlay {
  position: fixed; inset: 0;
  background: rgba(20,19,16,.5);
  display: flex; align-items: center; justify-content: center;
  z-index: 800;
  padding: 20px;
}
.vmf-conflict-modal {
  background: var(--white);
  border-radius: 16px;
  width: 100%;
  max-width: 520px;
  box-shadow: 0 32px 80px rgba(0,0,0,.35);
  overflow: hidden;
  font-family: 'Barlow', sans-serif;
}
.vmf-conflict-head {
  background: linear-gradient(135deg, #fce8e4, #fff4ef);
  padding: 16px 20px;
  display: flex; align-items: center; gap: 12px;
  border-bottom: 1px solid var(--bd-lt);
}
.vmf-conflict-head .vmf-c-ico { font-size: 24px; }
.vmf-conflict-head h3 {
  margin: 0;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 18px;
  font-weight: 700;
  color: #9b2c1a;
  text-transform: uppercase;
  letter-spacing: .4px;
}
.vmf-conflict-body { padding: 16px 20px; }
.vmf-conflict-affected {
  background: #fff8f6;
  border: 1px solid #f3c8be;
  border-radius: 10px;
  padding: 10px 12px;
  margin-bottom: 14px;
  font-size: 13px;
  color: var(--tx);
}
.vmf-conflict-affected strong { color: #9b2c1a; }
.vmf-conflict-body .vmf-lily-title {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 12px;
  font-weight: 700;
  color: var(--teal-dk);
  text-transform: uppercase;
  letter-spacing: .5px;
  margin-bottom: 8px;
  display: flex; align-items: center; gap: 6px;
}
.vmf-lily-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 6px; }
.vmf-lily-list button {
  width: 100%;
  text-align: left;
  background: var(--white);
  border: 1px solid var(--bd);
  border-radius: 10px;
  padding: 10px 12px;
  font-family: 'Barlow', sans-serif;
  font-size: 13px;
  color: var(--tx);
  cursor: pointer;
  transition: all .15s;
}
.vmf-lily-list button:hover { border-color: var(--teal); background: var(--teal-lt); color: var(--teal-dk); }
.vmf-conflict-foot {
  padding: 12px 20px;
  border-top: 1px solid var(--bd-lt);
  display: flex; justify-content: flex-end; gap: 8px;
  background: #fbfdfd;
}

/* ---------- Resolution toast ---------- */
.vmf-toast {
  position: fixed;
  bottom: 22px;
  right: 22px;
  background: var(--navy);
  color: #fff;
  padding: 10px 16px;
  border-radius: 10px;
  font-family: 'Barlow', sans-serif;
  font-size: 13px;
  font-weight: 600;
  box-shadow: 0 10px 30px rgba(0,0,0,.25);
  z-index: 900;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity .2s, transform .2s;
}
.vmf-toast.show { opacity: 1; transform: translateY(0); }
