/* mesh — shared "Anadir a una lista" picker.
   Dark surface (IG/Spotify pattern) so it's unmistakable on any page and so
   theme button rules (Astra/Elementor) can't repaint our buttons — every
   visual property on a button-or-input inside .mesh-lp uses !important.
   Mobile: bottom sheet with drag handle. Desktop (no anchor): centered modal.
   Desktop (with anchor): popover.
   Pairs with assets/js/mesh-list-picker.js. */

.mesh-lp-back {
  position: fixed; inset: 0; z-index: 9700;
  background: rgba(8,8,12,.6);
  opacity: 0; visibility: hidden;
  display: flex; align-items: flex-end; justify-content: center;
  transition: opacity .22s ease, visibility .22s ease;
  -webkit-backdrop-filter: blur(2px);
  backdrop-filter: blur(2px);
}
.mesh-lp-back.is-open { opacity: 1; visibility: visible; }
.mesh-lp-back.is-modal { align-items: center; padding: 20px; }

.mesh-lp {
  position: relative;
  width: 100%;
  background: #0d0d0d !important;
  color: #f5f2eb !important;
  font-family: 'Space Grotesk', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
  font-size: 15px;
  line-height: 1.3;
  display: flex; flex-direction: column;
  max-height: 78vh;
  box-shadow: 0 -10px 40px rgba(0,0,0,.5);
  transform: translateY(24px);
  opacity: 0;
  transition: transform .28s cubic-bezier(.16,1,.3,1), opacity .22s ease;
}
.mesh-lp-back.is-open .mesh-lp { transform: none; opacity: 1; }

/* Sheet — bottom-anchored, rounded top corners (mobile + small desktop fallback). */
.mesh-lp-back.is-sheet .mesh-lp {
  max-width: 100%;
  border-radius: 18px 18px 0 0;
}

/* Modal — centered card (desktop). */
.mesh-lp-back.is-modal .mesh-lp {
  max-width: 440px;
  border-radius: 16px;
  max-height: 80vh;
}

/* Popover — anchored to a button on desktop. */
.mesh-lp-back.is-popover {
  background: transparent !important;
  -webkit-backdrop-filter: none !important;
  backdrop-filter: none !important;
  pointer-events: none;
  align-items: flex-start; justify-content: flex-start;
}
.mesh-lp-back.is-popover .mesh-lp {
  position: absolute;
  pointer-events: auto;
  width: 360px;
  max-width: 360px;
  max-height: min(60vh, 480px);
  border-radius: 14px;
  box-shadow: 0 18px 48px rgba(0,0,0,.45);
}

/* Drag handle — only meaningful on bottom sheet. */
.mesh-lp-handle {
  display: none;
  width: 36px; height: 4px;
  background: rgba(245,242,235,.28) !important;
  border-radius: 4px;
  margin: 10px auto 4px;
  flex-shrink: 0;
}
.mesh-lp-back.is-sheet .mesh-lp-handle { display: block; }

/* X close — top-right floating. */
.mesh-lp-x,
button.mesh-lp-x {
  appearance: none !important;
  -webkit-appearance: none !important;
  position: absolute !important;
  top: 12px !important; right: 12px !important;
  width: 32px !important; height: 32px !important;
  padding: 0 !important; margin: 0 !important;
  display: inline-flex !important;
  align-items: center !important; justify-content: center !important;
  background: rgba(245,242,235,.08) !important;
  background-image: none !important;
  color: #f5f2eb !important;
  font-family: inherit !important;
  font-size: 20px !important; font-weight: 400 !important;
  line-height: 1 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  text-shadow: none !important;
  border: 0 !important;
  border-radius: 50% !important;
  box-shadow: none !important;
  cursor: pointer !important;
  min-height: 0 !important; min-width: 0 !important;
  z-index: 2;
}
.mesh-lp-x:hover { background: rgba(245,242,235,.16) !important; color: #fff !important; }
.mesh-lp-back.is-sheet .mesh-lp-x { top: 16px !important; }

/* Sliding stage — picker view and create view live side by side, animate X. */
.mesh-lp-stage {
  position: relative;
  display: flex;
  flex: 1 1 auto;
  min-height: 0;
  overflow: hidden;
  width: 100%;
}
.mesh-lp-view {
  flex: 0 0 100%;
  width: 100%;
  display: flex; flex-direction: column;
  min-height: 0;
  transition: transform .26s cubic-bezier(.16,1,.3,1);
}
.mesh-lp-view--picker { transform: translateX(0); }
.mesh-lp-view--create { transform: translateX(0); }
.mesh-lp-stage.is-create .mesh-lp-view--picker { transform: translateX(-100%); }
.mesh-lp-stage.is-create .mesh-lp-view--create { transform: translateX(-100%); }
.mesh-lp-view[aria-hidden="true"] { pointer-events: none; }
@media (prefers-reduced-motion: reduce) {
  .mesh-lp-view { transition: none; }
}

/* Headers ───────────────────────────────────────────────────── */
.mesh-lp-hd {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 56px 14px 22px;
  border-bottom: 1px solid rgba(245,242,235,.08) !important;
  flex-shrink: 0;
}
.mesh-lp-hd--create {
  padding: 16px 16px 14px;
  gap: 8px;
}
.mesh-lp-title {
  font-family: 'Barlow Condensed', Impact, sans-serif !important;
  font-size: 19px !important;
  font-weight: 900 !important;
  letter-spacing: .04em !important;
  text-transform: uppercase !important;
  color: #f5f2eb !important;
  line-height: 1.1 !important;
}
.mesh-lp-title--center { flex: 1 1 auto; text-align: center; }

/* "Nueva lista" link (picker view) — accent button, locked down. */
.mesh-lp-new-link,
button.mesh-lp-new-link {
  appearance: none !important;
  -webkit-appearance: none !important;
  font-family: inherit !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  text-decoration: none !important;
  text-shadow: none !important;
  color: #ffe135 !important;
  background: transparent !important;
  background-image: none !important;
  border: 0 !important;
  border-radius: 0 !important;
  padding: 6px 0 !important;
  margin: 0 !important;
  box-shadow: none !important;
  cursor: pointer !important;
  white-space: nowrap !important;
  min-height: 0 !important; min-width: 0 !important;
  width: auto !important; height: auto !important;
}
.mesh-lp-new-link:hover { color: #fff !important; text-decoration: underline !important; }

/* Create-view header buttons: Cancelar (left), Crear (right). */
.mesh-lp-cancel,
button.mesh-lp-cancel,
.mesh-lp-create,
button.mesh-lp-create {
  appearance: none !important;
  -webkit-appearance: none !important;
  font-family: inherit !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  text-decoration: none !important;
  text-shadow: none !important;
  background: transparent !important;
  background-image: none !important;
  border: 0 !important;
  border-radius: 0 !important;
  padding: 6px 4px !important;
  margin: 0 !important;
  box-shadow: none !important;
  cursor: pointer !important;
  white-space: nowrap !important;
  min-height: 0 !important; min-width: 0 !important;
  width: auto !important; height: auto !important;
}
.mesh-lp-cancel       { color: rgba(245,242,235,.7) !important; }
.mesh-lp-cancel:hover { color: #f5f2eb !important; }
.mesh-lp-create       { color: #ffe135 !important; }
.mesh-lp-create[disabled],
.mesh-lp-create:disabled { color: rgba(255,225,53,.3) !important; cursor: not-allowed !important; }

/* Form ─────────────────────────────────────────────────────── */
.mesh-lp-form { padding: 22px 22px 24px; }
.mesh-lp-form-row { display: flex; gap: 10px; align-items: stretch; }
.mesh-lp-form input,
input.mesh-lp-emoji,
input.mesh-lp-name {
  appearance: none !important;
  -webkit-appearance: none !important;
  font-family: inherit !important;
  font-size: 16px !important;
  font-weight: 500 !important;
  line-height: 1.3 !important;
  letter-spacing: 0 !important;
  color: #f5f2eb !important;
  background: rgba(245,242,235,.06) !important;
  background-image: none !important;
  border: 1.5px solid rgba(245,242,235,.14) !important;
  border-radius: 12px !important;
  padding: 12px 14px !important;
  margin: 0 !important;
  box-shadow: none !important;
  text-shadow: none !important;
  outline: none !important;
  min-height: 0 !important;
  width: 100% !important;
}
.mesh-lp-form input::placeholder { color: rgba(245,242,235,.4) !important; }
.mesh-lp-form input:focus { border-color: #6041d5 !important; background: rgba(96,65,213,.12) !important; }
.mesh-lp-emoji, input.mesh-lp-emoji { width: 60px !important; text-align: center !important; flex-shrink: 0; padding-left: 6px !important; padding-right: 6px !important; }
.mesh-lp-form-hint {
  margin: 12px 4px 0 !important;
  padding: 0 !important;
  font-size: 12px !important;
  color: rgba(245,242,235,.45) !important;
  line-height: 1.4 !important;
}

/* List ─────────────────────────────────────────────────────── */
.mesh-lp-list {
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding: 8px 12px 16px;
  flex: 1 1 auto;
  min-height: 0;
}
.mesh-lp-loading {
  padding: 32px 14px;
  text-align: center;
  font-size: 13px;
  color: rgba(245,242,235,.5);
}

/* Empty state — large "Crear mi primera lista" CTA. */
.mesh-lp-empty {
  padding: 22px 18px 14px;
  text-align: center;
}
.mesh-lp-empty-msg {
  margin: 0 0 16px !important;
  padding: 0 !important;
  font-size: 14px !important;
  color: rgba(245,242,235,.6) !important;
  line-height: 1.45 !important;
}
.mesh-lp-empty-cta,
button.mesh-lp-empty-cta {
  appearance: none !important;
  -webkit-appearance: none !important;
  font-family: 'Barlow Condensed', Impact, sans-serif !important;
  font-size: 14px !important;
  font-weight: 900 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
  text-shadow: none !important;
  text-decoration: none !important;
  background: #ffe135 !important;
  background-image: none !important;
  color: #0d0d0d !important;
  border: 0 !important;
  border-radius: 999px !important;
  padding: 12px 22px !important;
  margin: 0 auto !important;
  display: inline-flex !important;
  align-items: center !important; justify-content: center !important;
  box-shadow: none !important;
  cursor: pointer !important;
  min-height: 0 !important;
  width: auto !important; height: auto !important;
}
.mesh-lp-empty-cta:hover { background: #fff253 !important; }

/* List row — cover + name/sub + circle button. */
.mesh-lp-row,
button.mesh-lp-row {
  appearance: none !important;
  -webkit-appearance: none !important;
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  width: 100% !important;
  padding: 10px 8px !important;
  margin: 0 !important;
  font-family: inherit !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  text-align: left !important;
  text-decoration: none !important;
  text-shadow: none !important;
  color: #f5f2eb !important;
  background: transparent !important;
  background-image: none !important;
  border: 0 !important;
  border-radius: 12px !important;
  box-shadow: none !important;
  cursor: pointer !important;
  min-height: 0 !important;
  transition: background .12s ease;
}
.mesh-lp-row:hover { background: rgba(245,242,235,.05) !important; }
.mesh-lp-row:focus-visible { outline: 2px solid #6041d5 !important; outline-offset: 2px !important; }

.mesh-lp-cover {
  width: 44px !important; height: 44px !important;
  border-radius: 10px !important;
  background: linear-gradient(135deg, rgba(96,65,213,.4), rgba(255,225,53,.2)) !important;
  background-size: cover !important;
  background-position: center !important;
  display: inline-flex !important;
  align-items: center !important; justify-content: center !important;
  font-size: 20px !important;
  line-height: 1 !important;
  flex-shrink: 0 !important;
  overflow: hidden !important;
}
.mesh-lp-cover-ph { color: rgba(245,242,235,.7); font-size: 18px; }

.mesh-lp-meta {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  flex: 1 1 auto !important;
  min-width: 0 !important;
  gap: 2px !important;
}
.mesh-lp-nm {
  font-size: 15px !important;
  font-weight: 700 !important;
  line-height: 1.25 !important;
  color: #f5f2eb !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  width: 100% !important;
}
.mesh-lp-sub {
  font-size: 12px !important;
  font-weight: 500 !important;
  line-height: 1.3 !important;
  color: rgba(245,242,235,.55) !important;
}

/* The + / ✓ circle — the live commit affordance. */
.mesh-lp-pick {
  display: inline-flex !important;
  align-items: center !important; justify-content: center !important;
  width: 30px !important; height: 30px !important;
  border-radius: 50% !important;
  border: 1.5px solid rgba(245,242,235,.35) !important;
  background: transparent !important;
  color: rgba(245,242,235,.85) !important;
  font-size: 18px !important;
  font-weight: 400 !important;
  line-height: 1 !important;
  flex-shrink: 0 !important;
  transition: background .15s ease, border-color .15s ease, color .15s ease;
}
.mesh-lp-row.is-on .mesh-lp-pick {
  background: #6041d5 !important;
  border-color: #6041d5 !important;
  color: #fff !important;
}

@media (prefers-reduced-motion: reduce) {
  .mesh-lp, .mesh-lp-back, .mesh-lp-view { transition: opacity .12s ease !important; transform: none !important; }
}
