/* ─── Sidebar Components ── Pro Terminal ─────────────────── */

/* API box */
.api-box { background: transparent; border: 1px solid var(--line); border-radius: var(--radius); padding: 10px; }
.api-row { display: flex; gap: 5px; align-items: center; margin-bottom: 5px; }
.api-row:last-child { margin-bottom: 0; }
.api-lbl { font-family: var(--mono); font-size: 8px; color: var(--text3); width: 20px; flex-shrink: 0; }
.api-in {
  flex: 1; background: var(--bg2); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 5px 8px; color: var(--text);
  font-family: var(--mono); font-size: 9px; outline: none;
  transition: border-color .18s, background .18s;
}
.api-in:focus { border-color: var(--accent); background: var(--bg3); }
.api-st {
  font-family: var(--mono); font-size: 8px;
  padding: 1px 5px; border-radius: var(--radius); flex-shrink: 0;
}
.api-st.ok { background: rgba(34,197,94,.08); color: var(--green); border: 1px solid rgba(34,197,94,.18); }
.api-st.no { background: rgba(239,68,68,.05); color: var(--text3); border: 1px solid var(--line); }
.api-suggest { display: none; font-size: 9px; color: var(--text3); margin-top: 4px; align-items: center; gap: 4px; flex-wrap: wrap; }
.api-suggest.show { display: flex; }
.api-suggest-txt { font-family: var(--mono); font-size: 8px; }
.use-key {
  font-size: 8px; padding: 1px 6px; border-radius: var(--radius); cursor: pointer;
  border: 1px solid rgba(59,130,246,.25); background: rgba(59,130,246,.06);
  color: var(--a2); font-family: var(--mono);
}
.use-key:hover { background: rgba(59,130,246,.12); }

/* Config */
.scfg { background: transparent; border: 1px solid var(--line); border-radius: var(--radius); padding: 9px; }
.cfgr { display: flex; align-items: center; justify-content: space-between; margin-bottom: 4px; }
.cfgr:last-child { margin-bottom: 0; }
.cfgr-sep { padding-top: 4px; margin-top: 3px; border-top: 1px solid var(--line); }
.cfgl { font-family: var(--sans); font-size: 10px; color: var(--text2); }
.cfgi {
  background: var(--bg2); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 3px 6px; color: var(--text); font-family: var(--mono); font-size: 9px;
  outline: none; width: 58px; text-align: center;
  transition: border-color .18s;
}
.cfgi:focus { border-color: var(--accent); }
.cfgi-val { font-family: var(--mono); font-size: 9px; color: var(--accent); }

/* Keywords */
.kw-sugg-hd {
  display: flex; align-items: center; gap: 4px; cursor: pointer;
  font-family: var(--mono); font-size: 8px; color: var(--text3);
  padding: 2px 0; margin-bottom: 2px; user-select: none;
}
.kw-sugg-hd:hover { color: var(--text2); }
.kw-sugg-arr { font-size: 7px; width: 10px; flex-shrink: 0; }
.kw-sugg-cnt {
  margin-left: auto; background: var(--bg3); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 0 4px; font-size: 7px; color: var(--text3);
}
.kwsugg-wrap { display: none; margin-bottom: 4px; }
.kwsugg-wrap.open { display: block; }
.kwsugg { display: flex; flex-wrap: wrap; gap: 2px; }
.kwsg {
  font-size: 9px; padding: 3px 7px; border-radius: var(--radius); cursor: pointer;
  background: transparent; border: 1px solid var(--line); color: var(--text2);
  transition: var(--transition); user-select: none; font-family: var(--mono);
}
.kwsg:hover { border-color: var(--a2); color: var(--a2); background: rgba(59,130,246,.04); }
.kwsg.used { opacity: .3; cursor: default; pointer-events: none; }
.kwlist { display: flex; flex-direction: column; gap: 2px; max-height: 120px; overflow-y: auto; }
.kwr {
  display: flex; align-items: center; gap: 4px;
  background: var(--bg2); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 4px 8px;
  transition: border-color .18s;
}
.kwr:focus-within { border-color: var(--a2); }
.kwi { flex: 1; background: none; border: none; outline: none; color: var(--text); font-family: var(--mono); font-size: 9px; }
.kwi::placeholder { color: var(--text3); }
.kdel { color: var(--text3); cursor: pointer; font-size: 13px; line-height: 1; background: none; border: none; padding: 0 2px; flex-shrink: 0; }
.kdel:hover { color: var(--red); }
.kwlib-t { font-size: 9px; color: var(--text3); cursor: pointer; display: flex; align-items: center; gap: 3px; margin-top: 3px; font-family: var(--mono); }
.kwlib-t:hover { color: var(--text2); }
.kwlib-p { display: none; margin-top: 3px; }
.kwlib-p.open { display: block; }
.kwsc {
  display: inline-flex; align-items: center; gap: 2px;
  font-size: 9px; padding: 2px 6px; border-radius: var(--radius); cursor: pointer;
  background: rgba(232,168,0,.06); border: 1px solid rgba(232,168,0,.18); color: var(--accent); margin: 1px;
  font-family: var(--mono);
}
.kwsx { cursor: pointer; color: var(--text3); }
.kwsx:hover { color: var(--red); }

/* AI suggestions box */
.sugbox {
  background: transparent; border: 1px solid rgba(168,85,247,.15);
  border-radius: var(--radius); padding: 9px; margin-top: 5px; display: none;
}
.sugtit { font-family: var(--mono); font-size: 7px; color: var(--purple); letter-spacing: .1em; text-transform: uppercase; margin-bottom: 4px; }
.sugchips { display: flex; flex-wrap: wrap; gap: 2px; }
.sugchip {
  font-size: 9px; padding: 3px 7px; border-radius: var(--radius); cursor: pointer;
  background: rgba(168,85,247,.04); border: 1px solid rgba(168,85,247,.12); color: var(--purple);
  transition: var(--transition); font-family: var(--mono);
}
.sugchip:hover { background: rgba(168,85,247,.08); }

/* Metrics */
.mblk { margin-bottom: 5px; }
.mrow { display: flex; justify-content: space-between; align-items: center; margin-bottom: 2px; }
.mlbl { font-family: var(--mono); font-size: 8px; color: var(--text3); text-transform: uppercase; letter-spacing: .03em; }
.mval { font-family: var(--mono); font-size: 8px; color: var(--accent); }
.mpair { display: flex; gap: 2px; }
.nin {
  width: 100%; background: var(--bg2); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 4px 6px; color: var(--text);
  font-family: var(--mono); font-size: 9px; outline: none; text-align: center;
  transition: border-color .18s;
}
.nin:focus { border-color: var(--accent); }
.nin::placeholder { color: var(--text3); }
.mwarn {
  display: none; font-size: 8px; color: var(--orange);
  padding: 3px 6px; background: rgba(245,158,11,.06);
  border: 1px solid rgba(245,158,11,.18); border-radius: var(--radius); margin-bottom: 5px; font-family: var(--mono);
}
.mwarn.show { display: block; }

/* Filter chips */
.fchips { display: flex; flex-wrap: wrap; gap: 4px; }
.fchip {
  font-size: 9px; padding: 3px 8px; border-radius: var(--radius); cursor: pointer;
  background: transparent; border: 1px solid var(--line); color: var(--text2);
  transition: var(--transition); user-select: none; font-family: var(--mono);
}
.fchip:hover { color: var(--text); border-color: var(--text3); }
.fchip.on { background: rgba(59,130,246,.06); border-color: rgba(59,130,246,.2); color: var(--a2); }
.fchip.on.rf { background: rgba(239,68,68,.04); border-color: rgba(239,68,68,.18); color: var(--red); }

/* Exchanges */
.exsrch {
  width: 100%; background: var(--bg2); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 4px 8px; color: var(--text);
  font-family: var(--mono); font-size: 9px; outline: none; margin-bottom: 6px;
  transition: border-color .18s;
}
.exsrch:focus { border-color: var(--a2); }
.ex-subhd {
  display: flex; align-items: center; justify-content: space-between;
  padding: 4px 7px; background: transparent; border: 1px solid var(--line);
  border-radius: var(--radius); cursor: pointer; user-select: none; margin-bottom: 3px;
  font-family: var(--sans); font-size: 9px; color: var(--text2);
  transition: var(--transition);
}
.ex-subhd:hover { border-color: var(--text3); color: var(--text); }
.ex-cnt { font-size: 7px; color: var(--text3); margin-left: 3px; }
.ex-section { margin-bottom: 5px; }
.exscroll { max-height: 140px; overflow-y: auto; }
.egrid { display: grid; grid-template-columns: 1fr; gap: 1px; }
.ec {
  display: flex; align-items: center; gap: 3px;
  padding: 2px 5px; border: 1px solid var(--line);
  border-radius: var(--radius); background: var(--bg3); min-height: 22px;
  transition: var(--transition);
}
.ec:hover { border-color: var(--line2); }
.ecnm { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--text2); font-size: 8px; font-family: var(--mono); }
.ect { font-size: 7px; padding: 0 3px; border-radius: 2px; background: var(--bg2); color: var(--text3); flex-shrink: 0; font-family: var(--mono); }
.ecbtns { display: flex; gap: 1px; flex-shrink: 0; }
.ecb {
  font-family: var(--mono); font-size: 7px; padding: 1px 3px;
  border-radius: 2px; cursor: pointer; border: 1px solid transparent;
  background: none; transition: var(--transition); line-height: 1.4;
}
.ecb.al { color: var(--green); border-color: rgba(34,197,94,.18); }
.ecb.al.on, .ecb.al:hover { background: rgba(34,197,94,.1); border-color: rgba(34,197,94,.35); }
.ecb.bl { color: var(--red); border-color: rgba(239,68,68,.18); }
.ecb.bl.on, .ecb.bl:hover { background: rgba(239,68,68,.1); border-color: rgba(239,68,68,.35); }

/* Countries */
.cc-body { display: none; }
.cc-body.open { display: block; }
.country-hint { font-size: 8px; color: var(--text3); font-family: var(--mono); margin-bottom: 6px; }
.cblk { margin-bottom: 6px; }
.crow { display: flex; justify-content: space-between; align-items: center; margin-bottom: 3px; }
.cnm { font-size: 9px; font-weight: 600; color: var(--text2); font-family: var(--mono); }
.cbtns { display: flex; gap: 2px; }
.cbtn {
  font-family: var(--mono); font-size: 7px; cursor: pointer;
  background: none; padding: 1px 4px; border-radius: 2px; border: 1px solid transparent; transition: var(--transition);
}
.cbtn.al { color: var(--green); border-color: rgba(34,197,94,.18); }
.cbtn.al:hover { background: rgba(34,197,94,.06); }
.cbtn.bl { color: var(--red); border-color: rgba(239,68,68,.18); }
.cbtn.bl:hover { background: rgba(239,68,68,.06); }
.cbtn.cl { color: var(--text3); border-color: var(--line); }
.cbtn.cl:hover { color: var(--text2); }
.ccgrid { display: grid; grid-template-columns: 1fr 1fr; gap: 2px; }
.cc {
  display: flex; align-items: center; gap: 3px;
  padding: 2px 4px; background: var(--bg3); border: 1px solid var(--line);
  border-radius: var(--radius); cursor: pointer; font-size: 8px; color: var(--text3);
  user-select: none; transition: var(--transition); font-family: var(--mono);
}
.cc:hover { color: var(--text2); border-color: var(--line2); }
.cc.allow { border-color: rgba(34,197,94,.35); color: var(--green); background: rgba(34,197,94,.04); }
.cc.block { border-color: rgba(239,68,68,.35); color: var(--red); background: rgba(239,68,68,.04); }

/* Empty state */
.empty {
  flex: 1; display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  text-align: center; padding: 60px;
  animation: fadeIn .2s ease;
}
.empty-icon {
  width: 48px; height: 48px;
  background: var(--bg2); border: 1px solid var(--line);
  border-radius: var(--radius-lg); display: flex; align-items: center;
  justify-content: center; font-size: 18px; margin: 0 auto 12px;
}
.empty-t { font-size: 14px; font-weight: 600; margin-bottom: 6px; font-family: var(--sans); }
.empty-s { color: var(--text3); font-size: 11px; max-width: 320px; line-height: 1.7; }

/* Blocked grid */
.blkgrid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 5px; padding: 8px; align-content: start; overflow-y: auto; flex: 1; }
.blkcard {
  background: var(--bg1); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 8px 10px;
  display: flex; align-items: center; gap: 8px;
  transition: border-color .18s, box-shadow .18s;
}
.blkcard:hover { border-color: var(--line2); box-shadow: 0 1px 3px rgba(0,0,0,.1); }
.blkav {
  width: 26px; height: 26px; border-radius: var(--radius);
  display: flex; align-items: center; justify-content: center;
  font-size: 9px; font-weight: 700; flex-shrink: 0; overflow: hidden;
}
.blkav img { width: 100%; height: 100%; object-fit: cover; border-radius: var(--radius); }
.blkrst { font-size: 9px; color: var(--a2); cursor: pointer; background: none; border: none; white-space: nowrap; font-family: var(--mono); }
.blkrst:hover { color: var(--accent); }

/* Quick-save buttons in search results */
.qa-btn { background: none; border: 1px solid var(--line); border-radius: 3px; cursor: pointer; font-size: 10px; padding: 1px 5px; opacity: 0; transition: opacity .15s, background .15s; }
tr:hover .qa-btn { opacity: 1; }
.qa-raw { color: var(--text3); }
.qa-raw:hover { background: var(--bg3); color: var(--text); }
.qa-qual { color: var(--green); border-color: rgba(34,197,94,.3); }
.qa-qual:hover { background: rgba(34,197,94,.1); }

/* Import modal */
.mo { display: none; position: fixed; inset: 0; background: rgba(0,0,0,.85); z-index: 200; align-items: center; justify-content: center; }
.mo.open { display: flex; }
.mo-box {
  background: var(--bg1); border: 1px solid var(--line);
  border-radius: var(--radius-lg); padding: 20px;
  width: 680px; max-height: 90vh; overflow-y: auto;
  box-shadow: 0 8px 32px rgba(0,0,0,.35);
  animation: fadeIn .15s ease;
  display: flex; flex-direction: column;
}
.mo-hd {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 12px; padding-bottom: 10px; border-bottom: 1px solid var(--line);
}
.mo-close { background: none; border: none; color: var(--text3); cursor: pointer; font-size: 16px; }
.mo-close:hover { color: var(--text); }
.imp-desc { font-size: 10px; color: var(--text2); margin-bottom: 10px; line-height: 1.7; }
.imp-dz {
  border: 2px dashed var(--line2); border-radius: var(--radius-lg);
  padding: 32px; text-align: center; cursor: pointer;
  background: var(--bg2); transition: var(--transition);
}
.imp-dz:hover, .imp-dz.over { border-color: var(--accent); background: rgba(232,168,0,.03); }
.imp-hint { font-family: var(--mono); font-size: 9px; color: var(--text3); margin-top: 4px; }
.imp-file-info { display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px; }
.imp-fname { font-size: 11px; font-weight: 600; }
.imp-finfo { font-family: var(--mono); font-size: 9px; color: var(--text3); }
.imp-dup-warn { padding: 5px 8px; background: rgba(232,168,0,.06); border: 1px solid rgba(232,168,0,.18); border-radius: var(--radius); margin-bottom: 8px; font-size: 10px; color: var(--accent); }
.imp-map-title { font-size: 10px; font-weight: 600; color: var(--text2); margin-bottom: 6px; }
.imp-map-wrap { overflow-y: auto; overflow-x: hidden; max-height: min(280px, 40vh); border: 1px solid var(--line); border-radius: var(--radius); flex: 1 1 auto; }
.imp-grid-hdr, .imp-grid-row { display: grid; grid-template-columns: 130px 1fr 100px; gap: 6px; align-items: center; padding: 4px 8px; }
.imp-grid-hdr { font-family: var(--mono); font-size: 7px; color: var(--text3); letter-spacing: .08em; text-transform: uppercase; background: var(--bg3); border-bottom: 1px solid var(--line2); position: sticky; top: 0; z-index: 1; padding: 5px 8px; }
.imp-grid-body { }
.imp-grid-row { border-bottom: 1px solid var(--line); font-size: 10px; }
.imp-grid-row .imp-field { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.imp-grid-row .imp-sample { font-family: var(--mono); font-size: 8px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.imp-row { display: flex; align-items: center; gap: 6px; }
.imp-arrow { color: var(--text3); font-size: 10px; flex-shrink: 0; }
.imp-match { font-size: 8px; padding: 1px 4px; border-radius: 3px; background: rgba(34,197,94,.1); color: var(--green); margin-left: 4px; }
.map-sel { width: 100%; min-width: 0; box-sizing: border-box; background: var(--bg3); border: 1px solid var(--line2); border-radius: var(--radius); color: var(--text2); font-family: var(--mono); font-size: 9px; padding: 3px 5px; cursor: pointer; outline: none; }
.map-sel:focus { border-color: var(--accent); }
.imp-actions { display: flex; gap: 6px; margin-top: 10px; padding-top: 10px; border-top: 1px solid var(--line); flex-shrink: 0; }
.imp-badge { background: rgba(0,0,0,.2); border-radius: var(--radius); padding: 0 6px; font-size: 8px; }
.imp-res-t { font-size: 13px; font-weight: 600; margin-bottom: 4px; }
.imp-res-d { font-size: 10px; color: var(--text3); }

tr.in-list { opacity: 0.6; }
tr.in-list:hover { opacity: 0.85; }

/* ─── Background Task Dock ─────────────────────────────────
   Bottom-right floating dock for long-running tasks (scrape,
   FRED, refresh). Survives panel close + tab switches. */
.bg-dock {
  position: fixed; right: 16px; bottom: 16px; z-index: 9999;
  display: none; flex-direction: column; gap: 6px;
  width: 320px; max-height: 70vh; overflow-y: auto;
  pointer-events: none;
}
.bg-dock.open { display: flex; pointer-events: auto; }
.bg-task {
  display: flex; align-items: flex-start; gap: 8px;
  padding: 8px 10px;
  background: #0e1118;
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: 0 4px 14px rgba(0,0,0,.4);
  font-family: var(--mono);
  animation: bgSlideIn .25s ease;
  position: relative;
}
.bg-task.running { border-color: rgba(232,168,0,.3); background: linear-gradient(180deg, rgba(232,168,0,.05), #0e1118); }
.bg-task.done { border-color: rgba(34,197,94,.35); background: linear-gradient(180deg, rgba(34,197,94,.06), #0e1118); }
.bg-task.error { border-color: rgba(239,68,68,.35); background: linear-gradient(180deg, rgba(239,68,68,.06), #0e1118); }
.bg-icon { width: 16px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; padding-top: 2px; }
.bg-icon .bg-tick { color: var(--green); font-weight: 700; }
.bg-icon .bg-x { color: var(--red); font-weight: 700; }
.bg-body { flex: 1; min-width: 0; }
.bg-title { font-size: 10px; font-weight: 700; color: var(--text); margin-bottom: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.bg-msg { font-size: 9px; color: var(--text3); line-height: 1.4; word-break: break-word; }
.bg-dur { color: var(--text3); opacity: .7; }
.bg-bar { height: 3px; background: var(--bg3); border-radius: 2px; overflow: hidden; margin-top: 5px; }
.bg-bar-fill { height: 100%; background: var(--accent); transition: width .3s ease; }
.bg-close {
  background: transparent; border: none; color: var(--text3); cursor: pointer;
  font-size: 13px; line-height: 1; padding: 0 2px; flex-shrink: 0;
}
.bg-close:hover { color: var(--red); }
.bg-spin {
  width: 11px; height: 11px; border-radius: 50%;
  border: 1.5px solid rgba(232,168,0,.25);
  border-top-color: var(--accent);
  display: inline-block;
  animation: bgSpin .8s linear infinite;
}
@keyframes bgSpin { to { transform: rotate(360deg); } }
@keyframes bgSlideIn { from { transform: translateY(8px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }

/* ─── Campaign cards ─────────────────────────────────────── */
.camp-card {
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 12px 14px;
  margin-bottom: 12px;
  position: relative;
  transition: border-color .25s, transform .15s;
}
.camp-card.camp-urgent { animation: campPulse 2s ease-in-out infinite; }
.camp-card.camp-finished { opacity: .65; }
.camp-card.camp-finished:hover { opacity: 1; }
.camp-card.is-collapsed .camp-collapsible { display: none; }
.camp-card.is-collapsed { padding-bottom: 10px; }
.camp-collapse-btn:hover { background: var(--bg3); }
@keyframes campPulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(239,68,68,.0); }
  50% { box-shadow: 0 0 0 4px rgba(239,68,68,.12); }
}
.camp-head { display: flex; align-items: flex-start; gap: 10px; margin-bottom: 8px; }
.camp-name {
  background: transparent; border: none; outline: none;
  font-size: 13px; font-weight: 700; color: var(--text);
  width: 100%; padding: 0; margin-bottom: 2px;
  border-bottom: 1px dashed transparent; transition: border-color .15s;
}
.camp-name:hover, .camp-name:focus { border-bottom-color: var(--line2); }
.camp-name::placeholder { color: var(--text3); font-weight: 500; }
.camp-dates { font-family: var(--mono); font-size: 9px; }
.camp-countdown {
  font-family: var(--mono); font-size: 9px; font-weight: 700;
  padding: 3px 8px; border-radius: 12px;
  border: 1px solid; white-space: nowrap;
  letter-spacing: .05em; text-transform: uppercase;
}
.camp-icon-btn {
  background: transparent; border: 1px solid var(--line); color: var(--text2);
  border-radius: 6px; padding: 2px 8px; font-size: 11px; cursor: pointer;
  font-family: var(--mono); transition: background .15s, border-color .15s;
}
.camp-icon-btn:hover { background: var(--bg2); border-color: var(--line2); }

.camp-pills { display: flex; flex-wrap: wrap; gap: 4px; margin: 6px 0 10px; }
.camp-pill {
  font-family: var(--mono); font-size: 9px; font-weight: 600;
  padding: 3px 8px; border-radius: 12px; border: 1px solid; white-space: nowrap;
}
.camp-pill-registro    { color: var(--green);  background: rgba(34,197,94,.08);   border-color: rgba(34,197,94,.25); }
.camp-pill-depositos   { color: var(--accent); background: rgba(232,168,0,.08);   border-color: rgba(232,168,0,.3); }
.camp-pill-volumen     { color: var(--a2);     background: rgba(59,130,246,.08);  border-color: rgba(59,130,246,.3); }
.camp-pill-devolucion  { color: #a855f7;       background: rgba(168,85,247,.06);  border-color: rgba(168,85,247,.3); }

.camp-metrics {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 6px;
  margin-top: 4px;
}
.camp-metric {
  background: var(--bg2); border: 1px solid var(--line); border-radius: 6px;
  padding: 6px 8px; text-align: center;
}
.camp-metric input {
  width: 100%; background: transparent; border: none; outline: none;
  color: var(--text); font-family: var(--mono); font-size: 14px; font-weight: 700;
  text-align: center; padding: 0;
}
.camp-metric input::placeholder { color: var(--text3); font-weight: 400; }
.camp-metric-lbl { font-family: var(--mono); font-size: 8px; color: var(--text3); margin-top: 2px; text-transform: uppercase; letter-spacing: .04em; }
.camp-metric-fmt { font-family: var(--mono); font-size: 8px; color: var(--accent); margin-top: 1px; }

.camp-editor {
  margin-top: 10px; padding-top: 10px;
  border-top: 1px dashed var(--line);
}
.camp-editor-row, .camp-editor-section {
  display: flex; align-items: center; gap: 6px; flex-wrap: wrap;
  margin-bottom: 8px;
}
.camp-editor-row input[type="date"], .camp-editor-section input[type="number"], .camp-editor-section input[type="text"], .camp-editor-section input:not([type]) {
  background: var(--bg2); border: 1px solid var(--line); border-radius: 6px;
  padding: 4px 8px; color: var(--text); font-family: var(--mono); font-size: 10px; outline: none;
}
.camp-editor-row input[type="date"]:focus, .camp-editor-section input:focus { border-color: var(--accent); }
.camp-type-toggle {
  display: inline-flex; align-items: center; gap: 5px;
  font-family: var(--mono); font-size: 10px; color: var(--text); font-weight: 600;
  cursor: pointer; padding: 3px 8px; border-radius: 6px;
  background: var(--bg2); border: 1px solid var(--line);
}
.camp-type-toggle input[type="checkbox"] { margin: 0; cursor: pointer; }
.camp-chk-row { display: flex; gap: 4px; flex-wrap: wrap; }
.camp-chk-chip {
  display: inline-flex; align-items: center; gap: 4px;
  font-family: var(--mono); font-size: 9px; padding: 2px 8px;
  border-radius: 12px; border: 1px solid var(--line); color: var(--text2);
  cursor: pointer; background: var(--bg2);
}
.camp-chk-chip.on { background: rgba(232,168,0,.08); border-color: rgba(232,168,0,.35); color: var(--accent); }
.camp-chk-chip input[type="checkbox"] { margin: 0; cursor: pointer; }

/* ─── Campaign Details (Bonus/Cupones/etc + pago fijo + acciones) ─── */
.camp-details {
  margin-top: 10px;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255,255,255,.015);
}
.camp-details-header {
  font-family: var(--mono); font-size: 10px; font-weight: 700;
  color: var(--text); letter-spacing: .08em; margin-bottom: 8px;
}
.camp-details-label {
  font-family: var(--mono); font-size: 9px; color: var(--text3);
  text-transform: uppercase; letter-spacing: .05em; margin-bottom: 5px;
}
.camp-kind-row { display: flex; flex-wrap: wrap; gap: 5px; margin-bottom: 12px; }
.camp-kind-chip {
  font-family: var(--mono); font-size: 10px;
  padding: 4px 12px; border-radius: 14px;
  background: var(--bg2); border: 1px solid var(--line);
  color: var(--text2); cursor: pointer;
  transition: background .15s, border-color .15s, color .15s;
  user-select: none;
}
.camp-kind-chip:hover { border-color: var(--line2); background: var(--bg3); }
.camp-kind-chip.on {
  background: rgba(232,168,0,.1);
  border-color: rgba(232,168,0,.4);
  color: var(--accent);
  font-weight: 600;
}
.camp-details-row { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-top: 4px; }
.camp-details-field { display: flex; flex-direction: column; }
.camp-details-field input {
  background: var(--bg2); border: 1px solid var(--line); border-radius: 6px;
  padding: 6px 8px; color: var(--text); font-family: var(--mono); font-size: 11px;
  outline: none; transition: border-color .15s;
}
.camp-details-field input:focus { border-color: var(--accent); background: var(--bg3); }
.camp-details-actions {
  width: 100%; min-height: 56px; resize: vertical;
  background: var(--bg2); border: 1px solid var(--line); border-radius: 6px;
  padding: 7px 9px; color: var(--text); font-family: var(--mono); font-size: 11px;
  outline: none; transition: border-color .15s; box-sizing: border-box;
}
.camp-details-actions:focus { border-color: var(--accent); background: var(--bg3); }
.camp-details-actions::placeholder { color: var(--text3); }

/* ─── Campaign card v2 — flat always-visible layout ───────── */
.camp-section-title {
  font-family: var(--mono); font-size: 9px; font-weight: 700;
  color: var(--text2); letter-spacing: .08em; text-transform: uppercase;
  margin: 14px 0 6px; padding-top: 8px; border-top: 1px solid var(--line);
}
.camp-section-title:first-of-type { border-top: none; padding-top: 0; }

/* Date row + countdown */
.camp-date-row {
  display: flex; flex-wrap: wrap; gap: 8px; align-items: stretch;
  margin: 8px 0 4px; padding: 8px 10px;
  background: var(--bg2); border: 1px solid var(--line); border-radius: 8px;
}
.camp-date-field { flex: 1 1 130px; display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.camp-date-field label { font-family: var(--mono); font-size: 8px; color: var(--text3); text-transform: uppercase; letter-spacing: .05em; }
.camp-date-field input[type="date"] {
  background: var(--bg3); border: 1px solid var(--line); border-radius: 6px;
  padding: 5px 8px; color: var(--text); font-family: var(--mono); font-size: 11px; outline: none;
  font-variant-numeric: tabular-nums; width: 100%;
}
.camp-date-field input[type="date"]:focus { border-color: var(--accent); }
.camp-countdown-block {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  border: 1px solid var(--line); border-radius: 8px;
  padding: 4px 14px; min-width: 90px;
  font-family: var(--mono);
}
.camp-countdown-num { font-size: 22px; font-weight: 800; line-height: 1; font-variant-numeric: tabular-nums; }
.camp-countdown-lbl { font-size: 8px; font-weight: 600; letter-spacing: .05em; text-transform: uppercase; margin-top: 2px; }

/* Reward category rows */
.camp-row {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
  margin-bottom: 7px;
}
.camp-row-multi { align-items: flex-start; }
.camp-row .camp-num {
  background: var(--bg2); border: 1px solid var(--line); border-radius: 6px;
  padding: 4px 8px; color: var(--text); font-family: var(--mono); font-size: 11px;
  outline: none; width: 80px; text-align: right;
}
.camp-row .camp-num:focus { border-color: var(--accent); background: var(--bg3); }
.camp-unit { font-family: var(--mono); font-size: 9px; color: var(--text3); }
.camp-text {
  background: var(--bg2); border: 1px solid var(--line); border-radius: 6px;
  padding: 5px 8px; color: var(--text); font-family: var(--mono); font-size: 10px; outline: none;
}
.camp-text:focus { border-color: var(--accent); }

/* Pago grid — wraps automatically when narrower than ~3*180px */
.camp-pay-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(170px, 1fr)); gap: 8px;
  margin-top: 4px;
}
.camp-pay-cell { display: flex; flex-direction: column; gap: 4px; padding: 8px 10px; background: var(--bg2); border: 1px solid var(--line); border-radius: 8px; }
.camp-pay-cell label { font-family: var(--mono); font-size: 8px; color: var(--text3); text-transform: uppercase; letter-spacing: .05em; }
.camp-pay-cell input {
  background: var(--bg3); border: 1px solid var(--line); border-radius: 6px;
  padding: 5px 8px; color: var(--text); font-family: var(--mono); font-size: 13px; font-weight: 600;
  outline: none; text-align: center;
}
.camp-pay-cell input:focus { border-color: var(--accent); }

/* Social actions grid — wraps automatically; 4 platforms across when wide,
   2×2 in mid widths, 1 column on mobile */
.camp-soc-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(170px, 1fr)); gap: 8px; }
.camp-soc-card {
  background: var(--bg2); border: 1px solid var(--line); border-radius: 8px;
  padding: 9px 10px; display: flex; flex-direction: column; gap: 6px;
}
.camp-soc-head { font-family: var(--mono); font-size: 10px; font-weight: 700; color: var(--text); margin-bottom: 2px; }
.camp-soc-icon { display: inline-block; margin-right: 4px; }
.camp-soc-row { display: flex; align-items: center; gap: 6px; }
.camp-soc-row label { flex: 1; font-family: var(--mono); font-size: 9px; color: var(--text3); }
.camp-soc-row input[type="number"] {
  width: 50px; background: var(--bg3); border: 1px solid var(--line); border-radius: 5px;
  padding: 3px 6px; color: var(--text); font-family: var(--mono); font-size: 11px; outline: none;
  text-align: center;
}
.camp-soc-row input[type="number"]:focus { border-color: var(--accent); }
.camp-soc-chk {
  display: flex; align-items: center; gap: 6px;
  font-family: var(--mono); font-size: 9px; color: var(--text2);
  cursor: pointer;
}
.camp-soc-chk input[type="checkbox"] { margin: 0; cursor: pointer; }

/* The auto-fit grids handle wrapping automatically; nothing else to override */

/* Category cards (no checkbox — title + body always visible).
   "on" state lights up when a sub-field is configured. */
.camp-cat {
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 8px 10px;
  margin-bottom: 7px;
  background: rgba(255,255,255,.01);
  transition: border-color .2s, background .2s;
}
.camp-cat.on {
  border-color: rgba(232,168,0,.35);
  background: rgba(232,168,0,.04);
}
.camp-cat-title {
  font-family: var(--mono); font-size: 11px; font-weight: 700;
  color: var(--text2); letter-spacing: .03em;
  margin-bottom: 6px;
}
.camp-cat.on .camp-cat-title { color: var(--text); }
.camp-cat-body {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
}
