:root {
  --cw-bg: #f5f7fa;
  --cw-surface: #ffffff;
  --cw-border: #e1e4e8;
  --cw-text: #1f2a3e;
  --cw-muted: #64748b;
  --cw-accent: #1f93ff;
  --cw-accent-hover: #1677d9;
  --cw-accent-soft: #e8f4fd;
  --cw-success: #00c853;
  --cw-warn: #ffb300;
  --cw-danger: #ef4444;
  --cw-danger-soft: #fef2f2;
  --cw-warn-soft: #fffdea;
  --cw-radius: 10px;
  --cw-radius-lg: 16px;
  --cw-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.06);
  --cw-shadow-md: 0 4px 12px rgba(0, 0, 0, 0.08);
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}

* { box-sizing: border-box; margin: 0; }
body {
  background: var(--cw-bg);
  color: var(--cw-text);
  font-size: 14px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

button, input, textarea, select { font: inherit; }
button { cursor: pointer; border: 0; }
input, textarea { outline: none; }

.shell {
  max-width: 1000px;
  margin: 0 auto;
  padding: 16px;
  display: grid;
  gap: 16px;
}

.card {
  background: var(--cw-surface);
  border: 1px solid var(--cw-border);
  border-radius: var(--cw-radius-lg);
  padding: 20px;
  box-shadow: var(--cw-shadow);
}

.header {
  background: linear-gradient(135deg, var(--cw-accent-soft), #f0f4ff);
  border-color: var(--cw-accent-soft);
  display: flex;
  gap: 16px;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
}

.header-left h1 {
  font-size: 18px;
  font-weight: 700;
  color: var(--cw-text);
}
.header-left p {
  margin-top: 4px;
  font-size: 13px;
  color: var(--cw-muted);
}
.header-pills {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 10px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 700;
  white-space: nowrap;
}
.pill-on { background: #d1fae5; color: #065f46; }
.pill-off { background: #fee2e2; color: #991b1b; }
.pill-neutral { background: var(--cw-bg); color: var(--cw-muted); }
.dot { width: 8px; height: 8px; border-radius: 50%; }
.dot-green { background: var(--cw-success); }
.dot-red { background: var(--cw-danger); }
.dot-amber { background: var(--cw-warn); }

.context-bar {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
}

.chip {
  display: inline-block;
  padding: 4px 10px;
  border: 1px solid var(--cw-border);
  border-radius: 20px;
  font-size: 12px;
  background: var(--cw-surface);
  color: var(--cw-text);
}
.chip strong { font-weight: 600; }

.ghost-button {
  padding: 8px 14px;
  border: 1px solid var(--cw-border);
  border-radius: var(--cw-radius);
  background: var(--cw-surface);
  color: var(--cw-text);
  font-size: 12px;
  font-weight: 600;
}
.ghost-button:hover { border-color: var(--cw-accent); }

.primary-button {
  width: 100%;
  padding: 10px;
  border-radius: var(--cw-radius);
  background: var(--cw-accent);
  color: #fff;
  font-weight: 700;
  font-size: 13px;
}
.primary-button:hover:not(:disabled) { background: var(--cw-accent-hover); }
.primary-button:disabled { opacity: 0.4; cursor: not-allowed; }

.secondary-button {
  width: 100%;
  padding: 10px;
  border-radius: var(--cw-radius);
  border: 1px solid var(--cw-border);
  background: var(--cw-surface);
  color: var(--cw-text);
  font-weight: 700;
  font-size: 13px;
}
.secondary-button:hover:not(:disabled) { border-color: var(--cw-accent); }
.secondary-button:disabled { opacity: 0.4; cursor: not-allowed; }

.field-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  margin-bottom: 14px;
}

label {
  display: flex;
  flex-direction: column;
  gap: 5px;
  font-size: 12px;
  font-weight: 600;
  color: var(--cw-muted);
}

input, textarea {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid var(--cw-border);
  border-radius: var(--cw-radius);
  background: var(--cw-surface);
  color: var(--cw-text);
  transition: border-color 0.15s, box-shadow 0.15s;
}
input:focus, textarea:focus {
  border-color: var(--cw-accent);
  box-shadow: 0 0 0 3px rgba(31, 147, 255, 0.1);
}

textarea { resize: vertical; min-height: 80px; }

.message {
  padding: 10px 14px;
  border-radius: var(--cw-radius);
  font-size: 13px;
  line-height: 1.6;
}
.message-warn { background: var(--cw-warn-soft); color: #92400e; border: 1px solid #fde68a; }
.message-error { background: var(--cw-danger-soft); color: #991b1b; border: 1px solid #fecaca; }
.message-success { background: #f0fdf4; color: #065f46; border: 1px solid #bbf7d0; }

.two-cols {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.1fr);
  gap: 16px;
}

.three-cols {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.section-title {
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--cw-accent);
  margin-bottom: 12px;
}

.partner-name {
  font-size: 22px;
  font-weight: 750;
  letter-spacing: -0.03em;
  margin-bottom: 8px;
}

 .partner-meta {
  color: var(--cw-muted);
  font-size: 13px;
  display: grid;
  gap: 4px;
  margin-bottom: 12px;
}

 .partner-meta strong { color: var(--cw-text); }

.variable-list {
  display: grid;
  gap: 6px;
  max-height: 280px;
  overflow: auto;
}

.var-item {
  padding: 8px 10px;
  border: 1px solid var(--cw-border);
  border-radius: var(--cw-radius);
  background: #fafbfc;
}
.var-key {
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--cw-muted);
}
.var-value {
  font-size: 13px;
  color: var(--cw-text);
  word-break: break-word;
  margin-top: 2px;
}

 .record-list {
  display: grid;
  gap: 8px;
}

.record-item {
  padding: 10px;
  border: 1px solid var(--cw-border);
  border-radius: var(--cw-radius);
}
.record-row {
  display: flex;
  gap: 8px;
  align-items: flex-start;
  justify-content: space-between;
}
.record-title {
  font-weight: 700;
  font-size: 13px;
}
.record-meta {
  font-size: 12px;
  color: var(--cw-muted);
  margin-top: 3px;
}

.empty-state {
  color: var(--cw-muted);
  font-size: 13px;
}

.loading { opacity: 0.6; pointer-events: none; }

@media (max-width: 720px) {
  .two-cols, .three-cols, .field-grid {
    grid-template-columns: 1fr;
  }
  .header { flex-direction: column; }
}
