/* ── Gradient Bar ────────────────────────────── */
.gradient-bar {
  height: 32px;
  border-radius: 8px;
  position: relative;
  cursor: crosshair;
  border: 1px solid var(--color-border);
  margin: 12px 0;
}

.gradient-stop {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  border: 2px solid white;
  box-shadow: 0 1px 4px rgba(0,0,0,0.3);
  cursor: grab;
  z-index: 2;
}

.gradient-stop:active {
  cursor: grabbing;
}

.gradient-stop.active {
  border-color: var(--color-brand);
  box-shadow: 0 0 0 3px rgba(99,102,241,0.3), 0 1px 4px rgba(0,0,0,0.3);
}

/* ── Angle Picker ────────────────────────────── */
.angle-picker {
  width: 60px;
  height: 60px;
  border-radius: 50%;
  border: 2px solid var(--color-border);
  position: relative;
  cursor: pointer;
  background: var(--color-surface);
  display: inline-block;
}

.angle-picker:hover {
  border-color: var(--color-brand);
}

.angle-handle {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--color-brand);
  position: absolute;
  top: 50%;
  left: 50%;
  transform-origin: center center;
}

.angle-line {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 40%;
  height: 2px;
  background: var(--color-brand);
  transform-origin: left center;
}

/* ── Gradient Type Tabs ──────────────────────── */
.gradient-type-tabs {
  display: flex;
  gap: 4px;
  background: var(--color-bg);
  padding: 4px;
  border-radius: var(--radius-sm);
  margin-bottom: 16px;
}

.gradient-type-tab {
  flex: 1;
  padding: 8px 12px;
  font-size: 13px;
  font-weight: 600;
  text-align: center;
  border-radius: 6px;
  background: transparent;
  color: var(--color-text-secondary);
  cursor: pointer;
  transition: all 200ms;
  border: none;
}

.gradient-type-tab:hover {
  color: var(--color-text);
}

.gradient-type-tab.active {
  background: var(--color-surface);
  color: var(--color-brand);
  box-shadow: 0 1px 3px rgba(0,0,0,0.06);
}
