/* TZ v5 B-8 — Constraints panel + placement badges. */

.cw-cp-host { margin-bottom: 16px; }

.cw-cp-empty {
  padding: 16px 14px;
  background: rgba(239, 68, 68, 0.04);
  border: 1px solid rgba(239, 68, 68, 0.18);
  border-radius: 10px;
}
.cw-cp-empty-title {
  font: 600 13.5px/1.3 "Playfair Display", Georgia, serif;
  color: rgba(255, 255, 255, 0.94);
  margin-bottom: 4px;
}
.cw-cp-empty-desc {
  font-size: 12px;
  color: rgba(255, 255, 255, 0.62);
  margin-bottom: 12px;
  line-height: 1.5;
}
.cw-cp-btn-primary {
  padding: 7px 14px;
  background: linear-gradient(145deg, rgba(239, 68, 68, 0.78), rgba(220, 38, 38, 0.78));
  border: 0;
  border-radius: 7px;
  color: #fff;
  font: 600 12.5px/1.2 inherit;
  cursor: pointer;
}
.cw-cp-btn-primary:hover { filter: brightness(1.08); }

.cw-cp-card {
  padding: 14px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 10px;
}
.cw-cp-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
}
.cw-cp-title {
  font: 600 13px/1.2 inherit;
  color: rgba(239, 68, 68, 0.88);
}
.cw-cp-btn-link {
  padding: 0;
  background: transparent;
  border: 0;
  color: rgba(255, 255, 255, 0.55);
  font: 500 11.5px/1 inherit;
  cursor: pointer;
}
.cw-cp-btn-link:hover { color: rgba(255, 255, 255, 0.95); text-decoration: underline; }
.cw-cp-btn-danger { color: rgba(239, 68, 68, 0.80); }
.cw-cp-btn-danger:hover { color: rgba(239, 68, 68, 1); }
.cw-cp-section + .cw-cp-section { margin-top: 12px; }
.cw-cp-label {
  font-size: 11px;
  color: rgba(255, 255, 255, 0.55);
  letter-spacing: 0.04em;
  margin-bottom: 5px;
}
.cw-cp-hint {
  color: rgba(255, 255, 255, 0.35);
  text-transform: none;
  font-weight: normal;
}
.cw-cp-presets {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.cw-cp-preset {
  padding: 5px 10px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.10);
  border-radius: 7px;
  color: rgba(255, 255, 255, 0.78);
  font: 500 11.5px/1.2 inherit;
  cursor: pointer;
  transition: background 100ms ease, border-color 100ms ease, color 100ms ease;
}
.cw-cp-preset:hover {
  background: rgba(245, 158, 11, 0.10);
  border-color: rgba(245, 158, 11, 0.35);
  color: rgba(255, 255, 255, 0.98);
}
.cw-cp-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.cw-cp-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 9px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.10);
  border-radius: 14px;
  cursor: pointer;
  font-size: 11.5px;
  color: rgba(255, 255, 255, 0.78);
}
.cw-cp-chip input { accent-color: rgba(245, 158, 11, 0.95); }
.cw-cp-chip input:checked + span { color: rgba(255, 255, 255, 0.98); font-weight: 500; }
.cw-cp-textarea {
  width: 100%;
  box-sizing: border-box;
  padding: 8px 10px;
  background: rgba(0, 0, 0, 0.20);
  border: 1px solid rgba(255, 255, 255, 0.10);
  border-radius: 6px;
  color: rgba(255, 255, 255, 0.92);
  font: 12.5px/1.45 inherit;
  resize: vertical;
}
.cw-cp-textarea:focus {
  outline: 2px solid rgba(245, 158, 11, 0.50);
  outline-offset: 0;
  border-color: rgba(245, 158, 11, 0.50);
}
.cw-cp-toggle {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 6px;
  font-size: 12px;
  color: rgba(255, 255, 255, 0.78);
  cursor: pointer;
}
.cw-cp-toggle input { accent-color: rgba(245, 158, 11, 0.95); }
.cw-cp-row2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.cw-cp-input {
  width: 100%;
  box-sizing: border-box;
  padding: 7px 10px;
  background: rgba(0, 0, 0, 0.20);
  border: 1px solid rgba(255, 255, 255, 0.10);
  border-radius: 6px;
  color: rgba(255, 255, 255, 0.92);
  font: 12.5px/1.3 inherit;
}
.cw-cp-status {
  margin-top: 8px;
  font-size: 10.5px;
  color: rgba(255, 255, 255, 0.40);
  text-align: right;
  min-height: 14px;
}
.cw-cp-status.is-error { color: rgba(239, 68, 68, 0.85); }

/* ─── Keyword placement badges ─────────────────────────────────── */
.cw-kwp-badge {
  display: inline-block;
  margin-left: 8px;
  padding: 1px 7px;
  border-radius: 999px;
  font: 500 10.5px/1.5 system-ui, -apple-system, sans-serif;
  letter-spacing: 0.02em;
  vertical-align: middle;
}
.cw-kwp-ok-h1 {
  background: rgba(34, 197, 94, 0.18);
  border: 1px solid rgba(34, 197, 94, 0.40);
  color: rgba(187, 247, 208, 0.96);
}
.cw-kwp-ok-h2 {
  background: rgba(34, 197, 94, 0.10);
  border: 1px solid rgba(34, 197, 94, 0.28);
  color: rgba(187, 247, 208, 0.90);
}
.cw-kwp-ok-body {
  background: rgba(245, 158, 11, 0.12);
  border: 1px solid rgba(245, 158, 11, 0.32);
  color: rgba(254, 215, 170, 0.95);
}
.cw-kwp-lost {
  background: rgba(239, 68, 68, 0.14);
  border: 1px solid rgba(239, 68, 68, 0.38);
  color: rgba(254, 202, 202, 0.95);
}
