/*
 * PARAMOUNT PICKS — FRONTEND CSS v2.0
 * ALL rules scoped under .pp-plugin-wrap
 * Critical overrides use !important to beat theme styles
 * Dark/Light mode via [data-pp-theme] on .pp-plugin-wrap
 */

/* ── DARK (DEFAULT) ─────────────────────────────────────── */
.pp-plugin-wrap {
  --pp-bg:          #0a0a0a;
  --pp-card:        #111111;
  --pp-card-hover:  #161616;
  --pp-border:      #1e1e1e;
  --pp-gold:        #c9a227;
  --pp-gold-dim:    rgba(201,162,39,0.14);
  --pp-gold-glow:   rgba(201,162,39,0.28);
  --pp-text:        #cccccc;
  --pp-muted:       #666666;
  --pp-white:       #ffffff;
  --pp-green:       #4caf50;
  --pp-red:         #f44336;
  --pp-blue:        #2196f3;
  --pp-orange:      #ff9800;
  --pp-input-bg:    #0d0d0d;
  --pp-input-bd:    #2a2a2a;
  --pp-input-focus: rgba(201,162,39,0.15);
  --pp-shadow:      0 16px 40px rgba(0,0,0,0.5);
  --pp-radius:      14px;
  --pp-transition:  all 0.25s ease;
}

/* ── LIGHT ──────────────────────────────────────────────── */
.pp-plugin-wrap[data-pp-theme="light"] {
  --pp-bg:        #f0f0f0;
  --pp-card:      #ffffff;
  --pp-card-hover:#fafafa;
  --pp-border:    #dedede;
  --pp-gold:      #b8900f;
  --pp-gold-dim:  rgba(184,144,15,0.1);
  --pp-gold-glow: rgba(184,144,15,0.25);
  --pp-text:      #2a2a2a;
  --pp-muted:     #777777;
  --pp-white:     #111111;
  --pp-green:     #2e7d32;
  --pp-red:       #c62828;
  --pp-blue:      #1565c0;
  --pp-orange:    #e65100;
  --pp-input-bg:  #fafafa;
  --pp-input-bd:  #cccccc;
  --pp-input-focus:rgba(184,144,15,0.12);
  --pp-shadow:    0 8px 24px rgba(0,0,0,0.1);
}

/* ── BASE WRAPPER ───────────────────────────────────────── */
.pp-plugin-wrap {
  background: var(--pp-bg) !important;
  color: var(--pp-text) !important;
  font-family: 'Barlow', Arial, sans-serif !important;
  padding: 36px 20px !important;
  box-sizing: border-box !important;
  transition: background 0.3s ease, color 0.3s ease !important;
  width: 100% !important;
}
.pp-plugin-wrap *, .pp-plugin-wrap *::before, .pp-plugin-wrap *::after {
  box-sizing: border-box !important;
}

/* ── TOP TOOLBAR ────────────────────────────────────────── */
.pp-toolbar {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  flex-wrap: wrap !important;
  gap: 12px !important;
  margin-bottom: 20px !important;
}
.pp-toolbar-left { display: flex !important; align-items: center !important; gap: 14px !important; flex-wrap: wrap !important; }
.pp-toolbar-right { display: flex !important; align-items: center !important; gap: 10px !important; flex-wrap: wrap !important; }

.pp-picks-title {
  font-family: 'Bebas Neue', Impact, sans-serif !important;
  font-size: 30px !important;
  letter-spacing: 2px !important;
  color: var(--pp-white) !important;
  margin: 0 !important;
  padding: 0 !important;
  text-shadow: none !important;
  background: none !important;
  border: none !important;
  line-height: 1 !important;
}
.pp-picks-title span { color: var(--pp-gold) !important; }

/* Result count pill */
.pp-result-count {
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 1.5px !important;
  text-transform: uppercase !important;
  color: var(--pp-muted) !important;
  padding: 5px 12px !important;
  border: 1px solid var(--pp-border) !important;
  border-radius: 20px !important;
  background: transparent !important;
  white-space: nowrap !important;
}

/* Theme toggle */
.pp-theme-toggle {
  background: transparent !important;
  border: 1px solid var(--pp-border) !important;
  border-radius: 8px !important;
  padding: 8px 14px !important;
  color: var(--pp-muted) !important;
  font-family: inherit !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 1px !important;
  cursor: pointer !important;
  transition: var(--pp-transition) !important;
  white-space: nowrap !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  outline: none !important;
}
.pp-theme-toggle:hover { border-color: var(--pp-gold) !important; color: var(--pp-gold) !important; }

/* View toggle (grid / list) */
.pp-view-toggle {
  display: inline-flex !important;
  border: 1px solid var(--pp-border) !important;
  border-radius: 8px !important;
  overflow: hidden !important;
}
.pp-vt-btn {
  background: transparent !important;
  border: none !important;
  padding: 8px 12px !important;
  color: var(--pp-muted) !important;
  cursor: pointer !important;
  transition: var(--pp-transition) !important;
  font-size: 14px !important;
  line-height: 1 !important;
  outline: none !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
.pp-vt-btn + .pp-vt-btn { border-left: 1px solid var(--pp-border) !important; }
.pp-vt-btn:hover { color: var(--pp-gold) !important; background: var(--pp-gold-dim) !important; }
.pp-vt-btn.active { background: var(--pp-gold) !important; color: #000 !important; }

/* Sort dropdown */
.pp-sort-select {
  background: transparent !important;
  border: 1px solid var(--pp-border) !important;
  border-radius: 8px !important;
  padding: 8px 12px !important;
  color: var(--pp-muted) !important;
  font-family: inherit !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 1px !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  outline: none !important;
  appearance: none !important;
  -webkit-appearance: none !important;
}
.pp-sort-select option { background: #111 !important; color: #ccc !important; }
.pp-plugin-wrap[data-pp-theme="light"] .pp-sort-select option { background: #fff !important; color: #333 !important; }

/* ── FILTER PANEL ───────────────────────────────────────── */
.pp-filter-panel {
  background: var(--pp-card) !important;
  border: 1px solid var(--pp-border) !important;
  border-radius: var(--pp-radius) !important;
  padding: 18px 20px !important;
  margin-bottom: 22px !important;
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 16px !important;
  align-items: flex-end !important;
}
.pp-filter-group {
  display: flex !important;
  flex-direction: column !important;
  gap: 7px !important;
  flex: 1 !important;
  min-width: 120px !important;
}
.pp-filter-group label {
  font-size: 9px !important;
  font-weight: 800 !important;
  letter-spacing: 2.5px !important;
  text-transform: uppercase !important;
  color: var(--pp-muted) !important;
  display: block !important;
  background: none !important;
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
.pp-filter-btns { display: flex !important; flex-wrap: wrap !important; gap: 5px !important; }
.pp-filter-btn {
  font-family: inherit !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 1px !important;
  text-transform: uppercase !important;
  padding: 6px 12px !important;
  border-radius: 6px !important;
  border: 1px solid var(--pp-border) !important;
  background: transparent !important;
  color: var(--pp-muted) !important;
  cursor: pointer !important;
  transition: var(--pp-transition) !important;
  outline: none !important;
  white-space: nowrap !important;
}
.pp-filter-btn:hover { border-color: var(--pp-gold) !important; color: var(--pp-gold) !important; }
.pp-filter-btn.active { background: var(--pp-gold) !important; border-color: var(--pp-gold) !important; color: #000 !important; font-weight: 900 !important; }

.pp-filter-sel {
  font-family: inherit !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  padding: 7px 10px !important;
  border: 1px solid var(--pp-input-bd) !important;
  border-radius: 7px !important;
  background: var(--pp-input-bg) !important;
  color: var(--pp-text) !important;
  appearance: none !important;
  -webkit-appearance: none !important;
  cursor: pointer !important;
  outline: none !important;
  width: 100% !important;
  transition: border-color 0.2s !important;
}
.pp-filter-sel:focus { border-color: var(--pp-gold) !important; }
.pp-filter-sel option { background: #111 !important; color: #ccc !important; }

.pp-clear-filters {
  font-family: inherit !important;
  font-size: 10px !important;
  font-weight: 800 !important;
  letter-spacing: 1.5px !important;
  text-transform: uppercase !important;
  padding: 7px 14px !important;
  border-radius: 7px !important;
  border: 1px solid var(--pp-border) !important;
  background: transparent !important;
  color: var(--pp-muted) !important;
  cursor: pointer !important;
  transition: var(--pp-transition) !important;
  white-space: nowrap !important;
  outline: none !important;
  align-self: flex-end !important;
}
.pp-clear-filters:hover { border-color: var(--pp-red) !important; color: var(--pp-red) !important; }

/* ── PICKS GRID ─────────────────────────────────────────── */
.pp-picks-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)) !important;
  gap: 18px !important;
}

/* ── PICKS LIST ─────────────────────────────────────────── */
.pp-picks-list {
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
}

/* ── NO RESULTS ─────────────────────────────────────────── */
.pp-no-picks {
  text-align: center !important;
  padding: 60px 20px !important;
  color: var(--pp-muted) !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  border: 1px dashed var(--pp-border) !important;
  border-radius: var(--pp-radius) !important;
  background: transparent !important;
}

/* ════════════════════════════════════════════════════════════
   PICK CARD — GRID VIEW
   ════════════════════════════════════════════════════════════ */
.pp-pick-card {
  background: var(--pp-card) !important;
  border: 1px solid var(--pp-border) !important;
  border-radius: var(--pp-radius) !important;
  overflow: hidden !important;
  transition: transform 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease !important;
  position: relative !important;
  display: flex !important;
  flex-direction: column !important;
}
.pp-pick-card:hover {
  transform: translateY(-4px) !important;
  border-color: rgba(201,162,39,0.4) !important;
  box-shadow: var(--pp-shadow) !important;
}
.pp-pick-card::before {
  content: "" !important;
  display: block !important;
  height: 2px !important;
  background: linear-gradient(90deg, transparent, var(--pp-gold), transparent) !important;
  flex-shrink: 0 !important;
}

/* lock glow */
.pp-pick-card.is-lock { border-color: rgba(201,162,39,0.4) !important; box-shadow: 0 0 0 1px rgba(201,162,39,0.2) !important; }
.pp-pick-card.is-lock::before { background: var(--pp-gold) !important; }

.pp-card-head {
  padding: 13px 16px 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 8px !important;
  flex-wrap: wrap !important;
}

.pp-sport-tag {
  font-size: 10px !important;
  font-weight: 800 !important;
  letter-spacing: 1.5px !important;
  text-transform: uppercase !important;
  padding: 3px 9px !important;
  border-radius: 4px !important;
  background: var(--pp-gold-dim) !important;
  color: var(--pp-gold) !important;
  border: 1px solid rgba(201,162,39,0.22) !important;
  white-space: nowrap !important;
}

.pp-status-badge {
  font-size: 9px !important;
  font-weight: 800 !important;
  letter-spacing: 1.5px !important;
  text-transform: uppercase !important;
  padding: 3px 9px !important;
  border-radius: 10px !important;
  white-space: nowrap !important;
}
.pp-s-pending  { background: rgba(201,162,39,0.1)  !important; color: var(--pp-gold)   !important; border: 1px solid rgba(201,162,39,0.25) !important; }
.pp-s-won      { background: rgba(76,175,80,0.1)   !important; color: var(--pp-green)  !important; border: 1px solid rgba(76,175,80,0.25)  !important; }
.pp-s-lost     { background: rgba(244,67,54,0.1)   !important; color: var(--pp-red)    !important; border: 1px solid rgba(244,67,54,0.25)  !important; }
.pp-s-push     { background: rgba(33,150,243,0.1)  !important; color: var(--pp-blue)   !important; border: 1px solid rgba(33,150,243,0.25) !important; }
.pp-s-cancelled{ background: rgba(150,150,150,0.1) !important; color: var(--pp-muted)  !important; border: 1px solid rgba(150,150,150,0.2) !important; }

.pp-card-body {
  padding: 12px 16px 18px !important;
  display: flex !important;
  flex-direction: column !important;
  flex: 1 !important;
}

.pp-game-time {
  font-size: 11px !important;
  font-weight: 600 !important;
  color: var(--pp-muted) !important;
  margin-bottom: 5px !important;
  letter-spacing: 0.3px !important;
}
.pp-teams {
  font-size: 14px !important;
  font-weight: 800 !important;
  color: var(--pp-white) !important;
  margin-bottom: 10px !important;
  line-height: 1.35 !important;
}
.pp-vs { font-size: 11px !important; font-weight: 600 !important; color: var(--pp-muted) !important; }
.pp-pick-line {
  font-size: 17px !important;
  font-weight: 900 !important;
  color: var(--pp-gold) !important;
  margin-bottom: 3px !important;
  line-height: 1.2 !important;
}
.pp-pick-type-lbl {
  font-size: 10px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 1px !important;
  color: var(--pp-muted) !important;
  margin-bottom: 11px !important;
}

.pp-meta-row {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 6px !important;
  margin-bottom: 11px !important;
}
.pp-meta-pill {
  font-size: 11px !important;
  font-weight: 700 !important;
  padding: 4px 9px !important;
  border-radius: 6px !important;
  background: var(--pp-input-bg) !important;
  border: 1px solid var(--pp-border) !important;
  color: var(--pp-text) !important;
  white-space: nowrap !important;
}
.pp-meta-pill.units { color: var(--pp-blue) !important; background: rgba(33,150,243,0.07) !important; border-color: rgba(33,150,243,0.18) !important; }
.pp-meta-pill.book  { color: var(--pp-muted) !important; }

.pp-conf-low  { font-size: 12px !important; font-weight: 800 !important; color: var(--pp-orange) !important; }
.pp-conf-med  { font-size: 12px !important; font-weight: 800 !important; color: var(--pp-blue)   !important; }
.pp-conf-high { font-size: 12px !important; font-weight: 800 !important; color: var(--pp-green)  !important; }
.pp-conf-lock { font-size: 12px !important; font-weight: 800 !important; color: var(--pp-gold)   !important; }

.pp-card-div { height: 1px !important; background: var(--pp-border) !important; margin: 10px 0 !important; }

.pp-analysis-toggle {
  font-size: 10px !important;
  font-weight: 800 !important;
  letter-spacing: 1.5px !important;
  text-transform: uppercase !important;
  color: var(--pp-gold) !important;
  background: none !important;
  border: none !important;
  cursor: pointer !important;
  padding: 0 !important;
  margin-bottom: 6px !important;
  font-family: inherit !important;
  outline: none !important;
  display: block !important;
}
.pp-analysis-toggle:hover { opacity: 0.75 !important; }
.pp-analysis-body {
  display: none !important;
  font-size: 13px !important;
  color: var(--pp-text) !important;
  line-height: 1.72 !important;
  padding: 8px 0 2px !important;
}
.pp-analysis-body.open { display: block !important; }

.pp-ticket-img {
  width: 100% !important;
  border-radius: 8px !important;
  margin-top: 10px !important;
  border: 1px solid var(--pp-border) !important;
  display: block !important;
  cursor: zoom-in !important;
}

/* ════════════════════════════════════════════════════════════
   PICK CARD — LIST VIEW
   ════════════════════════════════════════════════════════════ */
.pp-picks-list .pp-pick-card {
  flex-direction: row !important;
  align-items: stretch !important;
  border-radius: 12px !important;
}
.pp-picks-list .pp-pick-card::before {
  width: 3px !important;
  height: auto !important;
  display: block !important;
  position: absolute !important;
  left: 0 !important; top: 0 !important; bottom: 0 !important;
  border-radius: 12px 0 0 12px !important;
  background: var(--pp-gold) !important;
}
.pp-picks-list .pp-card-head {
  display: none !important;
}
.pp-picks-list .pp-card-body {
  padding: 14px 18px 14px 22px !important;
  flex-direction: row !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 14px !important;
  flex: 1 !important;
}
.pp-list-col-sport  { flex: 0 0 70px !important; }
.pp-list-col-game   { flex: 1 1 200px !important; }
.pp-list-col-pick   { flex: 1 1 160px !important; }
.pp-list-col-meta   { flex: 0 0 auto !important; display: flex !important; gap: 6px !important; align-items: center !important; flex-wrap: wrap !important; }
.pp-list-col-status { flex: 0 0 auto !important; }
.pp-list-col-analysis { flex: 0 0 auto !important; }

.pp-list-label {
  font-size: 9px !important;
  font-weight: 800 !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  color: var(--pp-muted) !important;
  margin-bottom: 3px !important;
  display: block !important;
}

/* hide game time + analysis toggle in list card (shown differently) */
.pp-picks-list .pp-game-time  { font-size: 10px !important; }
.pp-picks-list .pp-teams      { margin-bottom: 2px !important; font-size: 13px !important; }
.pp-picks-list .pp-pick-line  { font-size: 15px !important; margin-bottom: 1px !important; }
.pp-picks-list .pp-pick-type-lbl { margin-bottom: 0 !important; }
.pp-picks-list .pp-meta-row   { margin-bottom: 0 !important; }
.pp-picks-list .pp-card-div   { display: none !important; }
.pp-picks-list .pp-ticket-img { max-width: 80px !important; border-radius: 6px !important; margin-top: 0 !important; }

/* ════════════════════════════════════════════════════════════
   UPLOAD FORM
   ════════════════════════════════════════════════════════════ */
.pp-form-wrap {
  max-width: 820px !important;
  margin: 0 auto !important;
}
.pp-form-card {
  background: var(--pp-card) !important;
  border: 1px solid var(--pp-border) !important;
  border-radius: 16px !important;
  overflow: hidden !important;
}
.pp-form-card-bar {
  height: 3px !important;
  background: linear-gradient(90deg, transparent, var(--pp-gold), transparent) !important;
}
.pp-form-head {
  padding: 22px 28px !important;
  border-bottom: 1px solid var(--pp-border) !important;
}
.pp-form-head h3 {
  font-family: 'Bebas Neue', Impact, sans-serif !important;
  font-size: 22px !important;
  letter-spacing: 2px !important;
  color: var(--pp-white) !important;
  margin: 0 0 3px !important;
  padding: 0 !important;
  text-shadow: none !important;
  background: none !important;
  border: none !important;
}
.pp-form-head p { font-size: 13px !important; color: var(--pp-muted) !important; margin: 0 !important; padding: 0 !important; }
.pp-form-body { padding: 28px !important; }

/* ── FORM ELEMENTS — forced to override any theme ── */
.pp-plugin-wrap .pp-f-row { margin-bottom: 18px !important; }
.pp-plugin-wrap .pp-f-label {
  display: block !important;
  font-size: 10px !important;
  font-weight: 800 !important;
  letter-spacing: 2.5px !important;
  text-transform: uppercase !important;
  color: var(--pp-muted) !important;
  margin-bottom: 7px !important;
  padding: 0 !important;
  background: none !important;
  border: none !important;
  width: auto !important;
  float: none !important;
}
.pp-plugin-wrap .pp-f-label span { color: var(--pp-gold) !important; }

.pp-plugin-wrap .pp-f-input,
.pp-plugin-wrap input.pp-f-input,
.pp-plugin-wrap .pp-f-select,
.pp-plugin-wrap select.pp-f-select,
.pp-plugin-wrap .pp-f-textarea,
.pp-plugin-wrap textarea.pp-f-textarea {
  width: 100% !important;
  background: var(--pp-input-bg) !important;
  border: 1px solid var(--pp-input-bd) !important;
  border-radius: 8px !important;
  color: var(--pp-white) !important;
  font-family: 'Barlow', Arial, sans-serif !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  padding: 12px 14px !important;
  outline: none !important;
  transition: border-color 0.25s, box-shadow 0.25s !important;
  appearance: none !important;
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  box-shadow: none !important;
  margin: 0 !important;
  display: block !important;
  float: none !important;
  min-height: unset !important;
  max-height: unset !important;
  height: auto !important;
  line-height: 1.4 !important;
}
.pp-plugin-wrap .pp-f-input:focus,
.pp-plugin-wrap input.pp-f-input:focus,
.pp-plugin-wrap .pp-f-select:focus,
.pp-plugin-wrap select.pp-f-select:focus,
.pp-plugin-wrap .pp-f-textarea:focus,
.pp-plugin-wrap textarea.pp-f-textarea:focus {
  border-color: var(--pp-gold) !important;
  box-shadow: 0 0 0 3px var(--pp-input-focus) !important;
  outline: none !important;
}
.pp-plugin-wrap .pp-f-input::placeholder,
.pp-plugin-wrap .pp-f-textarea::placeholder { color: #3a3a3a !important; }
.pp-plugin-wrap[data-pp-theme="light"] .pp-f-input::placeholder,
.pp-plugin-wrap[data-pp-theme="light"] .pp-f-textarea::placeholder { color: #aaa !important; }

.pp-plugin-wrap .pp-f-textarea { min-height: 100px !important; resize: vertical !important; }

.pp-f-grid-2 { display: grid !important; grid-template-columns: 1fr 1fr !important; gap: 14px !important; }
.pp-f-grid-3 { display: grid !important; grid-template-columns: 1fr 1fr 1fr !important; gap: 12px !important; }

/* ── CONFIDENCE BUTTONS — full override ── */
.pp-plugin-wrap .pp-conf-row {
  display: flex !important;
  gap: 8px !important;
  flex-wrap: wrap !important;
}
.pp-plugin-wrap .pp-conf-btn {
  flex: 1 !important;
  min-width: 80px !important;
  padding: 11px 8px !important;
  border-radius: 8px !important;
  border: 1px solid var(--pp-border) !important;
  background: transparent !important;
  font-family: inherit !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  letter-spacing: 1px !important;
  text-transform: uppercase !important;
  color: var(--pp-muted) !important;
  cursor: pointer !important;
  transition: var(--pp-transition) !important;
  outline: none !important;
  text-align: center !important;
  box-shadow: none !important;
  display: inline-block !important;
}
.pp-plugin-wrap .pp-conf-btn:hover {
  border-color: var(--pp-gold) !important;
  color: var(--pp-gold) !important;
  background: var(--pp-gold-dim) !important;
}
.pp-plugin-wrap .pp-conf-btn.sel {
  background: var(--pp-gold) !important;
  border-color: var(--pp-gold) !important;
  color: #000 !important;
  font-weight: 900 !important;
  box-shadow: 0 4px 14px var(--pp-gold-glow) !important;
}

/* ── SUBMIT BUTTON ── */
.pp-plugin-wrap .pp-f-submit {
  width: 100% !important;
  padding: 15px !important;
  background: var(--pp-gold) !important;
  border: none !important;
  border-radius: 8px !important;
  color: #000 !important;
  font-family: inherit !important;
  font-weight: 900 !important;
  font-size: 13px !important;
  letter-spacing: 3px !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  transition: box-shadow 0.3s, transform 0.3s !important;
  box-shadow: 0 6px 24px rgba(201,162,39,0.28) !important;
  margin-top: 6px !important;
  display: block !important;
  outline: none !important;
}
.pp-plugin-wrap .pp-f-submit:hover {
  box-shadow: 0 10px 32px rgba(201,162,39,0.42) !important;
  transform: translateY(-1px) !important;
}
.pp-plugin-wrap .pp-f-submit:disabled { opacity: 0.6 !important; cursor: not-allowed !important; transform: none !important; }

.pp-f-msg { margin-top: 12px !important; font-size: 13px !important; font-weight: 700 !important; padding: 10px 14px !important; border-radius: 8px !important; }
.pp-f-success { background: rgba(76,175,80,0.12) !important; color: var(--pp-green) !important; border: 1px solid rgba(76,175,80,0.3) !important; }
.pp-f-error   { background: rgba(244,67,54,0.12)  !important; color: var(--pp-red)   !important; border: 1px solid rgba(244,67,54,0.3)  !important; }

/* ── IMAGE LIGHTBOX ── */
.pp-lightbox {
  position: fixed !important;
  inset: 0 !important;
  background: rgba(0,0,0,0.9) !important;
  z-index: 999999 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 20px !important;
  cursor: zoom-out !important;
}
.pp-lightbox img { max-width: 100% !important; max-height: 90vh !important; border-radius: 10px !important; display: block !important; }

/* ── RESPONSIVE ── */
@media (max-width: 768px) {
  .pp-picks-grid { grid-template-columns: 1fr !important; }
  .pp-f-grid-2, .pp-f-grid-3 { grid-template-columns: 1fr !important; }
  .pp-filter-panel { flex-direction: column !important; }
  .pp-toolbar { flex-direction: column !important; align-items: flex-start !important; }
  .pp-picks-list .pp-card-body { flex-direction: column !important; align-items: flex-start !important; }
}
